- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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;
您可能关注的文档
- 大截面矩形母线直角煨弯器制作.doc
- 大手笔-美国历史上50笔顶级并购.docx
- 大拉机连续退火机介绍.doc
- 大摩女大战当当李国庆.doc
- 大教堂布拉格公寓酒店(CathedralPragueApartments).docx
- 大数定律与抽样陷阱.doc
- 大数据,重构物流供应链.docx
- 大数据冲击下如何找准消费者.doc
- 大数据在航空业有大作为.doc
- 大数据市场到底有多少掘金潜力.doc
- 计量规程规范 JJF 2326-2025甚高频信标导航测试仪校准规范.pdf
- JJF 1274-2025运动黏度测定器校准规范.pdf
- JJF 2326-2025甚高频信标导航测试仪校准规范.pdf
- 《JJF 1274-2025运动黏度测定器校准规范》.pdf
- 计量规程规范 JJF 1274-2025运动黏度测定器校准规范.pdf
- JJF 2340-2025氰化物水质在线分析仪校准规范.pdf
- 计量规程规范 JJF 2340-2025氰化物水质在线分析仪校准规范.pdf
- 《JJF 2340-2025氰化物水质在线分析仪校准规范》.pdf
- 计量规程规范 JJF 2330-2025城镇燃气相对密度计校准规范.pdf
- JJF 2330-2025城镇燃气相对密度计校准规范.pdf
最近下载
- 人教PEP版四年级英语上册Unit 6《Meet my family》Part A 配套课件.ppt VIP
- 揭开麻城孝感乡移民发源地之谜.doc VIP
- (38)--社区禁毒服务的工作服务中心禁毒社会工作.pdf VIP
- DL_T 724-2021 电力系统用蓄电池直流电源装置运行与维护技术规程.docx VIP
- 学堂在线 大国航母与舰载机(2025秋) 作业答案.docx VIP
- 看看 ws430_原创文档.pdf VIP
- 鄂尔多斯市人才发展集团有限公司人才储备笔试历年参考题库附带答案详解.pdf
- 石家庄轻工业调查报告.doc VIP
- 2025年体育单招语文试题附答案.docx VIP
- 《中越春节风俗差异》课件.ppt VIP
原创力文档


文档评论(0)