版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、實(shí)習(xí)1 1.4長整數(shù)四則運(yùn)算實(shí)習(xí)報(bào)告題目:設(shè)計(jì)一個(gè)實(shí)現(xiàn)任意長的整數(shù)進(jìn)行加法運(yùn)算的演示程序。一、 需求分析1.本演示程序中,利用雙向循環(huán)鏈表實(shí)現(xiàn)長整數(shù)的存儲(chǔ),每個(gè)結(jié)點(diǎn)含一個(gè)整型變量任何整型變量的范圍是-(215-1)(215-1)。在每個(gè)結(jié)點(diǎn)中僅存十進(jìn)制數(shù)的4位,即不超過9999的非負(fù)整數(shù),整個(gè)鏈表表示為萬進(jìn)制數(shù)。輸入和輸出形式按中國對(duì)于長整數(shù)的習(xí)慣,每四位一組,組間用逗號(hào)隔開。 2.演示程序以用戶和計(jì)算機(jī)的對(duì)話方式執(zhí)行,即在計(jì)算機(jī)終端上顯示“提示信息”之后,由用戶在鍵盤上輸入演示程序中規(guī)定的運(yùn)算命令;相應(yīng)的輸入數(shù)據(jù)(濾去輸入數(shù)據(jù)中的非法字符)和運(yùn)算結(jié)果顯示在其后。3.程序執(zhí)行的命令包括:(1)
2、構(gòu)造鏈表;(2)輸入數(shù)據(jù);(3)數(shù)據(jù)處理;(4)結(jié)束4. 測(cè)試數(shù)據(jù)(1)0;0;應(yīng)輸出0。(2)-2345,6789;-7654,3211;應(yīng)輸出-1,0000,0000.(3)-9999,9999;1,0000,0000,0000;應(yīng)輸出9999,0000,0001(4)1,0001,0001;-1,0001,0001;應(yīng)輸出0。(5)1,0001,0001;-1,0001,0000;應(yīng)輸出1.(6)-9999,9999,9999;-9999,9999,9999;應(yīng)輸出-1,9999,9999,9998。(7)1,0000,9999,9999;1;應(yīng)輸出1,0001,0000,0000。二、
3、 概要設(shè)計(jì)struct LinkNode /定義結(jié)構(gòu)體LinkNodeint data; /記錄每個(gè)節(jié)點(diǎn)的整數(shù)(小于10000)LinkNode *next; /記錄下一個(gè)節(jié)點(diǎn)的地址LinkNode *pre; /記錄前一個(gè)節(jié)點(diǎn)的地址;class LinkList /定義類LinkListprivate:LinkNode *head0,*head1; /head0,head1分別記錄兩個(gè)整數(shù)鏈表的頭指針LinkNode *currptr;LinkNode *result; /result記錄結(jié)果鏈表的頭指針public:LinkList(); /構(gòu)造函數(shù),初始化鏈表LinkList(); /析
4、構(gòu)函數(shù),釋放空間void Creat(string a); /引入字符串,創(chuàng)立兩個(gè)鏈表,分別表示兩個(gè)整數(shù)void Add(); /實(shí)現(xiàn)兩個(gè)整數(shù)相加void Display(); /顯示結(jié)果void addtwo(); /節(jié)點(diǎn)多的作為被加數(shù),少的作為加數(shù),實(shí)現(xiàn)整 /數(shù)絕對(duì)值大的加小的;void main() /主函數(shù)do while(Yes_No='y'|Yes_No='Y'); /Yes_No不等于'Y'或'y'時(shí),程序退出三、詳細(xì)設(shè)計(jì)#include<iostream>#include<string>#i
5、nclude<math.h>using namespace std;struct LinkNodeint data; /記錄每個(gè)節(jié)點(diǎn)的整數(shù)(小于10000)LinkNode *next; /記錄下一個(gè)節(jié)點(diǎn)的地址LinkNode *pre; /記錄前一個(gè)節(jié)點(diǎn)的地址;class LinkListprivate:LinkNode *head0,*head1; /head0,head1分別記錄兩個(gè)整數(shù)鏈表的頭指針LinkNode *currptr;LinkNode *result; /result記錄結(jié)果鏈表的頭指針public:LinkList(); /構(gòu)造函數(shù),初始化鏈表LinkLis
6、t(); /析構(gòu)函數(shù),釋放空間void Creat(string a); /引入字符串,創(chuàng)立兩個(gè)鏈表,分別表示兩個(gè)整數(shù)void Add(); /實(shí)現(xiàn)兩個(gè)整數(shù)相加void Display(); /顯示結(jié)果void addtwo(); /節(jié)點(diǎn)多的作為被加數(shù),少的作為加數(shù),實(shí)現(xiàn)整 /數(shù)絕對(duì)值大的加小的;/鏈表的實(shí)現(xiàn)部分int sum(int n);LinkList:LinkList() /構(gòu)造函數(shù),初始化鏈表head0=new LinkNode; /申請(qǐng)一個(gè)空間記錄整數(shù)的符號(hào)和節(jié)點(diǎn)數(shù)head1=new LinkNode;head0->next=head0;head0->pre=head0
7、; /初始化鏈表,建立雙向循環(huán)鏈表head1->next=head1;head1->pre=head1; result=new LinkNode;result->next=result;result->pre=result;currptr=NULL;LinkList:LinkList() /析構(gòu)函數(shù),釋放空間LinkNode *p1=head0,*p2=head1,*p3=result; /三個(gè)指針分別指向三條鏈表的頭指針while(p1!=p1->pre) p1->pre->next=p1->next; p1->next->pre=
8、p1->pre; currptr=p1; p1=p1->next; delete currptr;while(p2!=p2->pre) /逐個(gè)刪除節(jié)點(diǎn),釋放空間 p2->pre->next=p2->next; p2->next->pre=p2->pre; currptr=p2; p2=p2->next; delete currptr;while(p3!=p3->pre) p3->pre->next=p3->next; p3->next->pre=p3->pre; currptr=p3; p3=
9、p3->next; delete currptr;/ delete p1;/ delete p2;/ delete p3;void LinkList:Creat(string a) /引入字符串,創(chuàng)立兩/個(gè)鏈表,分別表示兩個(gè)整數(shù)int i=0,j=0,m=0,n=0,k=0,l=0,s=0,w=0; /i記錄字符串,j記錄加數(shù)節(jié)點(diǎn)數(shù);s記錄被加數(shù)節(jié)點(diǎn)數(shù)/w標(biāo)記字符串中的-號(hào)/k記錄字符串中的字符轉(zhuǎn)化為整數(shù)的值,l使每個(gè)節(jié)點(diǎn)記錄4位while(am!='') m+; /m記錄字符串中被加數(shù)的字符數(shù) n=m; while(an!='0') n+; /n記錄字符
10、串的總字符數(shù)if(a0='-') head0->data=(-1); /記錄整數(shù)符號(hào) w=1;else head0->data=1;for(i=m-1;i>=w;i-) if(ai!=',') /把字符轉(zhuǎn)化為整數(shù) k+=(ai-'0')*sum(l); l+; if(ai=','|i=w) currptr=new LinkNode; /把整數(shù)存到雙向循環(huán)鏈表中 currptr->data=k; currptr->next=head0; currptr->pre=head0->pre; he
11、ad0->pre->next=currptr; head0->pre=currptr; head0=currptr; s+; /節(jié)點(diǎn)數(shù)加1 k=0; /重新初始化k和l l=0; head0->pre->data*=s; /存儲(chǔ)整數(shù)符號(hào)和節(jié)點(diǎn)數(shù)/與建第一個(gè)整數(shù)鏈表一樣,建立第二個(gè)整數(shù)鏈表head1k=0;l=0;if(am+1='-') head1->data=(-1); m+;else head1->data=1;for(i=n-1;i>m;i-) if(ai!=',') k+=(ai-'0')*
12、sum(l); l+; if(ai=','|i=m+1) currptr=new LinkNode; currptr->data=k; currptr->next=head1; currptr->pre=head1->pre; head1->pre->next=currptr; head1->pre=currptr; head1=currptr; j+; k=0; l=0; head1->pre->data*=j;void LinkList:Add() /實(shí)現(xiàn)兩個(gè)整數(shù)相加LinkNode *temp;if(abs(head0
13、->pre->data)>abs(head1->pre->data) /兩個(gè)整數(shù)中,絕對(duì)值大的為被加數(shù) addtwo();else if(abs(head0->pre->data)<abs(head1->pre->data) temp=head0; head0=head1; head1=temp; addtwo();else if(abs(head0->pre->data)=abs(head1->pre->data) int k1,k2; LinkNode *p=head0,*q=head1; /如果節(jié)點(diǎn)數(shù)相同
14、,則判斷節(jié)點(diǎn)中數(shù)值大小while(p->data=q->data&&p!=head0->pre->pre&&q!=head1->pre->pre) p=p->next; q=q->next; k1=p->data; k2=q->data; if(k1>k2) addtwo(); else temp=head0; head0=head1; head1=temp; addtwo(); void LinkList:addtwo() /節(jié)點(diǎn)多的作為被加數(shù),少的作為加數(shù),實(shí)現(xiàn)整數(shù)絕對(duì)值大的加小的/默認(rèn)hea
15、d0存的整數(shù)絕對(duì)值比head1大int s=0,m1=head0->data,m2=head1->data;m1=(head0->pre->data/abs(head0->pre->data); /head0的符號(hào)m2=(head1->pre->data/abs(head1->pre->data); /head1的符號(hào)LinkNode *p=head0->pre->pre,*q=head1->pre->pre;result->data=head0->pre->data; /存結(jié)果的節(jié)點(diǎn)數(shù)和符號(hào)
16、 while(q!=head1->pre) /head0存的整數(shù)絕對(duì)值比head1大,即head0的節(jié)點(diǎn)數(shù)大于或等于head1 currptr=new LinkNode; currptr->data=(p->data)*m1+(q->data)*m2+s; /兩整數(shù)相加 if(m1*m2)>0) /如果符號(hào)相同 if(abs(currptr->data)-10000>=0) /相加后超過10000,則進(jìn)位 s=currptr->data/10000; currptr->data=abs(currptr->data)%10000; el
17、se /abs(currptr->data)-10000<0,不進(jìn)位 s=0; currptr->data=abs(currptr->data); else if(m1>0&&m2<0) /符號(hào)不同,在此相當(dāng)于實(shí)現(xiàn)兩個(gè)正整數(shù)相減 s=0; if(currptr->data<0) /小于0,向前一位借1 currptr->data+=10000; s=-1; else if(m1<0&&m2>0) /符號(hào)不同,在此相當(dāng)于實(shí)現(xiàn)負(fù)整數(shù)加上正整數(shù) s=0; if(currptr->data>0
18、) /大于0, currptr->data=10000-currptr->data; s=1; else currptr->data=abs(currptr->data); currptr->next=result; /存入鏈表 currptr->pre=result->pre; result->pre->next=currptr; result->pre=currptr; result=currptr; p=p->pre; q=q->pre; /當(dāng)head0節(jié)點(diǎn)數(shù)比head1長時(shí),繼續(xù)建鏈while(p!=head0-&
19、gt;pre) currptr=new LinkNode; currptr->data=p->data*m1+s; s=currptr->data/10000; if(m1*m2)>0) if(abs(currptr->data)-10000>=0) s=currptr->data/10000; currptr->data=abs(currptr->data)%10000; else s=0;currptr->data=abs(currptr->data); else if(m1>0&&m2<0) s
20、=0; if(currptr->data<0) currptr->data+=10000; s=-1; else if(m1<0&&m2>0) s=0; if(currptr->data>0) currptr->data=10000-currptr->data; s=1; else currptr->data=abs(currptr->data); currptr->data=abs(currptr->data)%10000; currptr->next=result; currptr->
21、pre=result->pre; result->pre->next=currptr; result->pre=currptr; result=currptr; p=p->pre;if(s!=0) /處理相加后,進(jìn)位問題 currptr=new LinkNode; currptr->data=abs(s); currptr->next=result; currptr->pre=result->pre; result->pre->next=currptr; result->pre=currptr; result=currpt
22、r; result->pre->data=m1*(abs(result->pre->data)+1);void LinkList:Display() /顯示結(jié)果LinkNode *p=result;int FuHao=result->pre->data/abs(result->pre->data);/結(jié)果的符號(hào)while(p->data=0&&p!=result->pre->pre) /當(dāng)運(yùn)算后前幾個(gè)節(jié)點(diǎn)的數(shù)據(jù)為0時(shí),不輸出 p=p->next; result->pre->data=(abs(r
23、esult->pre->data)-1)*FuHao; /結(jié)果記錄非0節(jié)點(diǎn)數(shù)cout<<FuHao*p->data; /首先顯示符號(hào)和第一個(gè)節(jié)點(diǎn)中的數(shù)if(abs(result->pre->data)!=1) p=p->next; /判斷非0節(jié)點(diǎn)數(shù)是否為1while(p!=result->pre->pre) /繼續(xù)輸出 cout<<"," /每4位一組,并用,隔開 cout.width(4); cout.fill('0'); cout<<p->data; p=p->
24、;next;if(p=result->pre->pre&&abs(result->pre->data)!=1) /顯示最后一個(gè)節(jié)點(diǎn)數(shù)據(jù) cout<<"," cout.width(4); cout.fill('0'); cout<<p->data;cout<<endl;int sum(int n) /計(jì)算10的乘方int i,s=1;for(i=1;i<=n;i+) s=s*10;return s;/主函數(shù)和其他函數(shù)的實(shí)現(xiàn) void main() /主函數(shù)cout<<"*n"cout<<"*歡迎使用任意長整數(shù)加法系統(tǒng)*n"cout<<"*n""cout<<"n"cout<<"在此系統(tǒng)中,可以輸入任意長的整數(shù) 。 |n"string ch;char Yes_No;docout<<"n" cout<<"|輸入形式為:(-)*,*,*;(-)*,*,*,*|n&quo
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 鐵路工程行業(yè)的數(shù)字化轉(zhuǎn)型-洞察分析
- 2025年度高端設(shè)備維修服務(wù)合同3篇
- 網(wǎng)絡(luò)流優(yōu)化算法-洞察分析
- 約數(shù)個(gè)數(shù)與圖論聯(lián)系-洞察分析
- 裝修用工合同
- 鐵路站務(wù)流程優(yōu)化-洞察分析
- 2025年學(xué)校科研實(shí)驗(yàn)室房屋租賃及成果轉(zhuǎn)化合同3篇
- 羽絨制品智能制造工藝優(yōu)化-洞察分析
- 按份擔(dān)保擔(dān)保合同年
- KTV包間長期租賃經(jīng)營合作合同書一
- 語文-山東省2025年1月濟(jì)南市高三期末學(xué)習(xí)質(zhì)量檢測(cè)濟(jì)南期末試題和答案
- 2025年七年級(jí)下冊(cè)道德與法治主要知識(shí)點(diǎn)
- 亞馬遜項(xiàng)目合伙合同
- 蘭溪市排水防澇提升雨污管網(wǎng)修復(fù)改造初步設(shè)計(jì)文本
- 即興表演(上海電影藝術(shù)職業(yè)學(xué)院)知到智慧樹答案
- 2024解析:第一章機(jī)械運(yùn)動(dòng)-基礎(chǔ)練(解析版)
- 2024年山東省淄博市中考數(shù)學(xué)試卷(附答案)
- (正式版)HG∕T 21633-2024 玻璃鋼管和管件選用規(guī)定
- 廣告拍攝制作合同
- 電氣工作票培訓(xùn)-課件
- 2022年北京控股集團(tuán)有限公司招聘筆試題庫及答案解析
評(píng)論
0/150
提交評(píng)論