大整数乘法--C++.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
大整数乘法--C

大整数乘法 仅供参考 #include #include using namespace std; void MUL_max string a,int la,string b,int lb,int **c ;//相乘函数 void ADD_max int * d,int **c,int la,int lb ;//相加函数 char * ZhuanH string ; void main string a; string b; int **c NULL; int *d NULL; int la 0,lb 0; int i 0,j 0,k 0; cout ************大整数乘法************** endl; cout 请输入乘数:; cin a; cout 请输入被乘数:; cin b; la a.length ; lb b.length ; //分配2维C数组,存储数组a和b的乘积 c new int*[la]; for k 0;k la;k++ c[k] new int[lb+1]; //分配数组d用于存储最终结果 d new int[la+lb+1]; for i 0;i la+lb+1;i++ //初始化,便于后面判断相加后的有效位数 d[i] 0; //初始化数组C,便于后面判断相加后的有效位数 for i 0;i la;i++ for j 0;j lb;j++ c[i][j] 0; //调用函数 MUL_max a,la,b,lb,c ; ADD_max d,c,la,lb ; k 0; cout a 和 b 相乘结果是: endl; for i 0;i la+lb;i++ if d[i] 0 k++; else break; for i k;i la+lb;i++ cout d[i]; cout endl; for int n 0;n lb;n++ delete c[n]; delete[la] c; delete [] d; void MUL_max string a,int la,string b,int lb,int **c int mid 0,i 0,j 0; int k 0; int num_a 0,num_b 0; char *char_a NULL,*char_b NULL; char_a ZhuanH a ;//将String转化为插入* char_b ZhuanH b ; //开始循环相乘la*lb次 for i la-1;i 0;i-- for j lb-1;j 0;j-- num_a a[i]-48; num_b b[j]-48; if k num_a*num_b 10 //判断乘积是否有进位 if mid! 0 //判断前一次相乘是否有进位 c[i][j+1] k%10+mid; else c[i][j+1] k%10; mid k/10; else//没有进位 if mid! 0 //判断前一次相乘是否有进位 c[i][j+1] k+mid; else c[i][j+1] k; mid 0; if mid! 0 c[i][0] k/10;//如果乘数个位和被乘数相乘,最后有进位 //数组相加函数 void ADD_max int *d,int **c,int la,int lb int i 0,j 0; int mid 0; int num_a 0,num_b 0; int add 0,midnum 0; //将相乘得到的二维数组C各行错位相加,得到一位数组d for i la-1;i 0;i-- for j lb;j 0;j-- num_a d[i+j+1]; num_b c[i][j]; add num_a+num_b; if add 10 //判断相加是否有进位 if midnum 1 d[i+j+1] add%10+1; else d[i+j+1] add%10; midnum 1; else d[i+j+1] add; midnum 0; if midnum 1 d[0] add/10; //转化函数 char * ZhuanH string src char *dst new char[255]; int i; for i 0;i src.length ;i++ dst[i] src[i]; dst[i] \0; return dst;

文档评论(0)

haocen + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档