版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、數(shù)據(jù)結(jié)構(gòu)與算法實(shí)驗(yàn)指導(dǎo)V2017常熟理工學(xué)院數(shù)據(jù)結(jié)構(gòu)與算法實(shí)驗(yàn)指導(dǎo)與報(bào)告書(shū)_2017-2018_學(xué)年 第_1_ 學(xué)期專(zhuān) 業(yè): 物聯(lián)網(wǎng)工程 實(shí)驗(yàn)名稱(chēng): 特殊矩陣和稀疏矩陣 實(shí)驗(yàn)地點(diǎn): N6-210 指導(dǎo)教師: 聶盼紅 計(jì)算機(jī)科學(xué)與工程學(xué)院2017實(shí)驗(yàn)五 特殊矩陣和稀疏矩陣【實(shí)驗(yàn)?zāi)康摹?、掌握數(shù)組的結(jié)構(gòu)類(lèi)型(靜態(tài)的內(nèi)存空間配置);通過(guò)數(shù)組的引用下標(biāo)轉(zhuǎn)換成該數(shù)據(jù)在內(nèi)存中的地址;2、掌握對(duì)稱(chēng)矩陣的壓縮存儲(chǔ)表示;3、掌握稀疏矩陣的壓縮存儲(chǔ)-三元組表表示,以及稀疏矩陣的轉(zhuǎn)置算法?!緦?shí)驗(yàn)學(xué)時(shí)】2學(xué)時(shí)【實(shí)驗(yàn)預(yù)習(xí)】回答以下問(wèn)題:1、什么是對(duì)稱(chēng)矩陣?寫(xiě)出對(duì)稱(chēng)矩陣壓縮存儲(chǔ)sak與aij之間的對(duì)應(yīng)關(guān)系。若n階矩陣A中
2、的元素滿(mǎn)足下述性質(zhì):aij=aji,則稱(chēng)為n階對(duì)稱(chēng)矩陣。sak與矩陣元素aij之間存在著一一對(duì)應(yīng)的關(guān)系: 若i>=j,k=i*(i+1)/2+j; 若i<j,k=j*(j+1)/2+i。 0<=i, j<=n-1 0<=k<=n*(n+1)/2-12、什么是稀疏矩陣?稀疏矩陣的三元組表表示。假設(shè)在m×n的矩陣中,有t個(gè)元素不為零,且tm×n,則稱(chēng)此矩陣為稀疏矩陣。稀疏矩陣的三元組成表示: 矩陣的行數(shù)、列數(shù)和非零元個(gè)數(shù)【實(shí)驗(yàn)內(nèi)容和要求】1、編寫(xiě)程序exp5_1.c,將對(duì)稱(chēng)矩陣進(jìn)行壓縮存儲(chǔ)。(1)對(duì)稱(chēng)矩陣數(shù)組元素Aij轉(zhuǎn)換成為以行為主的一維數(shù)
3、組sak,請(qǐng)描述k與ij的關(guān)系。(注意C程序中,i,j,k均從0開(kāi)始)(2)調(diào)試程序與運(yùn)行。對(duì)稱(chēng)矩陣存儲(chǔ)下三角部分即i>=j。對(duì)稱(chēng)矩陣為 3,9,1,4,7 9,5,2,5,8 1,2,5,2,4 4,5,2,1,7 7,8,4,7,9參考程序如下:#include<stdio.h>#define N 5int main() int upperNN= 3,9,1,4,7, 9,5,2,5,8, 1,2,5,2,4, 4,5,2,1,7, 7,8,4,7,9 ; /*對(duì)稱(chēng)矩陣*/ int rowMajor15; /*存儲(chǔ)轉(zhuǎn)換數(shù)據(jù)后以行為主的數(shù)組*/ int Index; /*數(shù)
4、組的索引值*/ int i,j; printf("Two dimensional upper triangular array:n"); for (i=0; i<N; i+) /*輸出對(duì)稱(chēng)矩陣*/ for(j=0; j<N; j+) printf("%3d",upperij); printf("n"); for(i=0; i<N; i+) /*進(jìn)行壓縮存儲(chǔ)*/ for(j=0; j<N; j+) if(i>=j) /*下三角元素進(jìn)行存儲(chǔ)*/ Index=i*(i+1)/2+j; /*ij與index的轉(zhuǎn)換
5、*/ rowMajorIndex=upperij; printf("nRow Major one dimensional array:n"); for(i=0; i<15; i+) /*輸出轉(zhuǎn)換后的一維數(shù)組*/ printf("%3d", rowMajori); printf("n"); return 1;2、完成程序exp5_2.c,實(shí)現(xiàn)稀疏矩陣的三元組表存儲(chǔ)及稀疏矩陣的轉(zhuǎn)置。調(diào)試并給出結(jié)果: 補(bǔ)充完整程序,運(yùn)行稀疏矩陣的一般轉(zhuǎn)置算法; 完成稀疏矩陣的快速轉(zhuǎn)置算法,并修改主函數(shù)的轉(zhuǎn)置調(diào)用算法,驗(yàn)證快速轉(zhuǎn)置算法的正確性。exp5
6、_2.c部分代碼如下:#include<stdio.h>#define MAXSIZE 20 /*非零元素個(gè)數(shù)最大值*/typedef int ElemType;typedef struct int i,j; ElemType e;Triple;typedef struct Triple dataMAXSIZE+1; /*三元組表,data0不用*/ int mu,nu,tu;/*矩陣的行數(shù)、列數(shù)、非零元個(gè)數(shù)*/TSMatrix;void TransposeSMatrix(TSMatrix *T,TSMatrix *M);/*一般轉(zhuǎn)置算法*/void FastTransposeSM
7、atrix(TSMatrix *M,TSMatrix *T);/*快速轉(zhuǎn)置算法*/int main() int i,j,k,q,col,p; int temp67=0,12,9,0,0,0,0, /*稀疏矩陣*/ 0,0,0,0,0,0,0, -3,0,0,0,0,14,0, 0,0,24,0,0,0,0, 0,18,0,0,0,0,0, 15,0,0,-7,0,0,0, ; TSMatrix T,M; M.mu=6; M.nu=7; M.tu=0; k=1; for (i=0;i< M.mu;i+) /*轉(zhuǎn)換為稀疏矩陣的三元組表示*/ for (j=0;j< M.nu;j+) i
8、f (tempij!=0) M.datak.i=i+1; M.datak.j=j+1; M.datak.e=tempij; k+; M.tu=k-1; FastTransposeSMatrix(&M,&T); /*調(diào)用轉(zhuǎn)置算法進(jìn)行轉(zhuǎn)置*/ /*輸出轉(zhuǎn)置結(jié)果*/ printf("稀疏矩陣:n"); for (i=0;i< M.mu;i+) /*轉(zhuǎn)換為稀疏矩陣的三元組表示*/ for (j=0;j< M.nu;j+) printf("%3d",tempij); printf("n"); printf("
9、;轉(zhuǎn)置前M三元組表:nmutnuttun"); printf("%dt%dt%dn",M.mu,M.nu,M.tu); printf("nitjten"); for (i=1;i<=M.tu;i+) printf("%dt%dt%dn",M.datai.i,M.datai.j,M.datai.e); printf("轉(zhuǎn)置后T三元組表:nmutnuttun"); printf("%dt%dt%dn",T.mu,T.nu,T.tu); printf("nitjten&quo
10、t;); for (i=1;i<=T.tu;i+) printf("%dt%dt%dn",T.datai.i,T.datai.j,T.datai.e);/*稀疏矩陣的轉(zhuǎn)置*/void TransposeSMatrix(TSMatrix *M,TSMatrix *T) int q,col,p; T->mu=M->nu; T->nu=M->mu; T->tu=M->tu; if (T->tu) q=1; for (col=1;col<=M->nu;+col) for (p=1;p<=M->tu;+p) if
11、 (M->datap.j=col) T->dataq.i=M->datap.j; T->dataq.j=M->datap.i; T->dataq.e=M->datap.e; +q; /*稀疏矩陣的快速轉(zhuǎn)置算法*/void FastTransposeSMatrix(TSMatrix *M,TSMatrix *T) int t,q,col,p,numMAXSIZE,cpotMAXSIZE; T->mu=M->nu; T->nu=M->mu; T->tu=M->tu; if (T->tu) /*快速轉(zhuǎn)置過(guò)程的實(shí)現(xiàn),請(qǐng)
12、補(bǔ)充代碼*/ for(col=1;col<=M->mu;+col) numcol=0; /num數(shù)組的初始化 for(t=1;t<=M->tu;+t) +numM->datat.j; /求M中每一列的非零元素的個(gè)數(shù) cpot1=1; /求col列中第一個(gè)非零元素在T中序號(hào) for( col=2;col<=M->nu;+col) /求cpot數(shù)組的值 cpotcol=cpotcol-1+numcol-1; for( p=1;p<=M->tu;+p) /進(jìn)行轉(zhuǎn)置 col=M->datap.j; q=cpotcol; T->dataq.i=M-&g
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 工程招標(biāo)設(shè)計(jì)階段合同條件(第二部分)
- 專(zhuān)業(yè)體育教練合作協(xié)議范本
- 企業(yè)資產(chǎn)收購(gòu)合同
- 事業(yè)單位引進(jìn)急需緊缺專(zhuān)業(yè)人才暨2024年
- 2024年最高額反擔(dān)保保證
- 政府采購(gòu)協(xié)議供貨公開(kāi)招標(biāo)文件2024年
- 農(nóng)家樂(lè)活動(dòng)合作合同
- 快遞合作協(xié)議書(shū)樣本
- 2024年如何制定具有法律效力的離婚協(xié)議
- 高校住宿租賃協(xié)議樣本
- 同底數(shù)冪的乘法練習(xí)
- 生物醫(yī)學(xué)工程前沿之生物醫(yī)學(xué)檢測(cè)與疾病診斷
- 進(jìn)場(chǎng)開(kāi)工通知書(shū)
- 中考語(yǔ)文復(fù)習(xí)常考名著精練4.《革命烈士詩(shī)抄》-有答案
- 樁基溶洞處理專(zhuān)項(xiàng)施工方案(2024.4.2旋)
- 中職數(shù)學(xué)《平面的基本性質(zhì)》課件
- 建筑設(shè)計(jì)消防專(zhuān)篇
- 初中數(shù)學(xué)基于核心素養(yǎng)導(dǎo)向的大單元教學(xué)設(shè)計(jì)(共50張)
- 學(xué)校節(jié)約能源實(shí)施方案
- 鎂合金行業(yè)發(fā)展分析及投資前景預(yù)測(cè)報(bào)告
- 室內(nèi)維修方案
評(píng)論
0/150
提交評(píng)論