c#課程設(shè)計(jì)--矩陣的按行按列讀取功能及矩陣的基本計(jì)算_第1頁
已閱讀1頁,還剩16頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  C#課程設(shè)計(jì)報(bào)告書</b></p><p>  課題矩陣的按行按列讀取功能</p><p><b>  及矩陣的基本計(jì)算</b></p><p>  院 系 航空航天工程學(xué)部(院) </p><p>  專 業(yè) 飛行器設(shè)計(jì)與工程 </p>

2、;<p><b>  摘要</b></p><p>  作為一名飛行器設(shè)計(jì)的大二學(xué)生,在計(jì)算方法和線性代數(shù)課上已經(jīng)學(xué)習(xí)了矩陣的相關(guān)知識(shí),但是,由于課時(shí)緊,并沒有很好的了解計(jì)算的根本原理,在計(jì)算時(shí)難免會(huì)遇到一些難題。因此,我計(jì)劃設(shè)計(jì)一個(gè)程序,可以進(jìn)行矩陣的基本運(yùn)算,并輸出結(jié)果,讓自己更加清楚計(jì)算的基本原理。</p><p>  該程序是用VISUAL ST

3、UDIO 2010,通過C#語言進(jìn)行相關(guān)代碼的編寫,進(jìn)行矩陣的按行按列讀取、轉(zhuǎn)置、高斯消元,求特征值。</p><p>  關(guān)鍵詞: 計(jì)算方法,線性代數(shù),矩陣的基本運(yùn)算,VISUAL STUDIO 2010,</p><p><b>  C#語言</b></p><p><b>  目錄</b></p>&l

4、t;p><b>  摘要2</b></p><p>  第一章 課設(shè)研究背景4</p><p><b>  1.1研究背景4</b></p><p>  1.2程序思路圖4</p><p>  第二章 各部分程序5</p><p>  2.1 按行按列

5、讀取生成矩陣程序5</p><p>  2.2 求轉(zhuǎn)置程序7</p><p>  2.3 高斯消元程序8</p><p>  2.3.1 輸出方程組的解程序8</p><p>  2.3.2 利用高斯消元法求線性方程組的解程序8</p><p>  2.3.3 選擇主元素程序10</p>

6、<p>  2.3.4 打印矩陣程序11</p><p>  第三章 程序設(shè)計(jì)中的重難點(diǎn)分析15</p><p>  第四章 課設(shè)總結(jié)16</p><p><b>  參考文獻(xiàn)17</b></p><p>  第一章 課設(shè)研究背景</p><p><b> 

7、 1.1研究背景</b></p><p>  作為一名飛行器設(shè)計(jì)的大二學(xué)生,在計(jì)算方法和線性代數(shù)課上已經(jīng)學(xué)習(xí)了矩陣的相關(guān)知識(shí),但是,由于課時(shí)緊,并沒有很好的了解計(jì)算的根本原理,在計(jì)算時(shí)難免會(huì)遇到一些難題。因此,我計(jì)劃設(shè)計(jì)一個(gè)程序,可以進(jìn)行矩陣的基本運(yùn)算,并輸出結(jié)果,讓自己更加清楚計(jì)算的基本原理。</p><p><b>  1.2程序思路圖</b><

8、/p><p>  給定矩陣的行數(shù)和列數(shù)</p><p>  輸入數(shù)據(jù),按行按列讀取,生成</p><p>  求轉(zhuǎn)置 選主元 </p><p>  輸出結(jié)果 化為上三角矩陣</p><p><b>  求x </b>

9、;</p><p><b>  輸出結(jié)果</b></p><p>  圖1.1 程序思路圖</p><p>  第二章 各部分程序</p><p>  2.1 按行按列讀取生成矩陣程序</p><p><b>  int a, b;</b></p><

10、;p>  Console.WriteLine("請(qǐng)輸入矩陣的行數(shù):");</p><p>  a = int.Parse(Console.ReadLine());</p><p>  Console.WriteLine("請(qǐng)輸入矩陣的列數(shù):");</p><p>  b = int.Parse(Console.ReadL

11、ine());</p><p>  int[,] juzhen = new int[a, b];</p><p>  for (int i = 0; i < juzhen.GetLength(0); i++)</p><p><b>  {</b></p><p>  for (int j = 0; j <

12、juzhen.GetLength(1); j++)</p><p><b>  {</b></p><p>  Console.WriteLine("請(qǐng)輸入一個(gè)數(shù):");</p><p>  juzhen[i, j] = int.Parse(Console.ReadLine());</p><p>&

13、lt;b>  }</b></p><p><b>  }</b></p><p>  Console.WriteLine("矩陣為:");</p><p>  for (int i = 0; i < juzhen.GetLength(0); i++)</p><p><b

14、>  {</b></p><p>  for (int j = 0; j < juzhen.GetLength(1); j++)</p><p><b>  {</b></p><p>  Console.Write("{0,5:d}", juzhen[i, j]);</p><p

15、><b>  }</b></p><p>  Console.WriteLine();</p><p><b>  }</b></p><p>  Console.ReadLine();</p><p>  圖2.1 矩陣的輸出(一)</p><p>  圖2.2

16、矩陣的輸出(二)</p><p><b>  2.2 求轉(zhuǎn)置程序</b></p><p>  int[,] zhuanzhi = new int[b, a];</p><p>  Console.WriteLine("轉(zhuǎn)置為:");</p><p>  for (int i = 0; i < j

17、uzhen.GetLength(1); i++)</p><p><b>  {</b></p><p>  for (int j = 0; j < juzhen.GetLength(0); j++)</p><p><b>  {</b></p><p>  zhuanzhi[i, j] =

18、 juzhen[j, i];</p><p>  Console.Write(" " + zhuanzhi[i, j]);</p><p><b>  }</b></p><p>  Console.WriteLine();</p><p><b>  }</b></p&g

19、t;<p>  Console.ReadLine();</p><p>  圖2.3 矩陣的轉(zhuǎn)置</p><p>  2.3 高斯消元程序</p><p>  2.3.1 輸出方程組的解程序</p><p><b>  int n=4; </b></p><p>  double

20、[,]juzhen={{10,-1,2,0,6},{-1,11,-1,3,25},{2,-1,10,-1,-11},</p><p>  {0,3,-1,8,5}}; </p><p>  double[]x=new double[n];</p><p>  Gauss(n, juzhen, x); </p><p>  Console.Wr

21、iteLine("方程組的解為:");</p><p>  for (int i = 0; i < n; i++)</p><p><b>  {</b></p><p>  Console.Write("x({0})={1,8:F3} ", i, x[i]);</p><p&g

22、t;<b>  }</b></p><p>  Console.WriteLine();</p><p>  2.3.2 利用高斯消元法求線性方程組的解程序</p><p>  public static void Gauss(int n, double[,] a, double[] x) </p><p><b

23、>  { </b></p><p>  double d; </p><p>  Console.WriteLine("高斯消去法解方程組的中間過程"); </p><p>  Console.WriteLine("============================"); </p><

24、;p>  Console.WriteLine("中間過程"); </p><p>  Console.WriteLine("增廣矩陣:");</p><p>  printArray(n, a);</p><p>  Console.WriteLine();</p><p>  for(int k

25、 = 0; k < n; k++)</p><p><b>  {</b></p><p>  Console.WriteLine("第{0}步", k + 1); </p><p>  Console.WriteLine("初始矩陣:);</p><p>  printArray(n

26、, a);</p><p>  Console.WriteLine();</p><p>  selectMainElement(n, k, a); </p><p>  Console.WriteLine("選擇主元素后的矩陣:");</p><p>  printArray(n, a);</p><

27、p>  Console.WriteLine();</p><p>  d = a[k, k];</p><p>  for (int j = k; j <= n; j++)</p><p><b>  {</b></p><p>  a[k, j] = a[k, j] / d;</p><

28、p><b>  }</b></p><p>  Console.WriteLine("將第{0}行中a[{0},{0}]化為a1后的矩</p><p>  陣:", k + 1); </p><p>  printArray(n, a); </p><p>  Console.WriteLine

29、();</p><p>  for(int i = k + 1; i < n; i++) </p><p><b>  { </b></p><p>  d = a[i, k];</p><p>  for (int j = k; j <= n; j++)</p><p><b&

30、gt;  {</b></p><p>  a[i, j] = a[i, j] - d * a[k, j];</p><p><b>  }</b></p><p><b>  } </b></p><p>  Console.WriteLine("消元后的矩陣:");

31、 </p><p>  printArray(n, a); </p><p>  Console.WriteLine(); </p><p><b>  }</b></p><p>  x[n - 1] = a[n - 1, n]; </p><p>  for (int i = n - 1; i

32、 >= 0; i--) </p><p><b>  { </b></p><p>  x[i] = a[i, n];</p><p>  for (int j = i + 1; j < n; j++)</p><p><b>  {</b></p><p>  

33、x[i] = x[i] - a[i, j] * x[j];</p><p><b>  }</b></p><p><b>  } </b></p><p><b>  }</b></p><p>  2.3.3 選擇主元素程序</p><p>  p

34、ublic static void selectMainElement(int n, int k, double[,] a)</p><p><b>  {</b></p><p>  double t, mainElement;</p><p><b>  int l;</b></p><p> 

35、 mainElement = Math.Abs(a[k, k]);</p><p><b>  l = k; </b></p><p>  for(int i = k + 1; i < n; i++) </p><p><b>  { </b></p><p>  if (mainElemen

36、t < Math.Abs(a[i, k]))</p><p><b>  { </b></p><p>  mainElement = Math.Abs(a[i, k]);</p><p><b>  l = i;</b></p><p><b>  }</b></

37、p><p><b>  }</b></p><p>  if (l != k) </p><p><b>  {</b></p><p>  for (int j = k; j <= n; j++) </p><p><b>  { </b></

38、p><p>  t = a[k, j];</p><p>  a[k, j] = a[l, j];</p><p>  a[l, j] = t;</p><p><b>  }</b></p><p><b>  }</b></p><p><b&g

39、t;  }</b></p><p>  2.3.4 打印矩陣程序</p><p>  public static void printArray(int n, double[,] a) </p><p><b>  {</b></p><p>  for(int i = 0; i < n; i++)

40、</p><p><b>  {</b></p><p>  for (int j = 0; j <= n; j++)</p><p><b>  {</b></p><p>  Console.Write("{0,10:F6} ", a[i, j]);</p>

41、<p><b>  }</b></p><p>  Console.WriteLine();</p><p><b>  } </b></p><p><b>  }</b></p><p>  圖2.4 增廣矩陣</p><p>  

42、圖2.5 高斯消元第一步</p><p>  圖2.6 高斯消元第二步</p><p>  圖2.7 高斯消元第三步</p><p>  圖2.8 高斯消元第四步</p><p>  圖2.9 方程組的解</p><p>  第三章 程序設(shè)計(jì)中的重難點(diǎn)分析</p><p>  在本次

43、課程設(shè)計(jì)中的難點(diǎn)就是高斯消元。高斯消元中,第一步要進(jìn)行選主元,即將x1對(duì)應(yīng)的系數(shù)從大到小排列,然后將方程的順序交換。這一步用的是c#中最基本的排序功能。同事,這一步還用到了for循環(huán)的嵌套。第二步是將原矩陣化為上三角矩陣,這一步用到了for循環(huán)的嵌套并多次使用。第三步是輸出方程組的解,這一步同樣用到了for循環(huán),但不是嵌套。</p><p><b>  第四章 課設(shè)總結(jié)</b></p

44、><p>  本次為期兩周的課程設(shè)計(jì),使我不僅將所學(xué)到的C#知識(shí)得以實(shí)踐,還學(xué)到了很多在課堂上沒有學(xué)到的東西,這對(duì)我的學(xué)習(xí)幫助很大。</p><p>  通過獨(dú)立完成一個(gè)自己比較喜歡的題目,并在題目的編寫過程中,不斷的遇到問題和解決問題,不僅可以鍛煉我的運(yùn)用c#的能力,還可以增加我對(duì)c#的喜愛,并激勵(lì)我在以后去學(xué)習(xí)并研究它。</p><p>  同時(shí),通過課設(shè),我還發(fā)現(xiàn)

45、了自己學(xué)習(xí)中的很多不足。比如,由于我所學(xué)的知識(shí)只是皮毛,因此無法應(yīng)對(duì)所有出現(xiàn)的問題,不得不尋求幫助。在解決問題的同時(shí),我也弄明白了很多新的未知的東西,這種收獲的喜悅是無法用語言形容的。的確,計(jì)算機(jī)語言是復(fù)雜和枯燥的,但是掌握好一門語言,不僅是你多了一種技術(shù),而且能夠幫助你在以后的找工作中脫穎而出。</p><p>  經(jīng)過課設(shè),我更加堅(jiān)定了以后好好學(xué)習(xí)c#的決心。荀子曾說過“不登高山,不知天之高也;不臨深溪,不知

46、地之厚也?!睂W(xué)以致用才是目的。同樣,有了興趣,學(xué)習(xí)才會(huì)變?yōu)橐患鞓返氖拢?lt;/p><p><b>  參考文獻(xiàn)</b></p><p>  [1] 明日科技著 C#4.0從入門到精通 機(jī)械工業(yè)出版社 2011</p><p>  [2] 明日科技著 C#經(jīng)典編程220例 清華大學(xué)出版社2012</p><p>  [3

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論