版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、實(shí)習(xí)題目一線性表及其應(yīng)用【問題描述】 大數(shù)運(yùn)算計(jì)算n的階乘(n=20)?!净疽蟆浚?)數(shù)據(jù)的表示和存儲; (1.1) 累積運(yùn)算的中間結(jié)果和最終的計(jì)算結(jié)果的數(shù)據(jù)類型要求是整型這是問題本身的要求; (1.2) 試設(shè)計(jì)合適的存儲結(jié)構(gòu),要求每個元素或節(jié)點(diǎn)最多存儲數(shù)據(jù)的3位數(shù)值。 (2)數(shù)據(jù)的操作及其實(shí)現(xiàn): 基于設(shè)計(jì)的存儲結(jié)構(gòu)實(shí)現(xiàn)乘法操作,要求從鍵盤上輸入n值,在屏幕上顯示最終計(jì)算結(jié)果。【實(shí)現(xiàn)提示】(1)設(shè)計(jì)數(shù)據(jù)的存儲結(jié)構(gòu): 介于階乘運(yùn)算的精確性以及實(shí)型數(shù)據(jù)表示的不精確性,本題不能采用實(shí)型表示累積運(yùn)算的中間結(jié)果和最終的計(jì)算結(jié)果,而只能用整型。然而由于普通整型和長整型所能表述數(shù)的范圍受其字長的限制,不
2、能表示大數(shù)階乘的累積結(jié)果,故必須設(shè)計(jì)一個合適的數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)對數(shù)據(jù)的存儲,例如可以讓每個元素或節(jié)點(diǎn)存儲數(shù)據(jù)的若干位數(shù)值。 從問題描述不難看出n值為任意值,故為使程序盡量不受限制,應(yīng)采用動態(tài)存儲結(jié)構(gòu)。(2) 數(shù)據(jù)的操作及其實(shí)現(xiàn): (2.1)累積運(yùn)算的特點(diǎn)是當(dāng)前的計(jì)算結(jié)果是下次乘法運(yùn)算的乘數(shù); (2.2)實(shí)現(xiàn)兩個數(shù)的乘法運(yùn)算須考慮: (1)乘數(shù)的各位數(shù)都要與被乘數(shù)進(jìn)行乘法運(yùn)算; (2)乘法過程中的進(jìn)位問題及其實(shí)現(xiàn); (3)因每個元素或節(jié)點(diǎn)最多存儲數(shù)據(jù)的3位數(shù)值,故當(dāng)元素或節(jié)點(diǎn)中的數(shù)值大于999,需向前一個元素或節(jié)點(diǎn)進(jìn)位。 【實(shí)現(xiàn)結(jié)構(gòu)】(1)采用鏈?zhǔn)酱鎯Y(jié)構(gòu)實(shí)現(xiàn)(普通單鏈表,循環(huán)單鏈表,普通雙項(xiàng)鏈表和
3、雙向循環(huán)鏈表中任選一種結(jié)構(gòu))。 (2)采用動態(tài)數(shù)組實(shí)現(xiàn)。【實(shí)現(xiàn)程序】#include stdafx.h#include using namespace std;template class Chain;templateclass ChainNodefriend Chain;private:T data;ChainNode *link;templateclass Chainpublic:Chain()first=0;Chain();bool IsEmpty()constreturn first=0;int Length()const;bool Find(int k,T&x) ;Chain&Ins
4、ert(int k,const T&x);Chain& Change(int k,T x);Chain& Delete(int k, T &x);Chain& Search(const T&x)const;int OutPut();private:ChainNode*first; ;/*析構(gòu)函數(shù)(刪除鏈表的所有節(jié)點(diǎn))*/template Chain:Chain()ChainNode*next;while(first)next=first-link;delete first;first=next;/*確定鏈表的長度*/template int Chain:Length()constChainNo
5、de*current=first;int len=0;while(current)len+;current=current-link;return len;/*在鏈表中查找第K個元素*/template bool Chain:Find(int k,T &x) ChainNode*current=first;int index=0;while(indexlink;index+;if(current) x=current-data;return true;return false;/*向鏈表中插入元素*/templateChain& Chain:Insert(int k,const T&x)Cha
6、inNode*p=first;for(int index=1;indexlink;ChainNode*y=new ChainNode;y-data=x;if(k)y-link=p-link;p-link=y;else y-link=first;first=y;return *this;/*改變鏈表第k個元素的值*/templateChain& Chain:Change(int k,T x)ChainNode *p=first;for(int index=0;p&indexlink;if (p) p-data=x;return *this;/*刪除鏈表第k個元素*/templateChain&C
7、hain:Delete(int k, T &x)if(k=0)first=first-link;elseChainNode* p = first;ChainNode* q = first;for(int index=1;indexlink;p=q-link;q-link=p-link;x=P-data;delete p;return *this;/*搜索第k個元素*/templateChain&Chain:Search(const T&x)constChainNode *current=first;int index=1;while(current & current-data !=x)cur
8、rent = current-link;index +;if(current)return index;return 0;/*倒序輸出鏈表*/templateint Chain:OutPut()ChainNode*current=first;int index=0;int len=0;while(current)len+;current=current-link;int *arry=new intlen;current=first;while(current) arryindex=current-data;current=current-link;index+;index=index-1;co
9、ut=0;index-)cout.fill(0);cout.width(3);coutarryindex;coutendl;return 0;int main()Chain A;int n,i,j,k;int l=0;A.Insert(0,1);coutplease enter a number :n;for(i=1;i=n;i+)int m=A.Length();for(j=0;jm;j+)A.Find(j,k);k=i*k;A.Change(j,k);for(j=0;j=1000)if(jm-1) A.Find(j+1,l);else A.Insert(j+1,0);l=0;l+=k/10
10、00;A.Change(j+1,l);k=k%1000;A.Change(j,k);coutLength = A .Length()endl;cout階乘為:;A.OutPut();return 0;【測試數(shù)據(jù)】 (1)n20,n!2432902008176640000 (2)n30,n!【運(yùn)行結(jié)果】實(shí)習(xí)題目二算術(shù)表達(dá)式求值【基本要求】(1)正確解釋表達(dá)式;(2)符合四則運(yùn)算規(guī)則: 先乘除、后加減 從左到右運(yùn)算先括號內(nèi),后括號外(3)輸出最后的計(jì)算結(jié)果 【實(shí)現(xiàn)關(guān)鍵】兩個棧的使用兩位數(shù)以上、負(fù)數(shù)、小數(shù)點(diǎn)?【實(shí)現(xiàn)方式】基本:控制臺程序【實(shí)現(xiàn)提示】(1)使用兩個工作棧:一個棧:存放運(yùn)算符.另一個棧:
11、存放操作數(shù)(2)運(yùn)算符之間的優(yōu)先關(guān)系可用二維數(shù)組(算符優(yōu)先順序如下:)【實(shí)現(xiàn)代碼】#include stdafx.h#include using namespace std;templateclass Stackpublic:Stack(int MaxStackSize=10);Stack()delete stack;bool IsEmpty()const return top=-1;bool IsFull()constreturn top=MaxTop;T Top()const;Stack&Add(const T &x);Stack&Delete(T&x);private:int top;i
12、nt MaxTop;T*stack;template Stack:Stack(int MaxStackSixe)MaxTop=MaxStackSixe-1;stack=new TMaxStackSixe;top=-1; templateT Stack:Top()constreturn stacktop;templateStack&Stack:Add(const T&x)stack+top=x;return *this;templateStack&Stack:Delete(T&x)x=stacktop-;return *this;/此函數(shù)用來比較兩個符號的優(yōu)先級int Comp( char le
13、ft, char right) char t9=+,-,*,/,%,(,),#;int smax99=/*+*/1,1,2,2,2,2,2,1,1, /*-*/ 1,1,2,2,2,2,2,1,1, /*/ 1,1,1,1,1,2,2,1,1, /*/*/ 1,1,1,1,1,2,2,1,1, /*%*/ 1,1,1,1,1,2,2,1,1, /*/ 1,1,1,1,1,1,2,1,1, /*(*/ 2,2,2,2,2,2,2,3,0, /*)*/ 1,1,1,1,1,1,0,1,1, /*#*/ 2,2,2,2,2,2,2,0,3; int j,k;for(int i=0;i9;i+)if(
14、left=ti)j=i;if(right=ti)k=i;switch(smaxjk)case 1:return 1;case 2:return -1;case 3:return 0;default: coutERROR!endl;return 2;double Cal(char b, char op, char a) double d=(int)b-48; double e=(int)a-48; switch(op) case +:return d+e; / 計(jì)算+ case -:return d-e; / 計(jì)算- case *:return d*e; / 計(jì)算* case /: / 計(jì)算/
15、if(e=0) cout被除數(shù)為0,有錯!endl; return false; else return d/e;default: return 0; int main() char x; Stack op;Stack k; op.Add(#); cout請輸入中綴表達(dá)式并以#結(jié)尾endl; char s20; char expr20; cin.getline(s,20); cout后綴表達(dá)式為:endl; for(int j=0;j=0&sj=9) coutsj; k.Add(sj); else if(sj!=) if(Comp(op.Top(),sj)=-1) op.Add(sj); el
16、se if(Comp(op.Top(),sj)=1) coutop.Top(); k.Add(op.Top(); op.Delete(x); op.Add(sj); if(sj=) while(op.Top()!=() coutop.Top(); k.Add(op.Top(); op.Delete(x); if(op.Top()=() op.Delete(x); if(sj=#) op.Delete(x); while(op.Top()!=#) cout=0;i-) if(expri=0&expri=9) k.Add(expri); else k.Delete(a); k.Delete(b);
17、 n=Cal(b,expri,a); m=n+0; k.Add(m); cout表達(dá)式的值為:endl; cout(double)k.Top()-48endl; return 0;【運(yùn)行結(jié)果】-實(shí)習(xí)題目三二叉樹基本算法的實(shí)現(xiàn)【功能要求】實(shí)現(xiàn)Create方法,要求鍵盤輸入二叉樹結(jié)點(diǎn)序列,創(chuàng)建一棵二叉樹(提示:前序遞歸) 實(shí)現(xiàn)SwapTree方法,以根結(jié)點(diǎn)為參數(shù),交換每個結(jié)點(diǎn)的左子樹和右子樹(提示:前序遞歸) 增加InorderTree方法,采用非遞歸方法實(shí)現(xiàn)二叉樹的中序遍歷 你可以選擇:對BinaryTree模板進(jìn)行功能擴(kuò)充;自己定義并實(shí)現(xiàn)二叉樹類要求鍵盤輸入二叉樹結(jié)點(diǎn)序列結(jié)點(diǎn)序列可以是前序,也
18、可以是層次空結(jié)點(diǎn)以#表示【代碼實(shí)現(xiàn)】#include stdafx.h#include using namespace std;templateclass BinaryTreeNode;templateclass BinaryTreepublic:BinaryTree()root=0;BinaryTree(const BinaryTree &Tree )copy(Tree.root,root);BinaryTree();bool IsEmpty()constreturn (root)?false:true);void Creat();bool Root (T&x)const;void Make
19、Tree(const T&element,BinaryTree&left,BinaryTree&right);void BreakTree( T&element,BinaryTree&left,BinaryTree&right);void PreOrder(void (*Visit)(BinaryTreeNode*u) PreOrder(Visit,root);void InOrder(void (*Visit)(BinaryTreeNode*u)InOrder(Visit,root);void PostOrder(void (*Visit)(BinaryTreeNode*u)PostOrde
20、r(Visit,root);void LevelOrder(void(*Visit)(BinaryTreeNode*u);void PreOutput() PreOrder(Output,root); coutendl;void InOutput()InOrder(Output,root); coutendl;void Postput() PostOrder(Output,root); coutendl;void LevelOutPut()LevelOrder(Output);coutendl;void Delete()PostOrder(Free,root);root=0;int Heigh
21、t()constreturn Height(root);int Size()constreturn Size(root);BinaryTreeNode*iCreat();bool equal(BinaryTree&Tree)return compare(root,Tree.root);void swap()swap(root);int leave()return leave(root);int noleave()return noleave(root);private:BinaryTreeNode*root;void PreOrder(void(*Visit)(BinaryTreeNode*u
22、),BinaryTreeNode*t);void InOrder(void(*Visit)(BinaryTreeNode*u),BinaryTreeNode*t);void PostOrder(void(*Visit)(BinaryTreeNode*u),BinaryTreeNode*t);static void Output(BinaryTreeNode* t)coutdata ;static void Free(BinaryTreeNode*t)delete t;int Height(BinaryTreeNode*t)const;int Size(BinaryTreeNode*t)cons
23、t; bool compare(BinaryTreeNode*t1,BinaryTreeNode*t2); void copy(const BinaryTreeNode*t1,BinaryTreeNode*&t2);void swap(BinaryTreeNode*t);int leave(BinaryTreeNode*t);int noleave(BinaryTreeNode*t);templateclass LinkedQueue;templateclass Nodefriend LinkedQueue;private:T data;Node*link;templateclass Link
24、edQueue public:LinkedQueue()front=rear=0;LinkedQueue();bool IsEmpty()constreturn (front)?false:true);bool IsFull()const;T First()const;T Last()const;LinkedQueue&Add(const T &x);LinkedQueue&Delete(T&x);private:Node*front;Node*rear;templatebool BinaryTree:Root(T&x)constif(root)x=root-data;return true;
25、else return false;templatevoid BinaryTree:MakeTree(const T &element ,BinaryTree&left,BinaryTree&right)root=new BinaryTreeNode(element,left.root,right.root);left.root=right.root=0;templatevoid BinaryTree:BreakTree(T&element ,BinaryTree&left,BinaryTree&right)element=root-data;left.root=root-LeftChild;
26、right.root=root-RightChild;delete root;root=0;templatevoid BinaryTree:PreOrder(void(*Visit)(BinaryTreeNode*u),BinaryTreeNode*t)if(t) Visit(t);PreOrder(Visit,t-LeftChild);PreOrder(Visit,t-RightChild);template void BinaryTree:InOrder(void(*Visit)(BinaryTreeNode*u),BinaryTreeNode*t)if(t)InOrder(Visit,t
27、-LeftChild);Visit(t);InOrder(Visit,t-RightChild);templatevoid BinaryTree:PostOrder(void(*Visit)(BinaryTreeNode*u),BinaryTreeNode*t)if(t)PostOrder(Visit,t-LeftChild);PostOrder(Visit,t-RightChild);Visit(t);templatevoid BinaryTree:LevelOrder(void(*Visit)(BinaryTreeNode*u)LinkedQueueBinaryTreeNode* Q;Bi
28、naryTreeNode*t;t=root;while(t)Visit(t);if(t-LeftChild) Q.Add(t-LeftChild);if(t-RightChild) Q.Add(t-RightChild);if(Q.IsEmpty() return ;else Q.Delete(t);templateint BinaryTree:Height(BinaryTreeNode*t)constif(!t) return 0;int hl=Height(t-LeftChild);int hr=Height(t-RightChild);if(hlhr) return +hl;else r
29、eturn +hr;templateint BinaryTree:Size(BinaryTreeNode*t)const if(!t) return 0; int sl=Size(t-LeftChild); int sr=Size(t-RightChild); return (1+sl+sr);templateBinaryTreeNode*BinaryTree:iCreat( ) T ch;cinch;BinaryTreeNode * root;if(ch=#) root=NULL;elseroot=new BinaryTreeNode;root-data=ch;root-LeftChild=
30、this-iCreat();root-RightChild=this-iCreat();return root; templatevoid BinaryTree:Creat() this-root = iCreat();templatebool BinaryTree:compare(BinaryTreeNode *t1, BinaryTreeNode *t2)if (t1=NULL&t2=NULL) return true;else if (t1!=NULL&t2=NULL) return false;else if (t1=NULL&t2!=NULL) return false;else i
31、f (t1-data!=t2-data) return false;else return (compare(t1-leftChild,t2-leftChild)&compare(t1-RightChild,t2-RightChild);templatevoid BinaryTree:copy(const BinaryTreeNode*t1,BinaryTreeNode*&t2)if(t1)t2=new BinaryTreeNode;t2-data=t1-data;copy(t1-LeftChild,t2-LeftChild);copy(t1-RightChild,t2-RightChild)
32、;templatevoid BinaryTree:swap(BinaryTreeNode *t)BinaryTreeNode *temp;if(!t) return;elsetemp=t-LeftChild;t-LeftChild=t-RightChild;t-RightChild=temp;swap(t-leftChild);swap(t-RightChild);templateint BinaryTree:leave(BinaryTreeNode*t)if(!t) return 0;if(t-LeftChild=0&t-RightChild=0)return 1;int leafl=lea
33、ve(t-LeftChild);int leafr=leave(t-RightChild); return leafl+leafr;templateint BinaryTree:noleave(BinaryTreeNode *t)if(!t) return 0;if(!t-LeftChild&!t-RightChild)return 0;int leafl=noleave(t-LeftChild);int leafr=noleave(t-RightChild);return leafl+leafr+1;templateclass BinaryTree;templateclass BinaryT
34、reeNodefriend BinaryTree;public:BinaryTreeNode()LeftChild=RightChild=0;BinaryTreeNode(const T&e)data=e;LeftChild=RightChild=0;BinaryTreeNode(const T&e,BinaryTreeNode *l,BinaryTreeNode *r)data=e;LeftChild=l;RightChild=r;private:T data;BinaryTreeNode*LeftChild,*RightChild;templateLinkedQueue:LinkedQueue()Node*next;while(front)next=front-link;delete front;front=next
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 專業(yè)無人機(jī)航拍拍攝合同文檔2024版版B版
- 2025年度智能廠區(qū)綜合環(huán)境管理服務(wù)合同4篇
- 個人保險理賠服務(wù)合同(2024版)3篇
- 二零二五年度廠房出租合同附設(shè)備故障應(yīng)急響應(yīng)及維修服務(wù)協(xié)議3篇
- 2025年新型智能化廠房土地購置與使用權(quán)合同4篇
- 2025年度二零二五智能家居攤位租賃及智慧城市建設(shè)合同4篇
- 2024陸運(yùn)運(yùn)輸合同能源消耗與碳排放管理協(xié)議2篇
- 二零二五年度電視劇編劇助理及劇本構(gòu)思與討論合同3篇
- 2025年度商業(yè)地產(chǎn)物業(yè)運(yùn)營與管理服務(wù)合同2篇
- 2024年04月重慶銀行科技部招考筆試歷年參考題庫附帶答案詳解
- 使用錯誤評估報(bào)告(可用性工程)模版
- 公司章程(二個股東模板)
- GB/T 19889.7-2005聲學(xué)建筑和建筑構(gòu)件隔聲測量第7部分:樓板撞擊聲隔聲的現(xiàn)場測量
- 世界奧林匹克數(shù)學(xué)競賽6年級試題
- 藥用植物學(xué)-課件
- 文化差異與跨文化交際課件(完整版)
- 國貨彩瞳美妝化消費(fèi)趨勢洞察報(bào)告
- 云南省就業(yè)創(chuàng)業(yè)失業(yè)登記申請表
- UL_標(biāo)準(zhǔn)(1026)家用電器中文版本
- 國網(wǎng)三個項(xiàng)目部標(biāo)準(zhǔn)化手冊(課堂PPT)
- 快速了解陌生行業(yè)的方法論及示例PPT課件
評論
0/150
提交評論