大数乘法

作者: 编码的哲哲 | 来源:发表于2016-09-07 20:43 被阅读136次

算法爬坑之线性表大数乘法

WAI0`%JDC1P({JBR$DE{F}O.jpg

include<iostream>

include<memory.h>

include<string.h>

using namespace std;

int* multi(int* num1, int size1, int* num2, int size2){

int size = size1 + size2;
int* ret = new int[size];
int  i   = 0;

memset(ret, 0, sizeof(int) * size);


for(i = 0; i<size2; ++i){
    
    int k = i;
    for(int j = 0; j < size1; ++j){
        
        ret[k++] += num2[i] * num1[j];          
    }
    
    
}



for (i = 0; i < size; ++i){
    
    if(ret[i] >= 10){
        
        ret[i+1] += ret[i]/10;
        ret[i]   %= 10;
    }
}



return ret;

}

int main(int argc, char** argv) {

char digit1[100];
char digit2[100];

cin >> digit1 >> digit2;

int size1 = strlen(digit1);
int size2 = strlen(digit2);

int* num1 = new int[size1];
int* num2 = new int[size2];

int* currentDigit1 = new int[size1];
int* currentDigit2 = new int[size2];

for(int j = 0, jj = size1 - 1; j < size1; j++, jj--){
    
    num1[jj] = digit1[j] - '0'; 
}

for(int k = 0, kk = size2 - 1; k < size2; k++, kk--){
    
    num2[kk] = digit2[k] - '0'; 
}
    

int* ret = multi(num1, size1, num2, size2);

cout<<"求得的乘积为:"<<endl; 
for(int i = size1+size2-2; i >= 0 ; i--){
    
    cout << ret[i];
    
}

delete[] ret;
return 0;

}

相关文章

  • 大数求和

    大数求和 大数乘法

  • 大数乘法(Multiply Strings)

    大数乘法的算法 大数乘法的关键在于如何用字符串来模拟大数乘法。方法有如下几种:模拟普通的手算乘法、利用代数方法优化...

  • 大数

    大数乘法

  • 大数乘法

    大数乘法:

  • 大数乘法

    其实大数乘法就是在考虑大数加法的进位的同时,考虑字符串num1和字符串num2相乘时,每一位所在的位置,以及加法运...

  • 大数乘法

    后期需要实现分治算法,降低复杂度 测试代码 输出结果: 12345678998765 * 1234567 = 01...

  • 大数乘法

    普通大数乘法 普通大数乘法模拟两个数字竖式相乘,为了方便操作,数字的个位在数组的第0位,时间复杂度为O ( n² ...

  • 大数乘法

    算法爬坑之线性表大数乘法 include include include<...

  • 大数乘法

  • 大数乘法

    描述实现大数乘法,输入是两个字符串如n1 = '340282366920938463463374607431768...

网友评论

    本文标题:大数乘法

    本文链接:https://www.haomeiwen.com/subject/octsettx.html