用链表实现大数相加减.doc

用链表实现大数相加减.doc

ID:55163719

大小:144.00 KB

页数:15页

时间:2020-04-29

用链表实现大数相加减.doc_第1页
用链表实现大数相加减.doc_第2页
用链表实现大数相加减.doc_第3页
用链表实现大数相加减.doc_第4页
用链表实现大数相加减.doc_第5页
资源描述:

《用链表实现大数相加减.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、《高级语言程序设计》作业报告作业名称:大整数相加减学院计算机科学与工程学院专业计算机软件学生姓名awell任课教师xxx提交日期2012.6.28一、问题描述实现两个大整数的相加减二、系统设计1、结构说明建立结构类型node:structnode{intnum;//每个位数用一个int类型表示,其中num>=0&&num<=9;node*next;//建立单向链表,连接相邻的数字;};2、函数说明建立链表(将输入的两个数中较大的保存在fir表头的链表中):voidcreatlist(){boolfalg=false;//标记输入的两个整数是否需要进行互换;if(

2、arr1.size()-falg1>arr2.size()-falg2)//falg1表示输入的第一个整数前面的符号;falg=true;if(arr2.size()-falg2==arr1.size()-falg1){for(inti=0;iarr2[i+falg2]){falg=true;break;}if(i==arr1.size()-falg1-1)falg=f

3、alse;}}if(falg){for(inti=arr1.size()-1;i>=falg1;i--){node*s;s=newnode;s->num=arr1[i]-'0';//从输入的整数尾部逆向建立链表if(fir==NULL)fir=s;elseefir->next=s;efir=s;}efir->next=NULL;//尾结点的next一定要赋NULL,不然会出现错误for(inti=arr2.size()-1;i>=falg2;i--){node*s;s=newnode;s->num=arr2[i]-'0';if(sec==NULL)sec=s;e

4、lseesec->next=s;esec=s;}esec->next=NULL;}else{for(inti=arr2.size()-1;i>=falg2;i--){node*s;s=newnode;s->num=arr2[i]-'0';if(fir==NULL)fir=s;elseefir->next=s;efir=s;}efir->next=NULL;for(inti=arr1.size()-1;i>=falg1;i--){node*s;s=newnode;s->num=arr1[i]-'0';if(sec==NULL)sec=s;elseesec->nex

5、t=s;esec=s;}esec->next=NULL;}if(opration=='+')return;if(!falg)f=!f;//f表示整个运算结果的正负}voidadd(){//实现加法boolfalg=false;//标记是否进位intnum2=sec->num;for(node*head1=fir,*head2=sec;head1;head1=head1->next){//因为以fir为表头建立的链表所保存的整数较大,所以,以sec为表头建立的链表会先或者同时遍历到表位intnum1=head1->num;head1->num=(falg+num1

6、+num2)%10;falg=(falg+num1+num2)/10;if(head2->next){//判断以sec为表头的链表是否达到表尾head2=head2->next;num2=head2->num;}elsenum2=0;}if(f)cout<<"-";if(falg)cout<<1;inti=0;char*ans=newchar[sizeof(arr1)+sizeof(arr2)];for(node*head1=fir;head1;head1=head1->next){ans[i]=head1->num+'0';i++;}for(i--;i>=0;

7、i--)cout<num;boolfalg=false;//判是否退位for(node*head1=fir,*head2=sec;head1;head1=head1->next){intnum1=head1->num;head1->num=num1-num2-falg;if(num1-falg-num2<0){falg=true;head1->num=head1->num+10;}elsefalg=false;if(head2->next){head2=head2->next;nu

8、m2=head2->nu

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。