-n階魔方課程設(shè)計報告_第1頁
已閱讀1頁,還剩17頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  經(jīng)濟管理學(xué)院本科課程設(shè)計論文</p><p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計</b></p><p>  學(xué) 號: </p><p>  姓 名: </p><p>  班 級: &l

2、t;/p><p>  專 業(yè): 信息管理與信息系統(tǒng) </p><p>  系 別: 管理系 </p><p>  指導(dǎo)教師: </p><p>  2011 年 1 月 14日 吉 林</p><p><b>  目

3、錄</b></p><p><b>  第1章 引言概述</b></p><p>  數(shù)據(jù)結(jié)構(gòu)是一門理論性強、思維抽象、難度較大的課程,是基礎(chǔ)課和專業(yè)課之間的橋梁。該課程的先行課程是計算機基礎(chǔ)、程序設(shè)計語言、離散數(shù)學(xué)等,后續(xù)課程有操作系統(tǒng)、編譯原理、數(shù)據(jù)庫原理、軟件工程等。 通過本門課程的學(xué)習(xí),我們應(yīng)該能透徹地理解各種數(shù)據(jù)對象的特點,學(xué)會數(shù)據(jù)的組織方法和

4、實現(xiàn)方法,并進一步培養(yǎng)良好的程序設(shè)計能力和解決實際問題的能力,而且該課程的研究方法對我們學(xué)生在校和離校后的學(xué)習(xí)和工作,也有著重要的意義。  數(shù)據(jù)結(jié)構(gòu)是計算機科學(xué)與技術(shù)專業(yè)的一門核心專業(yè)基礎(chǔ)課程,在該專業(yè)的課程體系中起著承上啟下的作用,學(xué)好數(shù)據(jù)結(jié)構(gòu)對于提高理論認知水平和實踐能力有著極為重要的作用。學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的最終目的是為了獲得求解問題的能力。對于現(xiàn)實世界中的問題,應(yīng)該能從中抽象出一個適當(dāng)?shù)臄?shù)學(xué)模型,該數(shù)學(xué)模型在計算機內(nèi)部用相應(yīng)的數(shù)據(jù)結(jié)

5、構(gòu)來表示,然后設(shè)計一個解此數(shù)學(xué)模型的算法,再進行編程調(diào)試,最后獲得問題的解答?! ∵M行課程設(shè)計是為了加強編程能力的培養(yǎng),鼓勵我們在學(xué)習(xí)完理論知識之后多動手同時發(fā)揮我們自主學(xué)習(xí)的能力。相信通過數(shù)據(jù)結(jié)構(gòu)課程實踐,無論是理論知識,還是實踐動手能力,我們都會有不同程度上的提高。</p><p><b>  第2章 需求分析</b></p><p><b>  2.

6、1問題描述</b></p><p>  2.1.1語言描述:給定一奇數(shù)n,構(gòu)造一個n階魔陣。n階魔陣是一個n階方陣,其元素由自然數(shù)1,2,3,…,n2組成。魔陣的每一行元素之和,每列元素之和以及主、副對角線元素之和均相等。即對于給定的奇數(shù)n以及i=1,2,3,…,n,魔陣a滿足條件:</p><p>  要求輸出結(jié)果的格式要具有n階方陣的形式。</p><p

7、>  2.1.2算法概述:依次將自然數(shù)填入方陣中,共填n輪,每輪填n次。第一輪的第一次,將1填如入方陣的中間一行的最后一列位置。設(shè)前一次填入的位置是,每輪中第2至第n次將數(shù)填入,若遇到下列兩種情況之一,則填寫位置按以下規(guī)則調(diào)整。</p><p>  是最后一列(即j=n)位置,則將下一個數(shù)填入;</p><p>  是最后一行(即i=n)位置,則將下一個數(shù)填入;</p>

8、<p>  新一輪的第一次填入 。</p><p>  2.1.3舉例說明:當(dāng)n=3時,得到3*3魔陣:</p><p>  具體程序?qū)嵭羞^程如下:</p><p>  圖1-1 在中間行最后一列的位置上插入第一個數(shù)據(jù)1;</p><p>  圖1-2 在數(shù)據(jù)1的右下角位置上插入元素2(即i+1);</p><

9、p>  圖1-3 檢查2的右下方為空,即將3插入;</p><p>  圖1-4 3的右下方有數(shù)據(jù)1,故將4插入3的左方;</p><p>  圖1-5 4的右下方有空位置,插入5;</p><p>  圖1-6 將6插入;</p><p>  圖1-7 將7插入;</p><p>  圖1-8 將8插入;<

10、;/p><p><b>  圖1-9將9插入;</b></p><p><b>  2.2 基本要求</b></p><p>  要求輸出結(jié)果的格式要具有n階魔陣的形式。給定一奇數(shù)n,構(gòu)造一個n階魔</p><p>  陣。n階魔陣是一個n階方陣,其元素由自然數(shù)1,2,3,…,n2組成。魔陣的</

11、p><p>  每一行元素之和,每列元素之和以及主、副對角線元素之和均相等。遇到不合法數(shù)據(jù)時能有相應(yīng)的提示并加以處理,同時保證不會出現(xiàn)死循環(huán)。提供連續(xù)實現(xiàn)的功能。</p><p><b>  2.3測試數(shù)據(jù)</b></p><p><b>  第一組:1,n; </b></p><p><b>

12、;  第二組:2; </b></p><p><b>  第三組:3,y; </b></p><p><b>  第四組:3,a; </b></p><p><b>  第五組:1,3; </b></p><p><b>  第3章 概要設(shè)計</b

13、></p><p>  3.1 數(shù)據(jù)結(jié)構(gòu) </p><p>  此課程設(shè)計采用一維數(shù)組來存儲二維矩陣。利用指針和數(shù)組之間相互應(yīng)用,表達矩陣。所用一維數(shù)組來存儲二維矩陣的方法能夠使矩陣更容易操作,并可</p><p>  在開辟的連續(xù)存儲空間中能夠有效的存儲矩陣。</p><p>  則上例n=3在一維數(shù)組中的存儲為如下圖:</p

14、><p>  0 1 2 3 4 5 6 7 8 </p><p>  圖3-1 n=3時在一維數(shù)組中的存儲圖</p><p> ?。唧w的表示運行方法為以下程序: </p><p>  int *p=new int[n*n];</p&

15、gt;<p>  int i; </p><p>  for(i=0;i<n*n;i++)</p><p><b>  {</b></p><p>  p[i]=0; </p><p><b>  }<

16、/b></p><p>  i=n/2; </p><p>  int j=n-1;</p><p>  int k=1; </p><p>  p[i*n+j]=k;

17、 </p><p>  while(k<n*n) </p><p><b>  {</b></p><p>  if(!p[((i+1)%n)*n+((j+1)%n)]) </p>

18、<p><b>  {</b></p><p>  p[((i+1)%n)*n+((j+1)%n)]=k+1; </p><p>  i++; </p><p><b>  j++;</b></p><p><b

19、>  }</b></p><p>  else </p><p><b>  {</b></p><p>  p[(i%n)*n+((j-1)%n)]=k+1; </p><p>  j--;

20、 </p><p><b>  } </b></p><p>  k++; </p><p><b>  }</b></p><p>  *為了保證算法的健壯性,在程序的設(shè)計當(dāng)中,加

21、入了一些模塊。</p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  cout<<"************n階魔陣************"<<endl;</p><p>  cout<&

22、lt;"請輸入一個奇數(shù)n"<<endl;</p><p>  int n; //魔陣階數(shù)</p><p>  string nn; //浮點數(shù),用以判斷輸入數(shù)是否為整數(shù) </p><p>  while(cin>>nn,n=ConvertStringToInt(nn),n

23、%2==0||n<=0||IsContainInString(nn,'.'))</p><p><b>  {</b></p><p>  if(IsContainInString(nn,'.'))</p><p><b>  {</b></p><p>  c

24、out<<"請輸入一個整數(shù)!"<<endl;</p><p><b>  }</b></p><p>  else if(n%2==0)</p><p><b>  {</b></p><p>  cout<<"請不要輸入偶數(shù)!&qu

25、ot;<<endl;</p><p><b>  }</b></p><p>  else if(n<=0)</p><p><b>  {</b></p><p>  cout<<"請輸入一個大于0的數(shù)"<<endl;</p>

26、;<p><b>  }</b></p><p><b>  }</b></p><p> ?。O(shè)計模塊可進行連續(xù)計算,程序如下:</p><p>  string re;</p><p>  cout<<"繼續(xù)?(y/n)"<<endl;&

27、lt;/p><p>  while(cin>>re,!IsContainInString(re,'y')&& !IsContainInString(re,'n'))</p><p><b>  {</b></p><p>  cout<<"選擇無效,請重新選擇!&qu

28、ot;<<endl;</p><p><b>  }</b></p><p>  if(IsContainInString(re,'n'))</p><p><b>  {</b></p><p>  cout<<"謝謝使用,再見!"<

29、;<endl;</p><p><b>  break;</b></p><p><b>  }</b></p><p> ?。缬龅教厥馇闆r,可以用dos命令對程序進行操作,具體程序如下:</p><p>  system("pause");

30、 </p><p><b>  return 0;</b></p><p>  當(dāng)遇到輸入錯誤時,如,輸入的為浮點型數(shù)據(jù),則用一下模塊進行處理:</p><p>  int ConvertStringToInt(string re) </p><p><b>  {</b></

31、p><p>  int n=re.length();</p><p>  int i,t=0;</p><p>  for(i=0;i<n;i++)</p><p><b>  {</b></p><p>  if(re[i]<'0' || re[i]>'9&

32、#39;)</p><p><b>  return 0;</b></p><p>  t=t*10+re[i]-48;</p><p><b>  }</b></p><p>  return t; </p><p><b>  }</b></p

33、><p> ?。狪nt ConertStringToInt(string re)的流程圖如下:</p><p>  圖3-1 ConertStringToInt()函數(shù)流程圖</p><p>  *bool IsContainInString(string &a,char b)的流程圖如下:</p><p>  圖3-2 IsContai

34、nInString()函數(shù)流程圖</p><p><b>  第4章 詳細設(shè)計</b></p><p>  #include <iostream></p><p>  #include <iomanip></p><p>  #include <string></p>&

35、lt;p>  using namespace std;</p><p>  int ConvertStringToInt(string);</p><p>  bool IsContainInString(string &,char);</p><p>  int main()</p><p><b>  {</

36、b></p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  cout<<"************n階魔陣************"<<endl;</p><p>  cout<<

37、;"請輸入一個奇數(shù)n"<<endl;</p><p>  int n; //魔陣階數(shù) </p><p>  string nn; //浮點數(shù),用以判斷輸入數(shù)是否為整數(shù) </p><p>  while(cin>>nn,n=ConvertStringToInt(nn),n%

38、2==0||n<=0|| IsContainInString(nn,'.'))</p><p><b>  {</b></p><p>  if(IsContainInString(nn,'.'))</p><p><b>  {</b></p><p>  c

39、out<<"請輸入一個整數(shù)!"<<endl;</p><p><b>  }</b></p><p>  else if(n%2==0)</p><p><b>  {</b></p><p>  cout<<"請不要輸入偶數(shù)!&qu

40、ot;<<end</p><p><b>  }</b></p><p>  else if(n<=0)</p><p><b>  {</b></p><p>  cout<<"請輸入一個大于0的數(shù)"<<endl;</p>

41、<p><b>  }</b></p><p><b>  }</b></p><p>  int *p=new int[n*n];</p><p><b>  int i;</b></p><p>  for(i=0;i<n*n;i++)</p>

42、<p><b>  {</b></p><p>  p[i]=0; //將數(shù)組全部清零 </p><p><b>  }</b></p><p>  i=n/2; //將初始坐標(biāo)定為中間一行最后一頁 </p><p>  int j=n-1;&

43、lt;/p><p>  int k=1; //第一個被填的數(shù)設(shè)為1 </p><p>  p[i*n+j]=k; //填第一個數(shù) </p><p>  while(k<n*n) //需要循環(huán)n*n-1次 </p><p><b>  {</b></p>

44、<p>  if(!p[((i+1)%n)*n+((j+1)%n)]) //判斷當(dāng)前坐標(biāo)的右下方是否有數(shù) </p><p><b>  {</b></p><p>  p[((i+1)%n)*n+((j+1)%n)]=k+1; //將右下方數(shù)填為k+1 </p><p>  i++;

45、 //當(dāng)前坐標(biāo)移向右下方 </p><p><b>  j++;</b></p><p><b>  }</b></p><p>  else //右下方有數(shù) </p><p><b>

46、  {</b></p><p>  p[(i%n)*n+((j-1)%n)]=k+1; //將左方數(shù)填為k+1 </p><p>  j--; //當(dāng)前坐標(biāo)移向左方 </p><p><b>  } </b></p><p>

47、  k++; //被填數(shù)自增 </p><p><b>  }</b></p><p>  for(i=0;i<n;i++) //填數(shù)完畢,將矩陣輸出 </p><p><b>  {</b>&l

48、t;/p><p>  for(j=0;j<n;j++)</p><p><b>  {</b></p><p>  cout<<setw(4)<<p[i*n+j]; //格式控制 </p><p><b>  }</b></p>&l

49、t;p>  cout<<endl;</p><p><b>  }</b></p><p>  string re;</p><p>  cout<<"繼續(xù)?(y/n)"<<endl; //是否繼續(xù) </p><p>  

50、while(cin>>re,!IsContainInString(re,'y') && !IsContainInString(re,'n')) //如果既沒有輸入Y,也沒有輸入N,則認定</p><p>  //非法輸入,重新輸入直到輸入合法為止 </p><p><b>  {</b></p&g

51、t;<p>  cout<<"選擇無效,請重新選擇!"<<endl;</p><p><b>  }</b></p><p>  if(IsContainInString(re,'n')) //如果輸入N,則退出 </p><p><b>  {<

52、/b></p><p>  cout<<"謝謝使用,再見!"<<endl;</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  }</b></p>

53、<p>  system("pause"); //外部DOS命令pause,用于暫停以監(jiān)測</p><p><b>  //結(jié)果</b></p><p><b>  return 0;</b></p><p><b>  }</b><

54、;/p><p>  int ConvertStringToInt(string re) //將字符串轉(zhuǎn)換成整型數(shù)的函數(shù),若 </p><p>  //字符串中部全為字符,則返回0</p><p><b>  {</b></p><p>  int n=re.length();</p><p&

55、gt;  int i,t=0;</p><p>  for(i=0;i<n;i++)</p><p><b>  {</b></p><p>  if(re[i]<'0' || re[i]>'9')</p><p><b>  return 0;</b&g

56、t;</p><p>  t=t*10+re[i]-48;</p><p><b>  }</b></p><p><b>  return t;</b></p><p><b>  }</b></p><p>  bool IsContainInStr

57、ing(string &a,char b) //判斷字符串中是否包</p><p><b>  //含指定字符 </b></p><p><b>  {</b></p><p>  int n=a.length();</p><p><b>  int i;&

58、lt;/b></p><p>  for(i=0;i<n;i++)</p><p><b>  {</b></p><p>  if(a[i]==b)</p><p>  return true;</p><p><b>  }</b></p>&l

59、t;p>  return false;</p><p><b>  }</b></p><p><b>  第5章 調(diào)試分析</b></p><p>  5.1輸入界面(1):</p><p>  圖5-1 輸入1,再輸入n</p><p>  5.2輸入界面(2):

60、</p><p><b>  圖5-2 輸入2</b></p><p>  5.3輸入界面(3):</p><p>  圖5-3 輸入3,再輸入y</p><p>  5.4輸入界面(4):</p><p>  圖5-4 輸入3,再輸入a</p><p>  5.5輸

61、入界面(5):</p><p>  圖5-5 輸入1.3</p><p>  為了使程序健壯行良好,我進行了多次調(diào)試,力求盡列出所有的可能數(shù)據(jù),并最程序進行修改,使之成為一個優(yōu)秀的程序。本程序是關(guān)于二維數(shù)組的,時間復(fù)雜度為O(n2 )。 </p><p><b>  第6章 課設(shè)總結(jié)</b></p><p> 

62、 通過此次課程設(shè)計,我深化了對數(shù)據(jù)結(jié)構(gòu)的基本概念、理論和方法的理解,把所學(xué)的理論知識用于處理實際問題。這種學(xué)以致用的感覺非常好,讓自己真正的掌握了所學(xué)的知識,并將其利用在實際問題中。還有就是C++的面向?qū)ο蟮某绦蛟O(shè)計理念,對程序設(shè)計是一個好的啟發(fā)。其中,在程序的調(diào)試中遇到了一些問題,這讓我重新審視到了做好一個程序需要具備哪些能力。實踐能給人以成就之感,我是以著“態(tài)度決定一切”的心態(tài)對待此次《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計的,于是偶然又必然地收獲了諸

63、多,概而言之,大約以下幾點:</p><p>  1.溫故而知新。課程設(shè)計發(fā)端之始,對知識系統(tǒng)全面地進行了梳理,遇到難處先是自己思考查資料,再向同學(xué)請教,掌握了基本理論知識,而且對理論知識進行實踐應(yīng)用,使得理解更加深刻,學(xué)會了如何思考的思維方式。</p><p>  2實踐出真知。時至今日,課程設(shè)計基本告成,切身領(lǐng)悟有了思路還需要用實踐進行考驗,才明曉實踐出真知。如在進行算法分析時要深刻地

64、從正確性、穩(wěn)健性、可讀性、時間復(fù)雜度等方面進行考慮,在一個算法中,進行簡單操作的次數(shù)越少,其運行時間也就相對的越短;次數(shù)越多,其運行時間也就相對的越長。同樣很多時候時間的長短與程序的難易程度(實現(xiàn)的所要付出的代價)呈反比。通過這次課設(shè)使我深刻理解了“不為則不知,無為則無知,實踐出真知”這句名言。 </p><p>  3.創(chuàng)新求發(fā)展?!皠?chuàng)新”目前已經(jīng)提升到國家發(fā)展戰(zhàn)略地位,足見“創(chuàng)新”的舉足輕重。因此,我們要從小

65、處著手,順應(yīng)時代發(fā)展潮流,在課程設(shè)計中不忘在小處創(chuàng)新,未必是創(chuàng)新技術(shù),但凡創(chuàng)新思維亦可,未必成功,只要實現(xiàn)創(chuàng)新思維培育和鍛煉即可。</p><p>  4.過而能改,善莫大焉。至善至美,是人類永恒的追求。但是,不從忘卻“金無足赤,人無完人”,我們換種思維方式,去惡亦是至善,改錯亦為至美。在課程設(shè)計過程中,我們不斷發(fā)現(xiàn)錯誤,不斷改正,不斷領(lǐng)悟,不斷獲取。最終的檢測調(diào)試環(huán)節(jié),本身就是在踐行“過而能改,善莫大焉”的知行

66、觀。</p><p>  一邊制作一邊探索,發(fā)現(xiàn)理論和實踐要充分地結(jié)合,是需要扎實的基本功的,解決實際的應(yīng)用問題,在理解了數(shù)據(jù)結(jié)構(gòu)內(nèi)在的邏輯關(guān)系的基礎(chǔ)上,深入討論它們在計算機中的存儲表示,結(jié)合上機進行算法及存儲表示的實現(xiàn)。進一步提高自身的綜合運用所學(xué)知識處理實際問題的能力,強化面向?qū)ο蟮某绦蛟O(shè)計理念,從而使自己有所提高。</p><p>  這就表明學(xué)好基礎(chǔ)知識是理論付諸實踐的前提。在這次

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論