Product //大数相乘 客官°小女子只卖身不卖艺 2022-08-06 00:28 120阅读 0赞 #include <stdio.h> #include <string.h> #define N 1000 void yiwei(char *ch, int a); void add(char *ch1, char *ch2); void rev(char *ch); int main() { char ch1[N], ch2[N], ch3[N], ch4[N]; int i, j, k; while(scanf("%s %s", ch1, ch2) != -1) { rev(ch1);rev(ch2); memset(ch4, 0, sizeof(ch4)); for( i=0; ch1[i]!=0; i++) { memset(ch3, 0, sizeof(ch3)); for( j=0; ch2[j]!=0; j++) //ch3中存的是对应位乘积+1,不加1可能为0了。 { ch3[j] = (ch1[i]-'0')*(ch2[j]-'0')+1; } for( k=0; ch3[k]; k++) { if(ch3[k]-1 > 9) { if(!ch3[k+1]) { ch3[k+1] += (ch3[k]-1)/10+1; ch3[k] = (ch3[k]-1)%10+1; } else { ch3[k+1] += (ch3[k]-1)/10; ch3[k] = (ch3[k]-1)%10+1; } } } k = 0; while(ch3[k]) { ch3[k] = ch3[k]-1+'0'; k++; } yiwei(ch3, i); add(ch4, ch3); } rev(ch4); if(ch4[0]=='0') ch4[1] = 0; printf("%s\n", ch4); } return 0; } void yiwei(char *ch, int a) { int len, i; len = strlen(ch); for( i=len+a; i>=a; i--) { ch[i] = ch[i-a]; } for(i=0; i<a; i++) ch[i] = '0'; } void add(char *ch1, char *ch2) { int i = 0; while(ch1[i] || ch2[i]) { if(!ch1[i] || !ch2[i]) ch1[i] = ch1[i]+ch2[i]; else ch1[i] = ch1[i]+ch2[i]-'0'; i++; } i = 0; while(ch1[i]) { if(ch1[i] > '9') { if(!ch1[i+1]) { ch1[i+1] += (ch1[i]-'0')/10+'0'; ch1[i] = '0'+(ch1[i]-'0')%10; } else { ch1[i+1] += (ch1[i]-'0')/10; ch1[i] = '0'+(ch1[i]-'0')%10; } } i++; } } void rev(char *ch) { int len, i; char ch1[N]; len = strlen(ch); for(i=0; i<len; i++) ch1[len-i-1] = ch[i]; for(i=0; i<len; i++) ch[i] = ch1[i]; }
相关 大数相乘 一、背景 最近在看算法的时候发现了一个问题,我们都知道方法的形参是要指定类型的,假如有以下方法 public int example(int a,int b){ 傷城~/ 2022年09月30日 13:55/ 0 赞/ 209 阅读
相关 大数相乘 参考地址:[http://www.cnblogs.com/heyonggang/p/3599857.html][http_www.cnblogs.com_heyonggang_ 悠悠/ 2022年08月20日 06:29/ 0 赞/ 190 阅读
相关 大数相乘 [用分治法实现大数乘法,加法,减法(java实现)][java] 大数乘法即多项式乘法问题,求A(x)与B(x)的乘积C(x),朴素解法的复杂度O 小咪咪/ 2022年08月19日 15:12/ 0 赞/ 186 阅读
相关 大数相乘 无意中看到一个华为面试题,使用代码计算[1234567891011121314151617181920\2019181716151413121110987654321][123 系统管理员/ 2022年08月11日 20:29/ 0 赞/ 194 阅读
相关 Product //大数相乘 include <stdio.h> include <string.h> define N 1000 void yiwei(char 客官°小女子只卖身不卖艺/ 2022年08月06日 00:28/ 0 赞/ 121 阅读
相关 大数相乘 题目:请使用代码计算1234567891011121314151617181920\2019181716151413121110987654321。 答: ![复制代码][ Bertha 。/ 2022年08月05日 08:54/ 0 赞/ 205 阅读
相关 大数相乘 在这之前我们先来了解一下Java 中每种基本数据类型所占存储空间的大小。其中 1Byte = 8bit。 <table> <tbody> <tr> <th> 朱雀/ 2022年06月02日 02:36/ 0 赞/ 253 阅读
相关 大数相乘 设X和Y是n位的二进制整数,现在要计算X\Y的结果 将a和b分为两段,每段长均为总长的1/2, ![20180329214901958][] 拼搏现实的明天。/ 2022年05月28日 05:06/ 0 赞/ 215 阅读
相关 大数相乘 题目 编写两个任意位数的大数相乘的程序,给出计算结果。比如: > 题目描述: 输出两个不超过100位的大整数的乘积。 > 输入: 输入两个大整数,如1234567 今天药忘吃喽~/ 2022年05月23日 11:23/ 0 赞/ 336 阅读
相关 大数相乘 def fun(num1,num2): num1 type str num2 type str a = map(int, 落日映苍穹つ/ 2021年10月24日 01:48/ 0 赞/ 330 阅读
还没有评论,来说两句吧...