配列を使用して、2 つの大きな正の整数を減算しようとしました。しかし、以下のコードを実行すると、g++ (Ubuntu) で実行するとセグメンテーション エラー (コア ダンプ) が発生します。
Subtract numbers using arrays - C++およびSubtracting two long positive integers in a array c++に従いましたが、これらから多くの助けを見つけることができませんでした。
int main() {
vector <int> N;
vector <int> a;
vector <int> y;
char digit1;
int l;
do {
cin.get(digit1);
if (digit1 != (int)
'\n')
N.push_back(int(digit1) - int('0'));
} while (digit1 != (int)
'\n');
char digit2;
do {
cin.get(digit2);
if (digit2 != (int)
'\n')
a.push_back(int(digit2) - int('0'));
} while (digit2 != (int)
'\n');
int i = N.size() - 1;
int j = a.size() - 1;
int k = 0;
do {
if (j >= 0) {
if (N[i] < a[j]) {
y[k] = N[i] + 10 - a[j];
l = i - 1;
while (N[l] == 0) {
N[l] = 9;
l--;
}
N[l] = N[l] - 1;
} else {
y[k] = N[i] - a[j];
}
i--;
j--;
k++;
} else {
y[k] = N[i];
i++;
k++;
}
} while (i >= 0);
for (int m = y.size() - 1; m >= 0; m--) {
cout << y[m];
}
return 0;