萬年歷課程設(shè)計_第1頁
已閱讀1頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計</b></p><p><b>  設(shè)計說明書</b></p><p>  數(shù)學(xué)與計算機科學(xué)學(xué)院</p><p>  2012 年 9 月 8 日</p><p><b>  課程設(shè)計任務(wù)書</b></p><

2、p>  2012—2013學(xué)年第1學(xué)期</p><p>  課程設(shè)計名稱: 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計 </p><p>  設(shè)計題目: 萬年歷的實現(xiàn) </p><p>  完成期限:自

3、2012 年 8 月 27 日至 2012 年 9 月 8 日共 2 周</p><p>  設(shè)計依據(jù)、要求及主要內(nèi)容(可另加附頁):</p><p>  運用C/ C++結(jié)構(gòu)體、函數(shù)、數(shù)據(jù)結(jié)構(gòu)等基知識,按以下要求編程實現(xiàn)萬年歷的功能:1) 闡述設(shè)計思想,畫出流程圖;2) 輸入任一年,判斷該年是否為閏年; 輸入年月日計算該日為當年的那一天;3).輸入任一年,顯示該年的日歷

4、,日歷包括陽歷、農(nóng)歷、節(jié)氣;4). 說明測試方法,寫出完整的運行結(jié)果,較好的界面設(shè)計.</p><p><b>  設(shè)計要求:</b></p><p>  1)問題分析和任務(wù)定義:根據(jù)設(shè)計題目的要求,充分地分析和理解問題,明確問題要求做什么?(而不是怎么做?)限制條件是什么?確定問題的輸入數(shù)據(jù)集合。</p><p>  2)邏輯設(shè)計:對問題描述

5、中涉及的操作對象定義相應(yīng)的數(shù)據(jù)類型,并按照以數(shù)據(jù)結(jié)構(gòu)為中心的原則劃分模塊,定義主程序模塊和各抽象數(shù)據(jù)類型。邏輯設(shè)計的結(jié)果應(yīng)寫出每個抽象數(shù)據(jù)類型的定義(包括數(shù)據(jù)結(jié)構(gòu)的描述和每個基本操作的功能說明),各個主要模塊的算法,并畫出模塊之間的調(diào)用關(guān)系圖;</p><p>  3)詳細設(shè)計:定義相應(yīng)的存儲結(jié)構(gòu)并寫出各函數(shù)的偽碼算法。在這個過程中,要綜合考慮系統(tǒng)功能,使得系統(tǒng)結(jié)構(gòu)清晰、合理、簡單和易于調(diào)試,抽象數(shù)據(jù)類型的實現(xiàn)盡

6、可能做到數(shù)據(jù)封裝,基本操作的規(guī)格說明盡可能明確具體。詳細設(shè)計的結(jié)果是對數(shù)據(jù)結(jié)構(gòu)和基本操作做出進一步的求精,寫出數(shù)據(jù)存儲結(jié)構(gòu)的類型定義,寫出函數(shù)形式的算法框架;</p><p>  4)程序編碼:把詳細設(shè)計的結(jié)果進一步求精為程序設(shè)計語言程序。同時加入一些注解和斷言,使程序中邏輯概念清楚;</p><p>  5)程序調(diào)試與測試:采用自底向上,分模塊進行,即先調(diào)試低層函數(shù)。能夠熟練掌握調(diào)試工具

7、的各種功能,設(shè)計測試數(shù)據(jù)確定疑點,通過修改程序來證實它或繞過它。調(diào)試正確后,認真整理源程序及其注釋,形成格式和風格良好的源程序清單和結(jié)果;</p><p>  6)結(jié)果分析:程序運行結(jié)果包括正確的輸入及其輸出結(jié)果和含有錯誤的輸入及其輸出結(jié)果。算法的時間、空間復(fù)雜性分析;</p><p>  7)編寫課程設(shè)計報告;</p><p>  以上要求中前三個階段的任務(wù)完成后

8、,先將設(shè)計說明書的草稿交指導(dǎo)老師面審,審查合格后方可進入后續(xù)階段的工作。設(shè)計工作結(jié)束后,經(jīng)指導(dǎo)老師驗收合格后將設(shè)計說明書打印裝訂,并進行答辯。</p><p>  指導(dǎo)教師(簽字): 教研室主任(簽字): </p><p>  批準日期: 2012年 8 月 27 日</p><p><

9、b>  摘 要</b></p><p>  設(shè)計了一個萬年歷軟件,該萬年歷具有如下的三大功能:①輸入任一年,判斷該年是否為閏年;②輸入任一年,顯示該年的日歷;③輸入年月日計算該日為當年的那一天,及該日為星期幾。</p><p>  本萬年歷采用Visual C++6.0工具作為軟件開發(fā)環(huán)境,運用了C語言、函數(shù)、數(shù)據(jù)結(jié)構(gòu)等基礎(chǔ)知識,該萬年操作簡單,界面清晰,易為用戶所接受

10、。</p><p>  關(guān)鍵詞:萬年歷; 閏年;平年;查詢</p><p><b>  目 錄</b></p><p><b>  1 課題描述1</b></p><p><b>  2 需求分析2</b></p><p><b>

11、  3 概要設(shè)計3</b></p><p><b>  4 詳細設(shè)計6</b></p><p><b>  5 程序編碼8</b></p><p>  6 程序調(diào)試與測試14</p><p><b>  7 結(jié)果分析17</b></p>&l

12、t;p><b>  8 總結(jié)19</b></p><p><b>  參考文獻20</b></p><p><b>  1 課題描述</b></p><p>  運用C語言及數(shù)據(jù)結(jié)構(gòu)等的基礎(chǔ)知識,按以下要求編程實現(xiàn)萬年歷的功能:</p><p>  1)輸入任一年,判

13、斷該年是否為閏年;</p><p>  2)輸入任一年,顯示該年的日歷;</p><p>  3)輸入年月日計算該日為當年的那一天;</p><p>  4)判斷輸入的合法性;</p><p>  5)說明測試方法,,寫出完整的運行結(jié)果,較好的界面設(shè)計。</p><p><b>  2 需求分析</b&

14、gt;</p><p>  要求1):閏年的判斷。首先應(yīng)該判斷輸入年份是否合法,如果輸入年份合法,則利用閏年的判斷規(guī)則判斷該年是否為閏年。閏年的判斷規(guī)則是︰如果輸入的年份能被4整除且不能夠被100整除,則該年肯定是閏年。在既能被4,也能被100整除的年份中,還能被400整除的也是閏年,否則是平年。</p><p>  要求2):輸出某年的年歷。輸出時首先應(yīng)判斷該年是否為閏年,閏年二月29天

15、,平年二月28天,還應(yīng)注意該年每月的天數(shù)。難點在于星期的判斷。計算方法為︰平年一年有365天,閏年一年為366天,從公元元年開始算起至該年的某月某日,總天數(shù)累加和除7取余及為星期幾。(注︰余數(shù)為0時,代表星期天)</p><p>  要求3):判斷輸入是否合法??梢韵扰袛噍斎氲哪攴菔欠裥∮?,再次判斷月份是否有小于零或超出12,如果通過此判斷合法,再判斷天數(shù),各月的天數(shù)不能小于零或超過其應(yīng)有的天數(shù)。( 例︰如果該

16、年是閏年,二月份不能超過29天,如果是該年平年,二月份不能超過28天;無論平年閏年,6月份的天數(shù)都不能超過30天) 在查詢過程中,如果發(fā)現(xiàn)輸入不合法或者不滿足輸入要求,則要求重新輸入。</p><p><b>  3 概要設(shè)計</b></p><p>  首先建立幾個具有以下功能的子函數(shù):閏年的判斷、計算總天數(shù)、計算星期、打印年歷、計算需要查詢的日期是當年第幾天及星期

17、幾。</p><p>  程序劃分為三個功能模塊:閏年的判斷、打印年歷、日期的查詢,如圖3.1所示:</p><p>  圖3.1 功能模塊圖</p><p>  主函數(shù)與建立的子函數(shù)及各子函數(shù)之間的調(diào)用關(guān)系,如圖3.2所示:</p><p>  圖3.2 模塊調(diào)用關(guān)系圖</p><p>  、求閏年流程圖如圖3.3

18、所示:</p><p>  圖3.3 判斷閏年流程圖</p><p>  2)、打印年歷流程圖如圖3.4所示:</p><p><b>  否</b></p><p><b>  是</b></p><p>  圖3.4 打印年歷關(guān)系圖</p><p>

19、;  3)、 整體程序主要流程圖如圖3.5所示:</p><p>  圖3.5 整個程序流程圖</p><p><b>  4 詳細設(shè)計</b></p><p> ?、牛蓚€整型數(shù)組leapDay[12]與noleapDay[12]分別存儲閏年與平年的每月天數(shù);</p><p> ?、疲甶nt checkLeapy

20、ear(int Year) ∥判斷閏年的函數(shù)</p><p><b>  其核心語句為:</b></p><p>  if(Year%4==0&&Year%100!=0||Year%400 == 0)</p><p>  return true;</p><p><b>  else</

21、b></p><p>  return false;</p><p>  ⑶.int calcuDays(int year,int month,int day) ∥計算總天數(shù)函數(shù)</p><p><b>  其核心語句為:</b></p><p>  for(i=1;i<year;i++ )</p&g

22、t;<p><b>  {</b></p><p>  if(checkLeapyear(i))</p><p>  days+= 366; //閏年加366天</p><p><b>  else</b></p><p>  days+= 365; //

23、平年加365天</p><p><b>  }</b></p><p>  for(j=1;j<month;j++ ) </p><p><b>  {</b></p><p>  if(checkLeapyear(year))</p><p>  mon=mon+

24、leapDay[j-1];</p><p><b>  else</b></p><p>  mon = mon+noleapDay[j-1];</p><p><b>  }</b></p><p>  days=days+mon+day; </p><p

25、> ?、龋甶nt calcuWeek(int totalDays) // 計算星期函數(shù)</p><p><b>  其核心語句為:</b></p><p>  weeknumber=totalDays%7;</p><p> ?、桑畍oid outputyear(int nowYear ) // 打

26、印年歷函數(shù)</p><p><b>  其核心語句為:</b></p><p>  for(i=0;i<12;i++)</p><p><b>  {</b></p><p>  days=calcuDays(nowYear,i+1,1); </p><p>  w

27、eeknumber=calcuWeek(days); //計算該年一月一日為星期幾 </p><p>  if (checkLeapyear(nowYear)) </p><p>  monthDay = leapDay[i]; //如果該年為閏年,采用閏年每月天數(shù)</p><p><b>  else</b>

28、</p><p>  monthDay = noleapDay[i]; //如果該年為平年,采用平年每月天數(shù) </p><p>  printf( "-----------%4d年%02d月-----------\n",nowYear,i+1 );</p><p>  printf( "%-5s%-5s%-5s%-5s%-5s%-5

29、s%-5s\n","天","一","二","三","四","五","六" );</p><p>  for(j=1;j<=monthDay;j++)</p><p><b>  {</b></p>&

30、lt;p>  if(j==1) //如果天數(shù)為當月的一號,將其移動到它的星期下并打印</p><p><b>  {</b></p><p>  for(k=0;k<weeknumber;k++) </p><p>  printf("%-5s"," ");</p>

31、;<p><b>  }</b></p><p>  printf("%-5d",j);</p><p>  if(weeknumber%7==6 ) //如果星期數(shù)為星期六,換行</p><p>  printf("\n");</p><p>  weeknu

32、mber=calcuWeek(days+j); //求下一天的星期數(shù)</p><p><b>  }</b></p><p>  printf("\n");</p><p><b>  }</b></p><p>  ⑹.void outputmenu() // 打印系統(tǒng)

33、菜單函數(shù)</p><p> ?、耍甶nt checkhefa(int year,int month,int day ) // 輸入合法性檢查函數(shù),比較簡單</p><p>  ⑻.int calcuday(int year,int month,int day) //計算某年某月某日為該年的第幾天</p><p> ?、停畍oid Outputday(int no

34、wYear,int nowMonth,int nowDay) //打印某年某日星期幾及其該年的第幾天函數(shù)</p><p> ?、危畍oid main() //主函數(shù)</p><p><b>  {</b></p><p><b>  }∥調(diào)用其它函數(shù)</b></p><

35、;p><b>  5 程序編碼</b></p><p>  #include <stdio.h></p><p>  #include <stdlib.h></p><p>  #define true 1</p><p>  #define false 0</p><p

36、>  int leapDay[12]={31,29,31,30,31,30,31,31,30,31,30,31}; //存儲閏年每月天數(shù)</p><p>  int noleapDay[12]={31,28,31,30,31,30,31,31,30,31,30,31}; //存儲非閏年每月天數(shù)</p><p>  int checkLeapyear(int Year) // 判

37、斷是否閏年</p><p><b>  {</b></p><p>  if(Year%4==0&&Year%100!=0||Year%400 == 0)</p><p>  return true;</p><p><b>  else</b></p><p&g

38、t;  return false;</p><p><b>  }</b></p><p>  int calcuDays(int year,int month,int day)// 計算總天數(shù)</p><p><b>  {</b></p><p><b>  int i,j;</

39、b></p><p>  int days=0,mon=0;</p><p>  for(i=1;i<year;i++ )</p><p><b>  {</b></p><p>  if(checkLeapyear(i))</p><p>  days+= 366; /

40、/閏年加366天</p><p><b>  else</b></p><p>  days+= 365; //平年加365天</p><p><b>  }</b></p><p>  for(j=1;j<month;j++ ) </p><p>

41、<b>  {</b></p><p>  if(checkLeapyear(year))</p><p>  mon=mon+leapDay[j-1];</p><p><b>  else</b></p><p>  mon = mon+noleapDay[j-1];</p>&l

42、t;p><b>  }</b></p><p>  days=days+mon+day; //總天數(shù)</p><p>  return days;</p><p><b>  }</b></p><p>  int calcuWeek(int totalDays

43、) // 計算星期幾</p><p><b>  {</b></p><p>  int weeknumber;</p><p>  weeknumber=totalDays%7; //天數(shù)除7取余為星期</p><p>  return weeknumber;<

44、/p><p><b>  }</b></p><p>  void outputyear(int nowYear ) // 打印年歷</p><p><b>  {</b></p><p>  int i,monthDay,days,weeknumber,j,k;</p>

45、<p>  for(i=0;i<12;i++)</p><p><b>  {</b></p><p>  days=calcuDays(nowYear,i+1,1); </p><p>  weeknumber=calcuWeek(days); //計算該年一月一日為星期幾 </p>

46、;<p>  if (checkLeapyear(nowYear)) </p><p>  monthDay = leapDay[i]; //如果該年為閏年,采用閏年每月天數(shù)</p><p><b>  else</b></p><p>  monthDay = noleapDay[i]; //如果該年為平年,采用平年

47、每月天數(shù) </p><p>  printf( "-----------%4d年%02d月-----------\n",nowYear,i+1 );</p><p>  printf( "%-5s%-5s%-5s%-5s%-5s%-5s%-5s\n","天","一","二","三&

48、quot;,"四","五","六" );</p><p>  for(j=1;j<=monthDay;j++)</p><p><b>  {</b></p><p>  if(j==1) //如果天數(shù)為當月的一號,將其移動到它的星期下并打印</p>

49、<p><b>  {</b></p><p>  for(k=0;k<weeknumber;k++) </p><p>  printf("%-5s"," ");</p><p><b>  }</b></p><p>  printf(

50、"%-5d",j);</p><p>  if(weeknumber%7==6 ) //如果星期數(shù)為星期六,換行</p><p>  printf("\n");</p><p>  weeknumber=calcuWeek(days+j); //求下一天的星期數(shù)</p><p><b>

51、;  }</b></p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  void outputmenu() // 打印系統(tǒng)菜單</p><p>

52、<b>  {</b></p><p>  printf("\t萬年歷查詢系統(tǒng)\n");</p><p>  printf("\n******************************");</p><p>  printf("\n0.退出");</p><p

53、>  printf("\n1.查詢某年是否是閏年");</p><p>  printf("\n2.打印某年的年歷");</p><p>  printf("\n3.查詢某年某月某日為該年的那一天及星期幾");</p><p>  printf("\n********************

54、*********\n");</p><p>  printf("\n請選擇:");</p><p><b>  }</b></p><p>  int checkhefa(int year,int month,int day ) // 輸入合法性檢查</p><p><b> 

55、 {</b></p><p>  if(year<=0) //如果輸入年份小于零,輸入的年份不合法 </p><p><b>  {</b></p><p>  printf("輸入年份不合法!\n");</p><p>  r

56、eturn false;</p><p><b>  }</b></p><p>  if(month<=0||month>12) //如果輸入月份小于零或大于12,輸入的月份不合法</p><p><b>  {</b></p><p>  printf(&

57、quot;輸入月份不合法!\n");</p><p>  return false; </p><p><b>  }</b></p><p>  if(day<=0||(day>leapDay[month-1]&&checkLeapyear(year))) //如果該年為閏年,輸入的天數(shù)小于零或大于該

58、年該月所應(yīng)有的天數(shù),輸入的天數(shù)不合法</p><p><b>  {</b></p><p>  printf("輸入天數(shù)不合法!\n");</p><p>  return false;</p><p><b>  }</b></p><p>  if(

59、day<=0||(day>noleapDay[month-1]&&!checkLeapyear(year)))//如果該年為平年,輸入的天數(shù)小于零或大于該年該月所應(yīng)有的天數(shù),輸入的天數(shù)不合法</p><p><b>  {</b></p><p>  printf("輸入天數(shù)不合法!\n");</p>&l

60、t;p>  return false;</p><p><b>  }</b></p><p>  return true;</p><p><b>  }</b></p><p>  int calcuday(int year,int month,int day) //計算某年某月某日為該

61、年的第幾天</p><p><b>  {</b></p><p>  int i,totalday=0,mon=0; //mon為月份累積的天數(shù)</p><p>  for(i=1;i<month;i++ )</p><p><b>  {</b></p>&l

62、t;p>  if(checkLeapyear(year))</p><p>  mon=mon+leapDay[i-1]; //如果該年為閏年,月份累積的天數(shù)為其上幾個月的天數(shù)和</p><p><b>  else</b></p><p>  mon=mon+noleapDay[i-1]; //如果該年為平年,月份累積的天數(shù)

63、為其上幾個月的天數(shù)和</p><p><b>  }</b></p><p>  totalday=mon+day;</p><p>  return totalday;</p><p><b>  }</b></p><p>  void Outputday(int now

64、Year,int nowMonth,int nowDay) //打印某年某日星期幾</p><p><b>  {</b></p><p>  int totalday,weekNo,days;</p><p>  totalday=calcuday(nowYear,nowMonth,nowDay); //計算某年某月某日為該年的第幾

65、天</p><p>  days=calcuDays(nowYear,nowMonth,nowDay); // 計算總天數(shù)</p><p>  weekNo=calcuWeek(days); // 計算星期幾</p><p>  switch (weekNo)</p><p><b>  {<

66、/b></p><p><b>  case 0:</b></p><p><b>  {</b></p><p>  printf("%-4d年%-2d月%-2d日是星期天,并且是這一年的第%-2d天!",nowYear,nowMonth,nowDay,totalday);</p>

67、<p><b>  break;</b></p><p><b>  }</b></p><p><b>  case 1:</b></p><p><b>  {</b></p><p>  printf("%-4d年%-2d月%-

68、2d日是星期一,并且是這一年的第%-2d天!",nowYear,nowMonth,nowDay,totalday);</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  case 2:</b></p><p

69、><b>  {</b></p><p>  printf("%-4d年%-2d月%-2d日是星期二,并且是這一年的第%-2d天!\n",nowYear,nowMonth,nowDay,totalday);</p><p><b>  break;</b></p><p><b>  }

70、</b></p><p><b>  case 3:</b></p><p><b>  {</b></p><p>  printf("%-4d年%-2d月%-2d日是星期三,并且是這一年的第%-2d天!\n",nowYear,nowMonth,nowDay,totalday);</

71、p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  case 4:</b></p><p><b>  {</b></p><p>  printf("%-4d年%

72、-2d月%-2d日是星期四,并且是這一年的第%-2d天!\n",nowYear,nowMonth,nowDay,totalday);</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  case 5:</b></p>

73、;<p><b>  {</b></p><p>  printf("%-4d年%-2d月%-2d日是星期五,并且是這一年的第%-2d天!\n",nowYear,nowMonth,nowDay,totalday);</p><p><b>  break;</b></p><p><

74、b>  }</b></p><p><b>  case 6:</b></p><p><b>  {</b></p><p>  printf( "%-4d年%-2d月%-2d日是星期六,并且是這一年的第%-2d天!\n",nowYear,nowMonth,nowDay,totald

75、ay);</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  printf("\n\n");</p><p><b>  }&

76、lt;/b></p><p>  void main() //主函數(shù)</p><p><b>  {</b></p><p>  int year,a,month,day;</p><p><b>  while(1)</b></p><p>

77、;<b>  {</b></p><p>  outputmenu(); //調(diào)用菜單函數(shù) </p><p>  scanf("%d",&a);</p><p>  while(a<0||a>3)</p><p><b>  {</b></p

78、><p>  printf("選擇有誤!請重新選擇:");</p><p>  scanf("%d",&a);</p><p><b>  }</b></p><p>  if(a==0) //如果a=0,則退出 </p><p><b&g

79、t;  {</b></p><p>  printf("退出系統(tǒng),謝謝使用!\n\n");</p><p><b>  break;</b></p><p><b>  }</b></p><p>  if(a==1) //如果a=1,則輸入年份判斷是否為閏年

80、</p><p><b>  {</b></p><p>  printf("請輸入需要查詢的年份:");</p><p>  scanf("%d",&year);</p><p>  while(year<=0) //檢驗?zāi)攴莸暮戏ㄐ?lt;/p>

81、<p><b>  {</b></p><p>  printf("輸入的年份有誤!請重新輸入:");</p><p>  scanf("%d",&year);</p><p><b>  }</b></p><p>  if(checkLe

82、apyear(year))</p><p>  printf("%-4d年是閏年!\n\n",year);</p><p><b>  else</b></p><p>  printf("%-4d年是平年!\n\n",year);</p><p><b>  }<

83、/b></p><p>  if(a==2) //如果a=2,則輸入年份并打印該年年歷</p><p><b>  {</b></p><p>  printf("請輸入需要查詢的年份:");</p><p>  scanf("%d",&year);</

84、p><p>  while(year<=0)</p><p><b>  { </b></p><p>  printf("輸入的年份有誤!請重新輸入:");</p><p>  scanf("%d",&year);</p><p><b&g

85、t;  }</b></p><p>  outputyear(year); //調(diào)用Outputyear函數(shù)</p><p><b>  }</b></p><p>  if(a==3) //如果a=3,則輸入年月日判斷改日為該年的第幾天及星期數(shù)</p><p><b>  {</b&g

86、t;</p><p>  printf("請輸入年月日(格式為YYYY-MM-DD):");</p><p>  scanf("%d-%d-%d",&year,&month,&day);</p><p>  while(!checkhefa(year,month,day)) //檢驗?zāi)暝氯盏暮戏ㄐ?,?/p>

87、果不合法,就重新輸入</p><p><b>  {</b></p><p>  printf("輸入錯誤!請重新輸入年月日(格式為YYYY-MM-DD):\n");</p><p>  scanf("%d-%d-%d",&year,&month,&day);</p>

88、<p><b>  }</b></p><p>  Outputday(year,month,day); //調(diào)用Outputday函數(shù)</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }&l

89、t;/b></p><p><b>  6 程序調(diào)試與測試</b></p><p>  1)進入程序后顯示主界面,如圖6.1。</p><p>  圖6.1 程序菜單界面顯示圖</p><p>  理論結(jié)果:-2小于0,不合法,應(yīng)重新輸入,2012能被4整除,且不能被100整除,應(yīng)為閏年。運行結(jié)果:進入主菜單后,按

90、數(shù)字1,輸入年份,判斷年份的合法性。如果年份不合法,則重新輸入,如果年份合法,顯示該年是閏年還是平年,如圖6.2。</p><p>  圖6.2 閏年判斷運行結(jié)果圖</p><p>  理論結(jié)果:-4小于0,不合法,應(yīng)重新輸入,2014年是平年,二月應(yīng)有28天,并且翻閱日歷,2014年一月一日為星期三。運行結(jié)果:在主菜單界面選擇數(shù)字2,輸入年份,判斷年份的合法性。如果輸入年份不合法,則重新

91、輸入,如果輸入年份合法,則打印該年的年歷,如圖6.3。</p><p>  圖6.3 打印年歷結(jié)果圖</p><p>  4)理論結(jié)果:2012年二月沒有30天,理應(yīng)重新輸入,2012年9月5日查閱日歷,其為星期三,并且經(jīng)計算,它為該年的第249天。運行結(jié)果:在主菜單界面選擇數(shù)字3,輸入年月日,判斷輸入的合法性。年月日中不能有小于等于零的,月份中不能有大于12的,無論平年閏年,每月的天數(shù)都

92、不能大于該月應(yīng)有的天數(shù),如果輸入不合法,則重新輸入,如果輸入合法,則顯示該年該月該日為星期幾,及該日為該年的第幾天,如圖6.4</p><p>  圖6.4日期查詢結(jié)果圖</p><p>  5)在主菜單界面選擇數(shù)字0,退出程序,如圖6.5。</p><p>  圖6.5 退出程序運行圖</p><p>  經(jīng)驗證:所有的理論與實際運行結(jié)果都

93、相同。</p><p><b>  7 結(jié)果分析</b></p><p> ?、逭_的輸入及其輸出結(jié)果:</p><p>  圖7.1正確的輸入運行結(jié)果圖</p><p>  ㈡含有錯誤的輸入及其輸出結(jié)果:</p><p>  圖7.2錯誤年份輸入判斷閏年運行結(jié)果圖</p><

94、p>  圖7.3錯誤年份輸入打印年份運行結(jié)果圖</p><p>  圖7.4錯誤格式輸入查詢?nèi)掌谶\行結(jié)果圖</p><p> ?、邕@個函數(shù)總體比較簡單,時間與空間復(fù)雜度都為線性階。</p><p><b>  8 總結(jié)</b></p><p>  在此程序中我順利的實現(xiàn)了對平年閏年的判斷,對某一年年歷的打印,以及判

95、斷某年某月某日是星期幾以及該日為該年的第幾天。</p><p>  通過這次課程設(shè)計,使我對C語言、數(shù)據(jù)結(jié)構(gòu)等都有了更深層次的認識,不再僅僅局限在原來的理論知識方面的內(nèi)容,更讓我懂得了,理論與實踐結(jié)合的重要性,理論只有應(yīng)用于實踐,才能體現(xiàn)出它的價值。</p><p>  雖然在這次課程中遇到了很多的問題,比如一開始我就在如何計算星期上犯難,后來查了許多資料,思考了很長時間終于想到了計算總天

96、數(shù)除7取余的方法,又如,開始在檢驗合法性的時候,我考慮的并不周全,只認為年月日只要不小于等于零,月份不大于12,天數(shù)不大于31就行了,但是我忽略了閏年二月天數(shù)有29天,平年28天,而且無論平年閏年,該年每月的天數(shù)都不應(yīng)大于其應(yīng)有的天數(shù),比如4月的天數(shù)不能超過30天,這些考慮不周,后來給程序調(diào)試帶來了很大的麻煩,但這些問題使我深深認識到在解決實際時,必須進行認真思考,而且要全面的考慮問題。</p><p>  從最

97、初的思考、查閱資料到最后的程序的成功運行, 這個程序在經(jīng)過反反復(fù)復(fù)調(diào)試后終于成功了,唯一讓我覺得美中不足的是界面設(shè)計不夠完美,我以后會在這方面多注意,爭取做到更完美。</p><p>  而且在這兩周的課程設(shè)計過程中,我也體會到了團隊合作的重要性,三個臭皮匠一個諸葛亮。大家在一起討論,一起商量,才能做出好的設(shè)計! </p><p>  總之,兩個禮拜的課程設(shè)計讓我受益匪淺。我深深認識到,要

98、學(xué)好一門學(xué)科,沒有刻苦鉆研的精神是不行的,只有在不斷的嘗試中,經(jīng)歷失敗,從失敗中總結(jié)經(jīng)驗,然后再不斷的嘗試,才能獲得成功。</p><p><b>  參考文獻</b></p><p>  [1] 嚴蔚敏,吳偉民.數(shù)據(jù)結(jié)構(gòu)(C語言版)[M].北京:清華大學(xué)出版社,2002</p><p>  [2] 李春葆.數(shù)據(jù)結(jié)構(gòu)(C語言版)習(xí)題與解析[M]

溫馨提示

  • 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)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論