南京理工大學(xué)C++課程設(shè)計(jì)

上傳人:燈火****19 文檔編號(hào):20471749 上傳時(shí)間:2021-03-23 格式:DOCX 頁(yè)數(shù):14 大?。?6.02KB
收藏 版權(quán)申訴 舉報(bào) 下載
南京理工大學(xué)C++課程設(shè)計(jì)_第1頁(yè)
第1頁(yè) / 共14頁(yè)
南京理工大學(xué)C++課程設(shè)計(jì)_第2頁(yè)
第2頁(yè) / 共14頁(yè)
南京理工大學(xué)C++課程設(shè)計(jì)_第3頁(yè)
第3頁(yè) / 共14頁(yè)

下載文檔到電腦,查找使用更方便

15 積分

下載資源

還剩頁(yè)未讀,繼續(xù)閱讀

資源描述:

《南京理工大學(xué)C++課程設(shè)計(jì)》由會(huì)員分享,可在線閱讀,更多相關(guān)《南京理工大學(xué)C++課程設(shè)計(jì)(14頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、 C++課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告 姓名 陳國(guó)杭 學(xué)號(hào) 9 班級(jí) 9151043301 任課教師 趙 琦 時(shí)間 3 月 選擇題目 矩陣轉(zhuǎn)置及乘法運(yùn)算 難易級(jí)別 A 級(jí) 實(shí)驗(yàn)報(bào)告成績(jī) 一、程序功能簡(jiǎn)介 該程序定義了一個(gè)向量類, 里面的元素是模板形式, 定義了有關(guān)向量類的各種屬性、方法及運(yùn)算符重載函數(shù)。 二、課程設(shè)計(jì)要求和目的 1. 利用已知的向量類對(duì)象定義一個(gè)矩陣類,矩陣類的數(shù)據(jù)是向量子對(duì)象,同樣定義矩陣類的各種屬性、方法及運(yùn)算符重載函數(shù)。 2. 完善成員函數(shù),使矩陣可以由文件輸入,具體的輸入格式自己規(guī)定。

2、 3. 完善矩陣的賦值、轉(zhuǎn)置、乘法等運(yùn)算,要求用整形矩陣和浮點(diǎn)型矩陣分別演算。 4. 更改 main 函數(shù)結(jié)構(gòu), 可由用戶選擇輸入矩陣數(shù)據(jù)的方法, 程序可以連續(xù)運(yùn)行, 知道選擇退出為止。 三、課程設(shè)計(jì)中要解決的問(wèn)題分析和調(diào)試 1. 源程序只給出了菜單的樣式,及函數(shù)類的格式。 2. 運(yùn)算符重載函數(shù)要重新熟練。 3. 引用的頭文件 (輸入輸出流) () (數(shù)學(xué)常用庫(kù)函數(shù)) (提供一些函數(shù)與符號(hào)常量) ( string 類)。 4. 添加人性化界面, 初始運(yùn)行程序時(shí)加

3、了一個(gè)友好的界面 , 并附帶輸出了自己的姓名和學(xué)號(hào),選擇退出時(shí),亦有特別字樣。 5. 在主函數(shù)中調(diào)用 read() 函數(shù),通過(guò) read() 中讀取外部文件,但會(huì)內(nèi)存錯(cuò)誤(已解決,行和列的未定義。)。 5. 在進(jìn)行四種不同的運(yùn)算時(shí)均會(huì)詢問(wèn)輸入方式, main 函數(shù)利用 switc

4、h 函數(shù)進(jìn)行主菜單 的編輯。 6. 在矩陣輸入中增加錯(cuò)誤判斷的功能,防止輸入錯(cuò)誤導(dǎo)致程序無(wú)法進(jìn)行。 7. 程序中若輸入的矩陣無(wú)法求逆,或者無(wú)法進(jìn)行乘法,會(huì)直接退出程序,亟待解決 四、源程序結(jié)構(gòu)流程框圖與說(shuō)明 入 開(kāi) 程 始 序 進(jìn) 主菜單:選擇何種計(jì)算 輸入選擇 選 擇 ” 5 ” 提示輸入矩陣的方式 N 輸入選擇 鍵盤輸入矩陣 Y 矩 陣 是 否 Y 進(jìn) 行 選

5、 符合要求 運(yùn) 擇 算 退 出 輸出結(jié)果 是否繼續(xù)執(zhí)行程序 N 結(jié)束退出 作者:陳國(guó)杭 學(xué)號(hào): 9 六、源程序代碼 以及草稿原件 #include #include #include #include #include using names

6、pace std; template// class CMatrix {  模板函數(shù) int row; int col; T**a; public: CMatrix();  //  構(gòu)造 函數(shù)√ CMatrix(int r,int c); CMatrix(const CMatrix &src);  //  拷貝 構(gòu)造函數(shù)√ ~CMatrix();  // 

7、析構(gòu) 函數(shù)√ CMatrix&operator=(const CMatrix&); CMatrixzhuanzhi();  //  轉(zhuǎn)置 函數(shù)√ 矩陣√  CMatrixqiuni(); // CMatrixoperator*(const CMatrix&m)const;  //  求逆 矩陣的 乘法√ CMatrixshucheng(double num);  //  矩陣

8、 數(shù)乘√ CMatrixread(char  *  ); // 從文件輸入√ void input();  //  從鍵盤 輸入√ void show();  //  顯示矩 陣√ }; template CMatrix::CMatrix() { row=0; col=0; a=NULL; }// 構(gòu)造函數(shù) template CMatrix:

9、:CMatrix(int r,int c) { row=r; col=c; int i,j; a=new T*[r]; for(i=0;i CMatrix::CMatrix(const CMatrix&m)  // 拷貝 {

10、row=m.row; col=m.col; int i,j; a=new T*[row];  //  動(dòng)態(tài)建立二維 數(shù)組 for(i=0;i CMatrix::~CMatrix()  //

11、 析構(gòu) { for(int i=0;i CMatrix&CMatrix::operator=(const  CMatrix&m) // 等于 { for(int i=0;i

12、int i=0;i CMatrixCMatrix::zhuanzhi() // 轉(zhuǎn)置 { CMatrix m(col,row); for(int i=0;i CM

13、atrixCMatrix::qiuni() { CMatrix s(1,1); s.a[0][0]=0; if(row!=col) { cout<<" 輸入的矩陣沒(méi)有逆矩陣。 \n"<

14、 } } for(i=0;ifabs(max)) { max=t.a[j][i]; k=j; } } if(k!=i) { for(j=0;j

15、+) { temp=t.a[i][j]; t.a[i][j]=t.a[k][j]; t.a[k][j]=temp; temp=n.a[i][j]; n.a[i][j]=n.a[k][j]; n.a[k][j]=temp; } } if(t.a[i][i]==0) { cout<<" 輸入的矩陣沒(méi)有逆矩陣。 \n"; return s; } temp=t.a[i][i]; for(j=0;j

16、=n.a[i][j]/temp; } for(j=0;j CMatrixCMatrix::operator*(cons

17、t CMatrix&m)const // 重載乘法 { CMatrix s(1,1); s.a[0][0]=0; CMatrix n(row,m.col); if(col!=m.row) { return s; } for(int i=0;i

18、 } template CMatrixCMatrix::shucheng(double  num) // 數(shù)乘 { CMatrix b(row,col); for(int i=0;i CMatrixCMatrix::read(char * ) // 從

19、文件輸入 { ifstream infile; in(); Loop:if(!infile) { in(); cout<<" 不能打開(kāi)該文件 "<>; in(); in();goto Loop; // 防止多次輸錯(cuò) } int row;int col; infile>>row>>col; CMatrixm(row,col);// 通過(guò)文件前兩個(gè)數(shù)字作為行、列 double z; int i=0,j=0; while(infile

20、>>z) { m.a[i][j]=z; if((j+1)%col==0) { j=0; i+=1; }// 定義何時(shí)換行 else j+=1; } in(); return m; } template void CMatrix::input()  //  鍵 盤輸入矩陣 { for(int i=0;i>a[i][j]; } templat

21、e void  CMatrix::show() // 顯示矩陣 { for(int i=0;i

22、>x) {  :"; if(

23、x==5) { cout<<" 歡迎再次使用 "<5||x<1) {cout<<" 輸入錯(cuò)誤,請(qǐng)重新輸入! "<>y; if (y!=1&&y!=2){cout<<" 輸入錯(cuò)誤,請(qǐng)重新輸入! "<

24、<>; cout<m1; CMatrixm2=m1.read(); CMatrixm3=m2.zhuanzhi(); cout<<" 原矩陣的轉(zhuǎn)置矩陣為: \n"; m3.show(); } if(y==2) { int h,l; co

25、ut<<" 請(qǐng)輸入矩陣的行 :"; cin>>h; cout<<" 請(qǐng)輸入矩陣的列 :"; cin>>l; cout<<" 請(qǐng)依次輸入矩陣的值: "; CMatrixm1(h,l); m1.input(); CMatrixm2=m1.zhuanzhi(); cout<

26、<<" 請(qǐng)輸入文件名: "; cin>>; cout<m1; CMatrixm2=m1.read(); CMatrixm3=m2.qiuni(); cout<<" 原矩陣的逆矩陣為: \n"; m3.show(); } if(y==2) { int h,l; cout<<" 請(qǐng)輸入矩陣的行 :"; cin>>h; cout<<" 請(qǐng)輸入矩陣的列 :"; cin>>l; cout<<" 請(qǐng)依次輸入矩陣的值:

27、 "; CMatrixm1(h,l); m1.input(); CMatrixm2=m1.qiuni(); cout<>; cout<m1; CM

28、atrixm2=m1.read(); cout<>; cout<m3; CMatrixm4=m3.read(); cout<m5=m2*m4; cout<<" 兩個(gè)矩陣相乘結(jié)果為: \n"; m5.show(); } if(y==2) { int h1,l1,h

29、2,l2; cout<>h1; cout<<" 請(qǐng)輸入第一個(gè)矩陣的列 :"; cin>>l1; cout<<" 請(qǐng)依次輸入第一個(gè)矩陣的值: "; CMatrixm1(h1,l1); m1.input(); cout<>h2; cout<<" 請(qǐng)輸入第二個(gè)矩陣的列 :"; cin>>l2; if(l1!=h2){cout<<" 兩矩陣不能相乘。 \

30、n"<m2(h2,l2); m2.input(); CMatrixm3=m1*m2; cout<>; cout<

31、CMatrixm1; CMatrixm2=m1.read(); cout<<" 請(qǐng)輸入要乘的實(shí)數(shù): "; cin>>s; CMatrixm3=m2.shucheng(s); cout<<" 輸入矩陣與實(shí)數(shù)相乘結(jié)果為: \n"; m3.show(); } if(y==2) { int h,l,s; cout<<" 請(qǐng)輸入矩陣的行 :"; cin>>h; cout<<" 請(qǐng)輸入矩陣的列 :"; cin>>l; cout<<" 請(qǐng)依次輸入矩陣的

32、值: "; CMatrixm1(h,l); m1.input(); cout<>s; CMatrixm2=m1.shucheng(s); cout<

33、----"<

展開(kāi)閱讀全文
溫馨提示:
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. 裝配圖網(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ì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!