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

下載本文檔

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

文檔簡介

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

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

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

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

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

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

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

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

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

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

11、  3 概要設計3</b></p><p><b>  4 詳細設計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)等的基礎知識,按以下要求編程實現(xiàn)萬年歷的功能:</p><p>  1)輸入任一年,判

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

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

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

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

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

19、;  3)、 整體程序主要流程圖如圖3.5所示:</p><p>  圖3.5 整個程序流程圖</p><p><b>  4 詳細設計</b></p><p>  ⑴.建立兩個整型數(shù)組leapDay[12]與noleapDay[12]分別存儲閏年與平年的每月天數(shù);</p><p>  ⑵.int 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> ?、牵甶nt 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>  ⑺.int 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>  ⑽.void 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、年該月所應有的天數(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ù)小于零或大于該年該月所應有的天數(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) //檢驗年份的合法性</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)) //檢驗年月日的合法性,如

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,不合法,應重新輸入,2012能被4整除,且不能被100整除,應為閏年。運行結(jié)果:進入主菜單后,按

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

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

92、不能大于該月應有的天數(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ù)總體比較簡單,時間與空間復雜度都為線性階。</p><p><b>  8 總結(jié)</b></p><p>  在此程序中我順利的實現(xiàn)了對平年閏年的判斷,對某一年年歷的打印,以及判

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

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

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

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

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論