基础算法模板———基础类——高精度乘法(高精度乘高精度)

数字存储采用vector
例如123456789存储为987654321
低位在前高位在后

vector<int> mul(const vector<int> &A, const vector<int> &B) {
    
    
    vector<int> C(A.size() + B.size());
    for (int i = 0; i < A.size(); i++) {
    
    
        for (int j = 0; j < B.size(); j++) {
    
    
            C[i + j] += A[i] * B[j];
        }
    }
    int t = 0;
    for (int i = 0; i < C.size(); i++) {
    
    
        t += C[i];
        C[i] = t % 10;
        t /= 10;
    }
    while (C.size() > 1 && C.back() == 0) C.pop_back();
    return C;
}

解释先欠着,有时间了再补吧

猜你喜欢

转载自blog.csdn.net/qq_36738806/article/details/126619888