1

配列を使用して、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;
4

3 に答える 3

0

ベクターにスペースを割り当てるy

vector<int> y(n,0); //n = max of N.size() & a.size()

else {
    y[k] = N[i];
    i++; // Should be i--
    k++;

}
于 2013-08-16T18:41:02.727 に答える
-1

含まれていvectorますか?

また、コンパイラの出力を教えてください。

于 2013-08-16T18:42:07.407 に答える