版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 課程設(shè)計報告</b></p><p> 課程設(shè)計題目:稀疏矩陣的轉(zhuǎn)置 </p><p> 2012年 06 月 21 日</p><p><b> 目錄</b></p><p><b> 一、課程設(shè)計題目</b>&l
2、t;/p><p> 二、題目與流程圖或模塊圖</p><p> 三、程序清單和運行結(jié)果</p><p> 四、小結(jié)(收獲和體會)</p><p><b> 一、課程設(shè)計目的:</b></p><p> 課程設(shè)計為學(xué)生提供了一個既動手又動腦,獨立實踐的機(jī)會,將課本上的理論知識和實際有機(jī)的結(jié)合起
3、來,鍛煉學(xué)生的分析解決實際問題的能力。提高學(xué)生適應(yīng)實際,實踐編程的能力。</p><p> 二、題目與流程圖或模塊圖</p><p><b> 1、題目:</b></p><p><b> 稀疏矩陣的轉(zhuǎn)置</b></p><p> 要求:1)以三元組的方式存儲稀疏矩陣</p>
4、<p> 2)普通轉(zhuǎn)置方法實現(xiàn)</p><p> 3)快速轉(zhuǎn)置方法實現(xiàn)</p><p><b> 2、流程圖:</b></p><p> 三、程序清單和運行結(jié)果:</p><p><b> 1、程序清單:</b></p><p> # define ma
5、xsize 1000</p><p> typedef int elemtype;</p><p> typedef struct</p><p><b> {</b></p><p> int row,col;</p><p> elemtype e;</p><
6、p><b> }triple;</b></p><p> typedef struct</p><p><b> {</b></p><p> triple data[maxsize+1];</p><p> int m,n,len;</p><p> }t
7、smatrix;</p><p> int init(triple *s)</p><p><b> {</b></p><p> s->row=s->col=0;</p><p><b> }</b></p><p> int create(tsmat
8、rix *b)</p><p><b> {</b></p><p><b> int i;</b></p><p> printf("please input m,n,len\n");</p><p> scanf("%d%d%d",&b-&
9、gt;m,&b->n,&b->len);</p><p> for(i=1;i<=b->len;i++)</p><p><b> {</b></p><p> printf("please input e,row,col\n");</p><p> s
10、canf("%d%d%d",&b->data[i].e,&b->data[i].row,&b->data[i].col);</p><p><b> }</b></p><p><b> }</b></p><p> void transposetsmat
11、rix(tsmatrix a,tsmatrix *b)</p><p><b> {</b></p><p> int i,j,k;</p><p><b> b->m=a.n;</b></p><p><b> b->n=a.m;</b></p>
12、;<p> b->len=a.len;</p><p> if(b->len<=0)</p><p> printf("the matrix is empty!");</p><p><b> else </b></p><p> if(b->len&g
13、t;maxsize) </p><p> printf("the matrix is error");</p><p><b> else</b></p><p><b> {</b></p><p><b> j=1;</b></
14、p><p> for(k=1;k<=a.n;k++)</p><p> for(i=1;i<=a.len;i++)</p><p> if(a.data[i].col==k)</p><p><b> {</b></p><p> b->data[j].row=a.data
15、[i].col;</p><p> b->data[j].col=a.data[i].row;</p><p> b->data[j].e=a.data[i].e;</p><p><b> j++;</b></p><p><b> }</b></p><p
16、><b> }</b></p><p><b> }</b></p><p> void fasttransposetsmatrix(tsmatrix a,tsmatrix *b)</p><p><b> {</b></p><p> int col,t,p,
17、q;</p><p> int num[maxsize],position[maxsize];</p><p> b->len=a.len;b->n=a.m;b->m=a.n;</p><p> if(b->len<=0)printf("the matrix is empty!");</p>&l
18、t;p><b> else </b></p><p> if(b->len>maxsize) </p><p> printf("the matrix is error"); </p><p><b> else</b></p><
19、;p><b> {</b></p><p> for(col=1;col<=a.n;col++)</p><p> num[col]=0;</p><p> for(t=1;t<=a.len;t++)</p><p> num[a.data[t].col]++;</p><
20、p> position[1]=1;</p><p> for(col=2;col<a.n;col++)</p><p> position[col]=position[col-1]+num[col-1];</p><p> for(p=1;p<=a.len;p++)</p><p><b> {</
21、b></p><p> col=a.data[p].col; q=position[col];</p><p> b->data[q].row=a.data[p].col;</p><p> b->data[q].col=a.data[p].row;</p><p> b->data[q].e=a.data[
22、p].e;</p><p> position[col]++;</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> void display(tsmatrix *b
23、)</p><p><b> {</b></p><p> int i,j,k;</p><p> for(i=1;i<=b->m;i++)</p><p> for(j=1;j<=b->n;j++)</p><p><b> {</b>&l
24、t;/p><p> for(k=1;k<=b->len;k++)</p><p><b> {</b></p><p> if(b->data[k].row==i&&b->data[k].col==j)</p><p> {printf("%5d",b-&g
25、t;data[k].e) ;break;}</p><p><b> }</b></p><p> if(k>b->len)</p><p> printf("%5d",0);</p><p> if(j==b->n) printf("\n");</
26、p><p><b> }</b></p><p><b> }</b></p><p><b> main()</b></p><p><b> {</b></p><p><b> triple s;</b&
27、gt;</p><p> tsmatrix a,b,c;</p><p><b> init(&s);</b></p><p> create(&a);</p><p> display(&a);</p><p> printf("\n");&
28、lt;/p><p> printf("pu tong zhuan zhi jie guo\n");</p><p> transposetsmatrix(a,&b);</p><p> display(&b);</p><p> printf("\n");</p>&l
29、t;p> printf("kuai su zhuan zhi jie guo\n");</p><p> fasttransposetsmatrix(a,&b);</p><p> display(&b);</p><p><b> }</b></p><p><b
30、> 2、運行結(jié)果:</b></p><p> 輸入矩陣的行、列、長度</p><p> 輸入非零元素的行、列、值</p><p> 輸出矩陣以及轉(zhuǎn)置后的矩陣</p><p> 四、小結(jié)(收獲和體會):</p><p> 通過一周的課程設(shè)計使我對數(shù)據(jù)結(jié)構(gòu)有了更深的理解,對以前學(xué)習(xí)中不明白的,
31、不理解的都有了進(jìn)一步的理解。在實際操作中遇到了很多困難,比如,在做矩陣的轉(zhuǎn)置時,一開始不了解矩陣轉(zhuǎn)置到底是什么,普通轉(zhuǎn)置的原理,快速轉(zhuǎn)置的原理。但通過查書,請教同學(xué)和老師,使我的動手能力和溝通能力都有了提高。</p><p> 在整個課程設(shè)計中總是在編寫程序中發(fā)生錯誤,有時會很沒耐性,但都被我逐個克服了,編程一定要有耐心,同時還有認(rèn)真仔細(xì),盡量保證不出現(xiàn)錯誤。編程要有條理,不僅使自己要看懂 ,別人也能看懂,這樣
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計論文----稀疏矩陣的轉(zhuǎn)置
- 稀疏矩陣的轉(zhuǎn)置論文-數(shù)據(jù)結(jié)構(gòu)課程設(shè)計論文
- 課程設(shè)計--矩陣轉(zhuǎn)置與乘法.doc
- 稀疏矩陣相乘課程設(shè)計報告
- c課程設(shè)計--矩陣轉(zhuǎn)置與乘法計算
- C課程設(shè)計--矩陣轉(zhuǎn)置與乘法計算.doc
- 稀疏矩陣的運算課程設(shè)計
- 課程設(shè)計-- 4-4 矩陣的轉(zhuǎn)置與乘法計算
- 稀疏矩陣的運算課程設(shè)計
- 課程設(shè)計---稀疏矩陣應(yīng)用
- c語言課程設(shè)計報告 --求3x4數(shù)組的轉(zhuǎn)置矩陣
- 課程設(shè)計-- 4-4 矩陣的轉(zhuǎn)置與乘法計算.doc
- 數(shù)據(jù)結(jié)構(gòu)--稀疏矩陣課程設(shè)計
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---稀疏矩陣
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-- 稀疏矩陣的運算
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計--稀疏矩陣的操作
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計報告--稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告--稀疏矩陣運算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計報告 稀疏矩陣運算器
- 課程設(shè)計報告—稀疏矩陣的完全鏈表表示及其運算
評論
0/150
提交評論