版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p><b> 多維數(shù)組</b></p><p> 計(jì)算機(jī)與通信工程學(xué)院</p><p><b> 目錄</b></p><p><b> 第一部分 需求分析</b></p&g
2、t;<p> 1.1程序設(shè)計(jì)的任務(wù)2</p><p> 1.2程序達(dá)到的功能2</p><p> 1.3程序功能模塊圖和流程圖2</p><p><b> 1.4測(cè)試數(shù)據(jù)3</b></p><p><b> 第二部分 詳細(xì)設(shè)計(jì)</b></p><p
3、> 2.1用到的數(shù)據(jù)類型和數(shù)據(jù)結(jié)構(gòu)定義4</p><p> 2.2各個(gè)函數(shù)的基本操作和功能4</p><p> 2.3各個(gè)函數(shù)的調(diào)用關(guān)系5</p><p> 2.4主程序思路5</p><p><b> 第三部分 調(diào)試分析</b></p><p> 3.1遇到的問(wèn)題及解決
4、過(guò)程6</p><p> 3.2設(shè)計(jì)過(guò)程中學(xué)到的知識(shí)7</p><p> 3.3經(jīng)驗(yàn)與體會(huì)7</p><p><b> 第四部分 用戶手冊(cè)</b></p><p> 4.1每一步驟的注釋說(shuō)明7</p><p><b> 4.2整體思路7</b></p
5、><p><b> 第五部分 測(cè)試結(jié)果</b></p><p><b> 5.1測(cè)試結(jié)果8</b></p><p> 5.2附錄-程序源碼9</p><p><b> 第一部分 需求分析</b></p><p> 1.1程序設(shè)計(jì)的任務(wù)</
6、p><p><b> 1.1.1問(wèn)題描述</b></p><p> 設(shè)計(jì)并模擬實(shí)現(xiàn)整型多維數(shù)組類型。</p><p> 1.1.2 基本要求</p><p> 設(shè)計(jì)并模擬實(shí)現(xiàn)多維數(shù)組類型。整型多維數(shù)組應(yīng)具有以下基本功能:</p><p> (1) 定義整型多維數(shù)組類型,各維的下標(biāo)是任意整數(shù)開(kāi)
7、始的連續(xù)整數(shù)。</p><p> (2) 下標(biāo)變量賦值,執(zhí)行下標(biāo)范圍檢查。</p><p> (3) 同類型數(shù)組賦值。</p><p> (4) 子數(shù)組賦值,例如 ,a[1..n]=a [2..n+1];a[2..4][3..5]=b[1..3][2..4]。</p><p> (5) 確定數(shù)組的大小。</p><
8、p><b> 1.1.3選作內(nèi)容</b></p><p> (1) 各維的下標(biāo)是任意字符開(kāi)始的連續(xù)字符。</p><p> (2) 數(shù)組初始化。</p><p> (3) 可修改數(shù)組的下標(biāo)范圍。</p><p> 1.2程序達(dá)到的功能</p><p> (1) 定義整型多維數(shù)組結(jié)
9、構(gòu)體,并定義各維的的結(jié)構(gòu)體。</p><p> (2) 下標(biāo)變量賦值。</p><p> (3) 同類型數(shù)組賦值,不同類型賦值時(shí)檢查出錯(cuò)誤。</p><p> (4) 子數(shù)組賦值,例如 a[1..n]=a [2..n+1];a[2..4][3..5]=b[1..3][2..4]。</p><p> (5) 確定數(shù)組的大小。</p
10、><p> (6) 數(shù)組初始化。</p><p> (7) 可修改數(shù)組的下標(biāo)。</p><p> 1.3程序功能模塊圖和流程圖</p><p> 圖1 程序功能模塊圖</p><p><b> 圖2. 程序流程圖</b></p><p><b> 1.4
11、測(cè)試數(shù)據(jù)</b></p><p> 多維數(shù)組a:三維;下標(biāo)[1**2][2**3][3**5];賦值:1 2 3 4 5 6 7 8 9 10 11 12</p><p> 多維數(shù)組b:兩維;下標(biāo)[1**2][2**3];賦值:1 2 3 4</p><p> 多維數(shù)組c;三維;下標(biāo)[2**3][3**4][4**6];賦值:2 3 4 5
12、6 7 8 9 10 11 12</p><p> 查找下標(biāo):a[2][3][4],a[1][3][5];替換值為原數(shù)值的復(fù)制,例如6改為66</p><p> 修改第2維的下標(biāo),保證原來(lái)數(shù)組個(gè)數(shù)不變</p><p><b> 第二部分 詳細(xì)設(shè)計(jì)</b></p><p> 2.1 用到的數(shù)據(jù)類型和數(shù)據(jù)結(jié)構(gòu)定
13、義</p><p> 2.1.1第幾維數(shù)組的結(jié)構(gòu)體定義</p><p> typedef struct{</p><p> ElemType lower; //定義每維數(shù)組的下界 </p><p> ElemType upper; //定義每維數(shù)組的上界</p><p> int boundnum; //定
14、義每維數(shù)組中元素的個(gè)數(shù) </p><p> }Boundi; //定義第i維數(shù)組</p><p> 2.1.2 多維數(shù)組結(jié)構(gòu)體的定義</p><p> typedef struct{</p><p> int dim; //定義多維數(shù)組的維數(shù) </p><p>
15、 Boundi bound[MAXDIM]; //定義第i維數(shù)組</p><p> int total; //定義數(shù)組中元素的個(gè)數(shù) </p><p> int elem[MAXTOTAL]; //數(shù)組中每個(gè)元素的地址,其中elem[0]為該多維數(shù)組的基址</p><p> }NArray;
16、//定義多維數(shù)組</p><p> 2.2各個(gè)函數(shù)的基本操作及功能</p><p> 2.2.1 NArray CreatArray();多維數(shù)組創(chuàng)建并初始化函數(shù)</p><p> 2.2.2 int Replace(NArray &A,NArray &B);兩個(gè)數(shù)組復(fù)制的函數(shù)</p><p> 2.2.3 void
17、AdjustBound(NArray &A);修改下標(biāo)的函數(shù)</p><p> 2.2.4 void FindSwap(NArray &A);查找并替換的函數(shù)</p><p> 2.2.5 void PrintArray(NArray A);打印輸出函數(shù)</p><p> 2.2.6 int main();主函數(shù)</p><
18、p> 圖3.程序子函數(shù)主函數(shù)截圖</p><p> 2.3 各個(gè)函數(shù)之間的調(diào)用關(guān)系</p><p> 圖4. 各個(gè)函數(shù)之間的調(diào)用關(guān)系</p><p><b> 2.4 主程序思路</b></p><p> 圖5.主程序思路流程圖</p><p><b> 第三部分 調(diào)試
19、分析</b></p><p> 3.1 遇到的問(wèn)題及解決過(guò)程</p><p> 3.1.1、在replace函數(shù)(即數(shù)組替換函數(shù))中,當(dāng)執(zhí)行替換循環(huán)時(shí),代碼如下:</p><p> for(i=0;i<A.total;i++){</p><p> B.elem[i]=A.elem[i]; //把多維數(shù)組A賦值給B
20、 </p><p><b> }</b></p><p> cout<<"********賦值成功********"<<endl; </p><p><b> return 0;</b></p><p> 把return 0;放到了for循環(huán)里了
21、。結(jié)果只a數(shù)組中只把第一個(gè)元素賦值給了c數(shù)組里,其他的元素仍沒(méi)有替換。</p><p> 3.1.2、在findswap函數(shù)中,給定數(shù)組下標(biāo)求地址映像時(shí)遇到了困難,原因還是由二維數(shù)組類比到三維數(shù)組及多維數(shù)組出現(xiàn)了問(wèn)題。三維數(shù)組可以想象成空間的數(shù)組,又由于c++中按行存儲(chǔ),所以舉了個(gè)例子: A[2][2][3]的三維數(shù)組,求A[2][2][1]的地址,23(2-1)+3(2-1)+1=10。</p>
22、<p> 公式為書(shū)上的公式: </p><p> LOC(j1,j2,***,jn)=LOC(0,0,***,0)+(b2***bnj1+b3***bnj2+***+bnjn-1+jn)L。</p><p> 其中n維數(shù)組的映像函數(shù)。bn代表第i維數(shù)組元素的個(gè)數(shù)。</p><p><b> 可縮寫成</b></p>
23、;<p> LOC(j1,j2,***,jn)=LOC(0,0,***,0)+。</p><p> 3.2 設(shè)計(jì)過(guò)程中學(xué)到的小知識(shí)</p><p> 3.2.1、當(dāng)輸出結(jié)果中想調(diào)用數(shù)據(jù)時(shí),即既想有輸出的原文字又有想調(diào)用的數(shù)據(jù)時(shí)。可以用<< <<將想調(diào)用的部分給包含起來(lái)。我也是在網(wǎng)上搜集資料偶然發(fā)現(xiàn)的。具體例子就是輸出函數(shù)PrintArray中
24、的輸出部分。如下截圖中劃線的部分:</p><p><b> 3.3 經(jīng)驗(yàn)與體會(huì)</b></p><p> 經(jīng)過(guò)這次課設(shè)我意識(shí)到雖然數(shù)據(jù)結(jié)構(gòu)課程已經(jīng)結(jié)束,但是數(shù)據(jù)結(jié)構(gòu)的學(xué)習(xí)還遠(yuǎn)遠(yuǎn)沒(méi)有結(jié)束,作為計(jì)算機(jī)專業(yè)的學(xué)生,應(yīng)當(dāng)學(xué)好數(shù)據(jù)結(jié)構(gòu)的知識(shí)點(diǎn),把專業(yè)知識(shí)打牢。同時(shí)應(yīng)當(dāng)動(dòng)手做一些程序設(shè)計(jì)的習(xí)題,雖然剛上手的時(shí)候有點(diǎn)難,只要肯鉆研下去,到問(wèn)題解決的時(shí)候覺(jué)得自己收獲還是挺大的。
25、同時(shí)也是為了鞏固自己數(shù)據(jù)結(jié)構(gòu)的實(shí)習(xí)。我以后還會(huì)挑一些題做的。</p><p> 第四部分、 用戶手冊(cè)</p><p> 4.1每一步驟的注釋說(shuō)明</p><p> 注釋說(shuō)明已包含在源程序中,請(qǐng)?jiān)斠?jiàn)附錄中的程序代碼,在此不再贅述。</p><p><b> 4.2 整體思路</b></p><p
26、> 我實(shí)現(xiàn)程序的功能的時(shí)候是把要求分成了幾個(gè)功能函數(shù),然后逐一的通過(guò)主函數(shù)調(diào)用功能函數(shù),來(lái)判別自己的功能函數(shù)是否正確,而不是從前寫到后一下寫完的。我覺(jué)得一個(gè)功能一個(gè)功能的實(shí)現(xiàn)更簡(jiǎn)單些,而且出錯(cuò)了容易查錯(cuò)。具體思路在前面都已經(jīng)描述,在此不再贅述。</p><p><b> 第五部分、測(cè)試結(jié)果</b></p><p> 5.1 測(cè)試結(jié)果截圖</p>
27、<p><b> 5.2 程序源碼</b></p><p> #include <iostream></p><p> using namespace std;</p><p> #define MAXDIM 5 //定義數(shù)組的最大維數(shù) </p><p> #define MA
28、XNUM 10 //定義每維數(shù)組的最大個(gè)數(shù) </p><p> #define MAXTOTAL 100 //定義數(shù)組元素的最大個(gè)數(shù)</p><p> typedef int ElemType;</p><p> typedef struct{</p><p> ElemType lower; //定義每維數(shù)組的下界 <
29、/p><p> ElemType upper; //定義每維數(shù)組的上界</p><p> int boundnum; //定義每維數(shù)組中元素的個(gè)數(shù) </p><p> }Boundi; //定義第i維數(shù)組</p><p> typedef struct{</p><p> int dim;
30、 //定義多維數(shù)組的維數(shù) </p><p> Boundi bound[MAXDIM]; //定義第i維數(shù)組</p><p> int total; //定義數(shù)組中元素的個(gè)數(shù) </p><p> int elem[MAXTOTAL]; //數(shù)組中每個(gè)元素的地址,其中elem[0]為該多維數(shù)組的基址&l
31、t;/p><p> }NArray; //定義多維數(shù)組 </p><p> NArray CreatArray() { //創(chuàng)建一個(gè)多維數(shù)組并初始化 </p><p> int total=1;</p><p> int n,i,j;</p><p> NArray A
32、; //定義多維數(shù)組A </p><p> cout<<"請(qǐng)輸入要?jiǎng)?chuàng)建數(shù)組的維數(shù):";</p><p><b> cin>>n; </b></p><p><b> if(n>5){</b></p><p> cou
33、t<<"超過(guò)數(shù)組的維數(shù)上限 請(qǐng)重新輸入:"<<endl;</p><p><b> cin>>n; </b></p><p><b> }</b></p><p><b> A.dim=n;</b></p><p>
34、 cout<<"請(qǐng)輸入每維數(shù)組的上下界:"<<endl;</p><p> for(i=1;i<=A.dim;i++){</p><p> cout<<"請(qǐng)輸入第"<<i<<"維數(shù)組的上下界:";</p><p> cin>&g
35、t;A.bound[i-1].lower;</p><p> cout<<endl;</p><p> cin>>A.bound[i-1].upper;</p><p> A.bound[i-1].boundnum=A.bound[i-1].upper-A.bound[i-1].lower+1;</p><p>
36、 total=total*A.bound[i-1].boundnum;</p><p><b> } </b></p><p> A.total=total; //統(tǒng)計(jì)出來(lái)數(shù)組中元素的個(gè)數(shù)</p><p> for(i=0;i<total;i++){</p><p> A.elem[i]=0;<
37、/p><p> cout<<"是否要初始化數(shù)組?Y-1,N-0: ";cin>>j;</p><p> switch(j){</p><p><b> case 1:{</b></p><p> cout<<"請(qǐng)以行序輸入"<<A
38、.total<<"個(gè)元素"<<endl;</p><p> for(i=0;i<A.total;i++){</p><p> cin>>A.elem[i];//輸入多維數(shù)組的元素 </p><p><b> } </b></p><p><b>
39、; }</b></p><p> case 0:;//不執(zhí)行操作,創(chuàng)建一個(gè)全為0的多維數(shù)組 </p><p><b> }</b></p><p><b> } </b></p><p> cout<<"*******創(chuàng)建多維數(shù)組成功********&qu
40、ot; <<endl;</p><p> return A; </p><p><b> }</b></p><p> int Replace(NArray &A,NArray &B){ //數(shù)組替換函數(shù) </p><p><b> int i;</b><
41、;/p><p> if(A.dim!=B.dim){</p><p> cout<<"*******這兩個(gè)數(shù)組不是同類型的******"<<endl; //判斷兩個(gè)數(shù)組的維數(shù)是否相同 </p><p> return 0; </p><p><b> }</b></
42、p><p> for(i=1;i<=A.dim;i++){</p><p> if(A.bound[i-1].boundnum!=B.bound[i-1].boundnum){</p><p> cout<<"*******這兩個(gè)數(shù)組不是同類型的********"<<endl; //判斷兩個(gè)數(shù)組各維的元素的個(gè)數(shù)是
43、否相同 </p><p> return 0; </p><p><b> }</b></p><p><b> }</b></p><p> for(i=0;i<A.total;i++){</p><p> B.elem[i]=A.elem[i]; //
44、把多維數(shù)組A賦值給B </p><p><b> }</b></p><p> cout<<"********賦值成功********"<<endl; </p><p> return 0;</p><p><b> }</b></p&
45、gt;<p> void AdjustBound(NArray &A){ //修改數(shù)組的下標(biāo)</p><p><b> int n;</b></p><p> cout<<"想要修改第幾維的上下界?請(qǐng)輸入:";</p><p><b> cin>>n;<
46、/b></p><p> cout<<"請(qǐng)輸入修改后的上下界:";</p><p> cin>>A.bound[n-1].lower;</p><p> cin>>A.bound[n-1].upper;</p><p> A.bound[n-1].boundnum=A.bo
47、und[n-1].upper-A.bound[n-1].lower+1;</p><p> cout<<"修改后的第"<<n<<"維元素的個(gè)數(shù)為:"<<A.bound[n-1].boundnum<<endl; </p><p><b> } </b></p&g
48、t;<p> void FindSwap(NArray &A){ //查找替換函數(shù) </p><p> int i,temptotal=1,sum=0,j;</p><p> int a[MAXDIM];</p><p> cout<<"請(qǐng)輸入你所查找的元素的下標(biāo):"; </p><
49、p> for(i=0;i<A.dim;i++)cin>>a[i];</p><p> for(i=0;i<A.dim;i++){</p><p> temptotal=a[i]-A.bound[i].lower;//給定數(shù)組下標(biāo)的求映像地址的計(jì)算公式。舉個(gè)例子A223的三維數(shù)組,求A221的地址,2*3*(2-1)+3*(2-1)+1=10。公式為書(shū)上的
50、公式 </p><p> for(j=i+1;j<A.dim;j++)</p><p> temptotal=temptotal*A.bound[j].boundnum;</p><p> sum=sum+temptotal;</p><p><b> }</b></p><p>
51、 cout<<"數(shù)組NArray";</p><p> for(i=0;i<A.dim;i++)cout<<"["<<a[i]<<"]";</p><p> cout<<"的值為:elem["<<sum<<"
52、;]="<<A.elem[sum]<<" 找到了目標(biāo)值"<<endl;</p><p> cout<<"想要改變這個(gè)目標(biāo)值嗎?Y-1,N-0:";cin>>i;</p><p><b> if(i==1){</b></p><p&g
53、t; cout<<"請(qǐng)輸入替換值"<<endl;cin>>j;</p><p> A.elem[sum]=j;</p><p><b> }</b></p><p> cout<<"替換后的數(shù)組為:"<<endl;</p>
54、<p> for(i=0;i<A.total;i++){</p><p> cout<<A.elem[i]<<" ";</p><p><b> } </b></p><p> cout<<endl;</p><p><b> }
55、</b></p><p> void PrintArray(NArray A){ //輸出數(shù)組有關(guān)信息的函數(shù) </p><p><b> int i,j;</b></p><p> cout<<"這是一個(gè)"<<A.dim<<"維數(shù)組NArray ";
56、</p><p> for(i=1;i<=A.dim;i++){</p><p> cout<<"["<<A.bound[i-1].lower<<"…"<<A.bound[i-1].upper<<"]";</p><p><b>
57、; }</b></p><p> cout<<"該數(shù)組的元素的個(gè)數(shù)為:"<<A.total<<" ";</p><p> cout<<"數(shù)組為:" <<endl;</p><p> for(i=0;i<A.tota
58、l;i++){</p><p> cout<<A.elem[i]<<" ";</p><p><b> }</b></p><p> cout<<endl;</p><p><b> }</b></p><p>
59、 int main(){</p><p><b> int m;</b></p><p> NArray a,b,c;</p><p> a=CreatArray(); //1、創(chuàng)建并初始化數(shù)組a</p><p> PrintArray(a);</p><p> b=CreatAr
60、ray(); //創(chuàng)建并初始化數(shù)組b </p><p> PrintArray(b);</p><p> cout<<"是否要替換數(shù)組?是-1 否-0: ";</p><p><b> cin>>m;</b></p><p><b> if(m==1){&l
61、t;/b></p><p> Replace(a,b); //5.1將a賦值給b 同類型的數(shù)組賦值 成功 </p><p> PrintArray(b);</p><p><b> } </b></p><p> c=CreatArray(); //創(chuàng)建并初始化數(shù)組c </p><
62、p> PrintArray(c);</p><p> cout<<"是否要替換數(shù)組?是-1 否-0: ";</p><p><b> cin>>m;</b></p><p><b> if(m==1){</b></p><p> Repla
63、ce(a,c); //5.2 將a賦值給c 不同類型的數(shù)組賦值 不成功 </p><p> PrintArray(c);</p><p><b> } </b></p><p> FindSwap(a); //4、查找和替換數(shù)組中的具體元素 </p><p> FindSwap(a);</p>
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)組的存儲(chǔ)格式轉(zhuǎn)換
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)----huffman編碼
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)迷宮課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)迷宮課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---迷宮
評(píng)論
0/150
提交評(píng)論