//我的计算器只能计算 乘法 加法太简单了自己,拿我的程序自己去改
//可以计算最大100位乘100位的数字
//修改程序第2行的abc的数组大小可以把计算数据大小改成无限大
//所有的注释掉的输出都是在写程序的时候自己来看的
分成三部分
第一部分超大数存储 因为数据太大 超过了各种类型的存储 longlong 大概能存储20位
所以用数组来存储 每一位存入的一个数组中
例如你输入 123456789
a[0]=9
a[1]=8
a[2]=7
...
a[8]=1
第二部分 计算
用小学的方法 一个一个数去计算 a[0]*b[0]的值存入c[0]中,如果c[0]大于10 就往前进一位,然后计算a[1]*b[0] 的值 存入 c[1] 中如果大于十就进位 如此类推 挨个计算
第三部输出 这个没什么好说的 自己看程序吧
#includeusing namespace std;#includeint main (){int i,j,k,l,A,B,C;char a[100],b[100],c[200]={0};int x,y,z;//-------------------------第一个数 输入步骤------------------------------------------------cout<>a; // a[0]=1百位 a[1]=2十位 a[2]=3个位//cout<>b;//cout<=10;l++) //循环进位{//printf("第%d位为%d",k+l,c[k+l]);c[k+l]=c[k+l]%10;c[k+l+1]=x/10+c[k+l+1];x=c[k+l+1];}}}//----------------------------------输出步骤------------------------------------------------for(i=19;c[i]==0;i--) //计算结果数组的中的位数{ //printf("第%d个数字为%d\n",i,c[i]);if(c[i]==0) c[i]='\0';}//cout<
取消
评论
//我的计算器只能计算 乘法 加法太简单了自己,拿我的程序自己去改
//可以计算最大100位乘100位的数字
//修改程序第2行的abc的数组大小可以把计算数据大小改成无限大
//所有的注释掉的输出都是在写程序的时候自己来看的
分成三部分
第一部分超大数存储 因为数据太大 超过了各种类型的存储 longlong 大概能存储20位
所以用数组来存储 每一位存入的一个数组中
例如你输入 123456789
a[0]=9
a[1]=8
a[2]=7
...
a[8]=1
第二部分 计算
用小学的方法 一个一个数去计算 a[0]*b[0]的值存入c[0]中,如果c[0]大于10 就往前进一位,然后计算a[1]*b[0] 的值 存入 c[1] 中如果大于十就进位 如此类推 挨个计算
第三部输出 这个没什么好说的 自己看程序吧
#includeusing namespace std;#includeint main (){int i,j,k,l,A,B,C;char a[100],b[100],c[200]={0};int x,y,z;//-------------------------第一个数 输入步骤------------------------------------------------cout<>a; // a[0]=1百位 a[1]=2十位 a[2]=3个位//cout<>b;//cout<=10;l++) //循环进位{//printf("第%d位为%d",k+l,c[k+l]);c[k+l]=c[k+l]%10;c[k+l+1]=x/10+c[k+l+1];x=c[k+l+1];}}}//----------------------------------输出步骤------------------------------------------------for(i=19;c[i]==0;i--) //计算结果数组的中的位数{ //printf("第%d个数字为%d\n",i,c[i]);if(c[i]==0) c[i]='\0';}//cout<
取消
评论