c語言課程設(shè)計(jì)---個(gè)人消費(fèi)管理系統(tǒng)_第1頁
已閱讀1頁,還剩36頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p><b>  目 錄</b></p><p><b>  1 需求分析1</b></p><p><b>  1.1問題描述</b></p><p>  1.2 輸入數(shù)據(jù)要求..................................................

2、..............................................1</p><p>  1.2輸出數(shù)據(jù)要求1</p><p>  1.3開發(fā)環(huán)境和工具2</p><p>  1.4成員分工2</p><p>  2總體設(shè)計(jì).........................................

3、...........................................................................3</p><p>  2.1 總體設(shè)計(jì)思路.................................................................................................3</p>

4、<p>  2.2模塊結(jié)構(gòu)圖3</p><p>  2.3模塊說明4</p><p><b>  3詳細(xì)設(shè)計(jì)5</b></p><p>  3.1 數(shù)據(jù)類型定義5</p><p>  3.2 算法思想 6</p><p>  3.3 具體實(shí)現(xiàn)

5、 7</p><p>  A 讀入及保存文件模塊 7</p><p>  B 信息插入、刪除模塊 7</p><p>  C 查找及顯示信息模塊 9</p><p>  D 排序模塊:按時(shí)間,類別,金額 11</p><p>  E 統(tǒng)計(jì)模塊

6、 15</p><p>  4測試結(jié)果及分析21</p><p><b>  5總結(jié)23</b></p><p>  參考文獻(xiàn)………………………………………………………….............................25</p><p>  附錄...............

7、..............................................................................................................26</p><p><b>  1 需求分析</b></p><p><b>  問題描述</b></p>&l

8、t;p>  當(dāng)代大學(xué)生有著旺盛的消費(fèi)需求,消費(fèi)觀念的超前和消費(fèi)實(shí)力的滯后決定了他們特殊的消費(fèi)心理和消費(fèi)行為。大學(xué)生科學(xué)消費(fèi)觀的建立和合理消費(fèi)規(guī)劃不僅關(guān)系到大學(xué)生健康消費(fèi)心理的形成,還影響到大學(xué)生邁入社會(huì)后社會(huì)經(jīng)濟(jì)生活的適應(yīng)能力,本系統(tǒng)將提供一個(gè)日常消費(fèi)記錄,統(tǒng)計(jì),分析的平臺(tái),幫助大學(xué)生合理的管理自己的日常消費(fèi)。</p><p><b>  輸入數(shù)據(jù)要求</b></p>&

9、lt;p>  消費(fèi)表信息:時(shí)間,類別,品名,單價(jià),數(shù)量,金額</p><p>  消費(fèi)信息存放在文件中,以編號(hào)的先后順序存放</p><p>  用戶從鍵盤讀入消費(fèi)時(shí)間,類別,品名,單價(jià),數(shù)量,金額,保存到文件中</p><p><b>  例如:</b></p><p>  sum:40.000000index:

10、1 time:2009-8-4 type:1 name:hzw price:0.700000 num:5 sum:3.500000index:0 time:2010-8-9 type:1 name:hzw price:0.900000 num:4</p><p><b>  輸出數(shù)據(jù)要求</b></p><p>  打開:顯示文

11、件中的所有消費(fèi)記錄,提供分頁顯示</p><p>  保存:將消費(fèi)表的更新結(jié)果存入文件</p><p>  更新:可插入、刪除、修改各消費(fèi)記錄</p><p>  查找:按時(shí)間,類別、品名查找消費(fèi)記錄</p><p>  排序:按時(shí)間,類別,金額</p><p>  統(tǒng)計(jì):求各類別消費(fèi)品的總金額,求各月的消費(fèi)總金額,求

12、各年的消費(fèi)總金額</p><p><b>  例如:</b></p><p><b>  開發(fā)環(huán)境和工具</b></p><p>  開發(fā)環(huán)境:Windows 2000</p><p>  開發(fā)工具:C Free5.0</p><p><b>  成員分工</

13、b></p><p>  超 人(郭振興):系統(tǒng)測試、主調(diào)模塊、、總體設(shè)計(jì)……</p><p>  蜘蛛俠(林莉莎):、查詢模塊、排序模塊、更新模塊……</p><p><b>  2總體設(shè)計(jì)</b></p><p><b>  2.1總體設(shè)計(jì)思路</b></p><p&

14、gt;  本設(shè)計(jì)主要包括數(shù)據(jù)錄入模塊,信息刪除模塊,查詢顯示模塊,數(shù)據(jù)排序模塊, 數(shù)據(jù)統(tǒng)計(jì)模塊.</p><p><b>  2.2模塊結(jié)構(gòu)圖</b></p><p>  根據(jù)需求將系統(tǒng)劃分為五個(gè)功能模塊如圖所示</p><p><b>  2.3模塊說明</b></p><p>  1.數(shù)據(jù)錄入模

15、塊. 本模塊的設(shè)計(jì)主要包括三個(gè)函數(shù),struct Time(消費(fèi)時(shí)間),enum TYPE(消費(fèi)類型)struct ConsumeRecord(完整的消費(fèi)記錄)struct ConsumeRecord 函數(shù)主要實(shí)現(xiàn)程序的初始建庫,把數(shù)據(jù)添加到文件中,其主要過程是打開文件,調(diào)用Time ,TYPE函數(shù),將需要錄入的數(shù)據(jù)從鍵盤輸入,添加到文件中。</p><p>  2.信息刪除模塊. 本模塊通過輸入需要查找

16、的條目的索引號(hào),程序循環(huán)遍歷所有已存的消費(fèi)條目,如果消費(fèi)條目的索引號(hào)等于要?jiǎng)h除的索引號(hào),刪除該索引號(hào)對(duì)應(yīng)的消費(fèi)條目,并將其后面的消費(fèi)條目依次往前移動(dòng)。</p><p>  3.查詢顯示模塊. 本模塊通過輸入需要查找的條目的索引號(hào),程序循環(huán)遍歷所有已存的消費(fèi)條目,直到查找完或者找到。找到后顯示從record指針開始的number個(gè)條目,遍歷需要查找的條目,依次顯示。</p><p> 

17、 4.數(shù)據(jù)排序模塊. 本模塊交換兩個(gè)條目的內(nèi)容,將record數(shù)組用選擇冒泡法分別以消費(fèi)時(shí)間,類型,價(jià)格進(jìn)行排序。</p><p>  5.數(shù)據(jù)統(tǒng)計(jì)模塊. 本模塊已存條目指針和已存?zhèn)€數(shù)如果已存條目小于等于零,退出統(tǒng)計(jì), 將條目按時(shí)間排序,如果只有一條記錄直接輸出,如果有多條記錄,則遍歷所有記錄并分別打印如果當(dāng)前記錄與下一條記錄年份月份相同,則將其歸于一個(gè)月,并累加該月的總金額. 月份變了,打印統(tǒng)計(jì)月份

18、的總金額,/將年份金額賦值為下一月份,開始記錄下一月份.</p><p><b>  3詳細(xì)設(shè)計(jì)</b></p><p><b>  3.1數(shù)據(jù)類型定義</b></p><p>  //時(shí)間結(jié)構(gòu)體記錄消費(fèi)時(shí)間</p><p>  struct Time</p><p><

19、;b>  {</b></p><p><b>  int year;</b></p><p>  int month;</p><p><b>  int day;</b></p><p><b>  };</b></p><p>  

20、類型結(jié)構(gòu)體記錄消費(fèi)類型</p><p><b>  enum TYPE</b></p><p><b>  {</b></p><p><b>  STUDY,</b></p><p><b>  EAT,</b></p><p>

21、<b>  PLAY</b></p><p><b>  };</b></p><p>  //消費(fèi)條目結(jié)構(gòu)體,用以記錄完整的消費(fèi)記錄</p><p>  struct ConsumeRecord</p><p><b>  {</b></p><p>

22、  int index;//消費(fèi)索引</p><p>  Time time;//消費(fèi)時(shí)間</p><p>  TYPE type;//消費(fèi)類型</p><p>  char name[256];//消費(fèi)名稱</p><p>  float price;//單價(jià)</p><p>  int num;//數(shù)目</p

23、><p>  float sum;//總價(jià)</p><p>  nt _tmain(int argc, _TCHAR* argv[]</p><p>  ConsumeRecord* recordTmp;//臨時(shí)條目指針</p><p>  int indexToDelete;//需要?jiǎng)h除的條目的索引號(hào)</p><p> 

24、 int indexToFind;//需要查找的條目的索引號(hào)</p><p>  char sortType=0;//排序類型</p><p>  int nCurrent=0;//已存條目的個(gè)數(shù)</p><p>  int nCurrentDump;//暫存“已存條目的個(gè)數(shù)”,用以分頁顯示的時(shí)候,還原已存條目個(gè)數(shù)</p><p>  cha

25、r next;//分頁顯示時(shí)輸入變量,輸入‘n’顯示下一頁(十行)</p><p>  FILE *file;//文件指針,用以從文件讀取記錄,或?qū)懳募?lt;/p><p>  ConsumeRecord* pCurrent;//現(xiàn)在所指向的條目的指針</p><p>  ConsumeRecord record[100];//現(xiàn)存條目數(shù)組</p><

26、;p>  char input='o';//記錄需要做的操作的變量</p><p><b>  3.2算法思想</b></p><p>  分別用時(shí)間結(jié)構(gòu)體記錄消費(fèi)時(shí)間, 類型結(jié)構(gòu)體記錄消費(fèi)類型, 消費(fèi)條目結(jié)構(gòu)體記錄完整的消費(fèi)記錄.其中查詢和刪除模塊通過掃描已建立的所有數(shù)據(jù),索引出符合條件的條目,統(tǒng)計(jì)模塊先通過以時(shí)間,類型,價(jià)格進(jìn)行排序,再統(tǒng)計(jì)各

27、類別消費(fèi)品的總金額,各月的消費(fèi)總金額,各年的消費(fèi)總金額.</p><p><b>  3.3具體實(shí)現(xiàn)</b></p><p>  A.讀入及保存文件模塊</p><p>  將消費(fèi)數(shù)據(jù)以文件的形式儲(chǔ)存,定義一個(gè)文件指針file使其指向該文件,利用標(biāo)準(zhǔn)輸入函數(shù)fopen讀入文件內(nèi)數(shù)據(jù)。具體是用指針指向條目的第一行,判斷如果已存文件數(shù)小于最大文件數(shù)

28、,讀取文件。讀取一條后,指針指向下一個(gè)地方以讀取下一條目,同時(shí)使讀入條目數(shù)nCurrent加一。如此循環(huán)讀完數(shù)據(jù)后,將文件關(guān)閉。</p><p>  以同樣的方法打開文件,遍歷所有的條目直到結(jié)束,將消費(fèi)一個(gè)條目寫入文件,消費(fèi)條目指針指向下一個(gè)消費(fèi)條目,用以將下一個(gè)消費(fèi)條目寫入文件,最后關(guān)閉文件。</p><p>  B.信息插入、刪除模塊</p><p>  自定義

29、函數(shù)DeleteRecord(ConsumeRecord* record,int& nCurrent,int index) 其中record是消費(fèi)條目指針,nCurrent是已存消費(fèi)條目的個(gè)數(shù),index為索引號(hào),利用循環(huán)遍歷所有的索引號(hào),如果遇到的索引號(hào)與要?jiǎng)h除的索引號(hào)相同,則實(shí)現(xiàn)調(diào)用刪除函數(shù)DeleteRecord(ConsumeRecord* record,int& nCurrent,int index)功能,即:

30、</p><p><b>  {</b></p><p>  for (int i = 0;i<nCurrent;i++)</p><p><b>  {</b></p><p>  if (record->index==index)</p><p><b&

31、gt;  {</b></p><p>  for (int j = i;j<nCurrent;j++)</p><p><b>  {</b></p><p>  record[j]=record[j+1];</p><p><b>  }</b></p><p

32、>  nCurrent--;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  插入數(shù)據(jù)時(shí)首先要判斷條目是否已滿,若已滿則輸出printf("the record is f

33、ull!");即已經(jīng)存滿不能再插入數(shù)據(jù),否則將pCurrent指向已存條目的下一個(gè)位置指針即pCurrent=&record[nCurrent];循環(huán)直到正確輸入</p><p>  若輸入不正確,打印警告信息即:</p><p>  if (pCurrent->num<0)</p><p><b>  {</b>

34、</p><p>  printf("unrecomannd fomat!\n");</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  插入后計(jì)算總金額</b></p><p>

35、;  pCurrent->sum=pCurrent->price*pCurrent->num;</p><p>  pCurrent++; nCurrent++;</p><p><b>  }</b></p><p>  pCurrent=&record[nCurrent];</p><p&

36、gt;<b>  如下:</b></p><p>  C.查找及顯示信息模塊</p><p>  Record:指向消費(fèi)條目記錄數(shù)組,</p><p>  nCurrent:已存條目數(shù),</p><p>  index:需要查找的條目的索引號(hào)</p><p>  利用ConsumeRecord*

37、FindRecord(ConsumeRecord* record,int& nCurrent,int index)</p><p>  遍歷所有已存的消費(fèi)條目,直到查找完或者找到如果消費(fèi)條目的索引號(hào)為需要查找的索引號(hào)才,找到了,返回;遍歷完了沒有找到,輸出“not found!”即:</p><p><b>  {</b></p><p&

38、gt;  for (int i = 0;i<nCurrent;i++,record++)</p><p><b>  {</b></p><p>  if (record->index==index)</p><p><b>  {</b></p><p>  return record

39、;</p><p><b>  }</b></p><p><b>  }</b></p><p>  printf("not found!");</p><p><b>  return 0;</b></p><p><b&g

40、t;  }</b></p><p>  查找完后調(diào)用ShowRecord輸出要顯示的條目。</p><p>  ShowRecord函數(shù)功能如下:</p><p>  void ShowRecord(ConsumeRecord* record)</p><p><b>  {</b></p>&

41、lt;p>  printf("index:%d %d-%d-%d type:%d name:%s price:%f num:%d sum:%f\n",\record->index,record->time.year,record->time.month,record->time.day,record->type,record->name

42、,record->price,record->num,record->sum);</p><p><b>  }</b></p><p>  然后調(diào)用顯示ShowRecords查找到的從指針開始的總的條目,ShowRecords功能如下:</p><p>  void ShowRecords(ConsumeRecord* re

43、cord,int number)</p><p><b>  {</b></p><p>  for (int i=0;i<number;i++)</p><p><b>  {</b></p><p>  ShowRecord(record+i);</p><p>&

44、lt;b>  }</b></p><p><b>  }</b></p><p>  注:number:需要顯示的條目數(shù)。</p><p>  Record:指向第一個(gè)要顯示的指針。</p><p>  D.排序模塊:按時(shí)間,類別,金額</p><p>  具體來說是定義了一個(gè)函

45、數(shù),實(shí)現(xiàn)三種方式的排序,其中運(yùn)用了switch語句,根據(jù)不同的排序類型劃分了不同的case,然后選擇出相應(yīng)的功能來實(shí)現(xiàn)要求,比較實(shí)用而且簡潔。函數(shù)內(nèi)部是采用冒泡法排序,首先判斷選擇的類型然后進(jìn)入相應(yīng)的功能區(qū)。定義函數(shù)</p><p>  void SortRecord(ConsumeRecord* record,int nCurrent,char type)</p><p>  其中 re

46、cord:排序數(shù)組頭指針,nCurrent:數(shù)組的個(gè)數(shù),type:排序類型</p><p>  void SortRecord(ConsumeRecord* record,int nCurrent,char type)</p><p><b>  {</b></p><p><b>  int i,j;</b></p

47、><p>  switch(type)</p><p><b>  {</b></p><p>  case 't': //按時(shí)間排序</p><p>  for(i=0;i<nCurrent-1;i++)</p><p><b>  {</b></p

48、><p>  for(j=0;j<nCurrent-1-i;j++)</p><p><b>  {</b></p><p>  //比較兩個(gè)條目的年份,前一個(gè)年份大則交換 </p><p>  if(record[j].time.year>record[j+1].time.year)</p>&l

49、t;p><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p><p><b>  else if </b></p><p>  //年份相同,比較月份<

50、;/p><p>  (record[j].time.year==record[j+1].time.year&&record[j].time.month>record[j+1].time.month)</p><p><b>  {</b></p><p>  swap(&record[j],&record[j+

51、1]);</p><p><b>  }</b></p><p><b>  else if</b></p><p>  //年份月份相同,比較日期 (record[j].time.year==record[j+1].time.year&&record[j].time.month==record[j+1].

52、time.month&&record[j].time.day>record[j+1].time.day)</p><p><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p>

53、<p><b>  }</b></p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  //按類型排序</b></p><p><b>  case 'l'

54、;:</b></p><p>  for(i=0;i<nCurrent-1;i++)</p><p><b>  {</b></p><p>  for(j=0;j<nCurrent-1-i;j++)</p><p><b>  {</b></p><p&

55、gt;  //比較類型,前面的條目大就交換</p><p>  if(record[j].type>record[j+1].type)</p><p><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }&

56、lt;/b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  //按價(jià)格排序</b></p><p><b&g

57、t;  case 'p':</b></p><p>  for(i=0;i<nCurrent-1;i++)</p><p><b>  {</b></p><p>  for(j=0;j<nCurrent-1-i;j++)</p><p><b>  {</b>

58、;</p><p>  //遍歷價(jià)格,前面的大就交換</p><p>  if(record[j].price>record[j+1].price)</p><p><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><

59、;p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  }</b></p><

60、;p><b>  }</b></p><p><b>  如下:</b></p><p><b>  E.統(tǒng)計(jì)模塊</b></p><p>  為了便于統(tǒng)計(jì),現(xiàn)將數(shù)據(jù)進(jìn)行排序,根據(jù)不同的統(tǒng)計(jì)方式進(jìn)行不同的排序,如為了計(jì)算每年的消費(fèi)總額,需要將數(shù)據(jù)按時(shí)間排序,然后進(jìn)行統(tǒng)計(jì),按類型排序就利于統(tǒng)計(jì)每個(gè)

61、項(xiàng)目的消費(fèi)情況。在程序中就要在統(tǒng)計(jì)之前根據(jù)需要調(diào)用相應(yīng)的函數(shù)實(shí)現(xiàn)排序功能。具體如下所示:</p><p>  void Statistic(ConsumeRecord* record,int nCurrent)</p><p><b>  {</b></p><p>  //如果已存條目小于等于零,退出</p><p>

62、  if (nCurrent<=0)</p><p><b>  {</b></p><p><b>  return;</b></p><p><b>  }</b></p><p>  //將條目按時(shí)間排序</p><p>  SortReco

63、rd(record,nCurrent,'t');</p><p>  double sumYear = record->sum;//按年統(tǒng)計(jì)的總金額,將第一條記錄的金額付給他</p><p>  double sumMonth = record->sum;//按月統(tǒng)計(jì)的總金額,將第一條記錄的金額付給他</p><p>  double s

64、umType = record->sum;//按類型統(tǒng)計(jì)的總金額,將第一條記錄的金額付給他</p><p>  //如果只有一條記錄直接輸出</p><p>  if (nCurrent == 1)</p><p><b>  {</b></p><p>  //輸出按年統(tǒng)計(jì)的總金額</p><

65、p>  printf("year:%d sum:%f\n",record[0].time.year,sumYear);</p><p>  //輸出按月統(tǒng)計(jì)的總金額</p><p>  printf("year:%d--month%d: sum:%f\n",record[0].time.year,record[0].time.mon

66、th,sumMonth);</p><p>  //輸出按類型統(tǒng)計(jì)的總金額</p><p>  printf("type:%d sum:%f\n",record[0].type,sumType);</p><p><b>  return;</b></p><p><b>  }<

67、;/b></p><p>  //如果有多條記錄,則遍歷所有記錄并分別打印</p><p>  for (int i=0;i<nCurrent;i++)</p><p><b>  {</b></p><p>  //如果當(dāng)前記錄與下一條記錄年份相同,則將其歸于一年,并累加改年的總金額</p>

68、<p>  if (record[i].time.year==record[i+1].time.year)</p><p><b>  {</b></p><p>  sumYear+=record[i+1].sum;</p><p><b>  }</b></p><p><b&g

69、t;  else</b></p><p><b>  {</b></p><p>  //年份變了,打印統(tǒng)計(jì)年份的總金額</p><p>  printf("year:%d sum:%f\n",record[i].time.year,sumYear);</p><p>  //將年份

70、金額賦值為下一年份,開始記錄下一年分</p><p>  sumYear=record[i+1].sum;</p><p><b>  }</b></p><p>  //如果當(dāng)前記錄與下一條記錄年份月份相同,則將其歸于一個(gè)月,并累加該月的總金額</p><p>  if (record[i].time.year==re

71、cord[i+1].time.year&&record[i].time.month==record[i+1].time.month)</p><p><b>  {</b></p><p>  sumMonth+=record[i+1].sum;</p><p><b>  }</b></p>

72、<p><b>  else</b></p><p><b>  {</b></p><p>  //月份變了,打印統(tǒng)計(jì)月份的總金額</p><p>  printf("year:%d--month%d: sum:%f\n",record[i].time.year,record[i].

73、time.month,sumMonth);</p><p>  //將年份金額賦值為下一月份,開始記錄下一月分</p><p>  sumMonth=record[i+1].sum;</p><p><b>  }</b></p><p><b>  }</b></p><p&g

74、t;  //按類型將記錄排序</p><p>  SortRecord(record,nCurrent,'l');</p><p><b>  //遍歷所有記錄</b></p><p>  for (int i=0;i<nCurrent;i++)</p><p><b>  {</b

75、></p><p>  //如果當(dāng)前記錄與下一條記錄類型相同,則將其歸于同一類型,并累加改類型的總金額</p><p>  if (record[i].type==record[i+1].type)</p><p><b>  {</b></p><p>  sumType+=record[i+1].sum;<

76、;/p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  //類型變了,打印該類型的總金額</p><p>  printf("type:%d sum:%

77、f\n",record[i].type,sumType);</p><p>  //將類型金額賦值為下一類型,開始記錄下一類型</p><p>  sumType = record[i+1].sum;</p><p><b>  }</b></p><p><b>  }</b></

78、p><p><b>  }</b></p><p><b>  如下:</b></p><p>  //輸入‘e’則退出,否則一直運(yùn)行</p><p>  以上是各個(gè)函數(shù)功能,在實(shí)際運(yùn)行時(shí)要建立一個(gè)dos菜單輸入不同的指令來實(shí)現(xiàn)相應(yīng)的功能,即下面的顯示信息:</p><p>  

79、提示用戶選擇想要的操作</p><p><b>  4.測試結(jié)果及分析</b></p><p><b>  部分結(jié)果如下:</b></p><p>  本次測試主要對(duì)程序的五個(gè)模塊功能進(jìn)行了檢驗(yàn),剛開始的時(shí)候也出現(xiàn)了很多沒有預(yù)想到的錯(cuò)誤,接著一步步查找錯(cuò)誤,認(rèn)真分析,最終正確地實(shí)現(xiàn)了功能,結(jié)果與預(yù)期基本相同.最終通過給老師

80、提問,以及自己的演示也出現(xiàn)了一些問題,比如:功能實(shí)現(xiàn)不全,以及結(jié)果顯示不清楚等等.</p><p>  出現(xiàn)的顯示不清楚如下: </p><p>  應(yīng)當(dāng)按照平常習(xí)慣建立表格形式的目錄,沒有必要每次的結(jié)果都要在前面附帶類型.</p><p>  這個(gè)不足在于2009年的統(tǒng)計(jì)處有問題.這些問題提醒了我以后做什么事情都要多方面考慮,設(shè)計(jì)這種程序關(guān)鍵在于它的實(shí)用性.<

81、;/p><p><b>  5.總結(jié)</b></p><p>  經(jīng)過上一個(gè)學(xué)期對(duì)《C程序設(shè)計(jì)》的學(xué)習(xí),我們學(xué)習(xí)了理論知識(shí),了解了C語言程序設(shè)計(jì)的思想,這些知識(shí)都為我們的下一步學(xué)習(xí)打下了堅(jiān)實(shí)的基礎(chǔ)。通過課程設(shè)計(jì),一方面是為了檢查我們一個(gè)學(xué)期來我們學(xué)習(xí)的成果,另一方面也是為了讓我們進(jìn)一步的掌握和運(yùn)用它,同時(shí)也讓我們認(rèn)清自己的不足之處和薄弱環(huán)節(jié),加以彌補(bǔ)和加強(qiáng)。</p&

82、gt;<p>  在個(gè)人消費(fèi)系統(tǒng)程序編寫過程中也體會(huì)到了做事情一頂要細(xì)心、認(rèn)真。更加知道了要掌握好基礎(chǔ)知識(shí)。還有體會(huì)到了成功的感覺!更加體會(huì)到了團(tuán)隊(duì)合作的重要性(很感謝我的隊(duì)友),“一個(gè)諸葛亮比不上三個(gè)臭皮匠?!敝懒酥挥袌F(tuán)隊(duì)合作才會(huì)更好的完成設(shè)計(jì)!也體會(huì)到以后在工作中團(tuán)隊(duì)合作的必要性和重要性!</p><p>  通過本項(xiàng)課程設(shè)計(jì)培養(yǎng)了我獨(dú)立思考、 綜合運(yùn)用所學(xué)有關(guān)相應(yīng)知識(shí)的能力,掌握 工程軟件設(shè)

83、計(jì)的基本方法,強(qiáng)化上機(jī)動(dòng)手編程能力,闖過理論與實(shí)踐相結(jié)合的難關(guān)!也知道了自己的動(dòng)手能力不強(qiáng)有待進(jìn)一步的提高!在設(shè)計(jì)過程中不能夠把書本上的知識(shí)與實(shí)踐相結(jié)合,這也就增加了設(shè)計(jì)不好該程序的想法!一次次設(shè)計(jì)錯(cuò)誤增加了我放棄的想法!不過經(jīng)過大家的努力終于完成了課程設(shè)計(jì)!完成該程序后想起自己以前的每一次對(duì)自己失去信心,就覺得并不是在知識(shí)掌握上打敗了,而是自己對(duì)自己缺乏信心!只要自己對(duì)自己不失去信心相信就可以完成那些以前認(rèn)為完成不了的事情!懂得了自己

84、以后要在做任何事情時(shí)都要自信!當(dāng)自己都不相信自己能夠成功時(shí)還可能會(huì)獲得成功嗎?也知道了自己在以前的學(xué)習(xí)中有很大的不足導(dǎo)致在設(shè)計(jì)過程中出現(xiàn)了很多的問題,有些地方看不懂也不知道怎么去設(shè)計(jì),但是在設(shè)計(jì)過程中也學(xué)習(xí)了很多,掌握了自己以前沒有學(xué)好的知識(shí),雖然一時(shí)可以掌握完以前沒有學(xué)好的知識(shí),不過也給自己敲響了警鐘,在學(xué)習(xí)中不可以伏于表面,要想學(xué)好每一門課程都要踏踏實(shí)實(shí),做什么都不是給別人看的!都是要更好的掌握該門知識(shí),提高自己的自身的修養(yǎng),提高自

85、己的能力!為以后的工作打下良好的知識(shí)</p><p><b>  參考文獻(xiàn)</b></p><p> ?、弊T浩強(qiáng)編著.C程序設(shè)計(jì)第二版〔M〕.北京:清華大學(xué)出版社,1999</p><p>  ⒉陳朔鷹,陳英編著.C語言趣味程序百例精解〔M〕.北京:北京理工大學(xué)出版社,1994</p><p> ?、畴娔X知識(shí)與技術(shù)學(xué)術(shù)交

86、流版〔J〕2005.2 (備注:來自網(wǎng)絡(luò)資源)</p><p> ?、碒erbert Schildit著. 戴健鵬譯. C語言大全 (第二版)〔M〕.北京:電子工業(yè)出版社,1994</p><p>  ⒌譚浩強(qiáng),張基溫,唐永炎編著. C語言程序設(shè)計(jì)教程.〔M〕北京: 高等教育出版社,1992</p><p> ?、肚赜咽?,曹化工編著. C語言程序設(shè)計(jì)教程. 〔

87、M〕武漢:華中理工大學(xué)出版社,1996</p><p>  7.黃明等編著.21世紀(jì)進(jìn)階輔導(dǎo)C語言程序設(shè)計(jì). 〔M〕大連理工大學(xué)出版</p><p><b>  附錄</b></p><p><b>  源程序:</b></p><p>  // 個(gè)人消費(fèi)系統(tǒng).cpp : 定義控制臺(tái)應(yīng)用程序的入口點(diǎn)

88、。</p><p>  //#include "stdafx.h"</p><p>  #include<stdio.h></p><p>  #include<tchar.h></p><p>  #include <stdlib.h></p><p>  //

89、時(shí)間結(jié)構(gòu)體記錄消費(fèi)時(shí)間</p><p>  struct Time</p><p><b>  {</b></p><p><b>  int year;</b></p><p>  int month;</p><p><b>  int day;</b&g

90、t;</p><p><b>  };</b></p><p>  //消費(fèi)條目結(jié)構(gòu)體,用以記錄完整的消費(fèi)記錄</p><p>  struct ConsumeRecord</p><p><b>  {</b></p><p>  int index;//消費(fèi)索引</

91、p><p>  Time time;//消費(fèi)時(shí)間</p><p>  int type;//消費(fèi)類型</p><p>  char name[256];//消費(fèi)名稱</p><p>  float price;//單價(jià)</p><p>  int num;//數(shù)目</p><p>  float

92、sum;//總價(jià)</p><p><b>  };</b></p><p><b>  //讀取文件。</b></p><p>  //file文件指針,record消費(fèi)條目數(shù)組指針,len為消費(fèi)條目數(shù)組最大長度(用以判定越界),nCurrent消費(fèi)條目數(shù)組已存條目個(gè)數(shù)</p><p>  void

93、 ReadFile(FILE*& file,ConsumeRecord* record,int len,int& nCurrent)</p><p><b>  {</b></p><p>  //打開文件data.txt</p><p>  file = fopen("data.txt","r&q

94、uot;);</p><p>  //讀取文件直到結(jié)束</p><p>  while(!feof(file))</p><p><b>  {</b></p><p>  //如果已存文件數(shù)小于最大文件數(shù),讀取文件</p><p>  if (nCurrent<len)</p>

95、<p><b>  {</b></p><p><b>  //讀取一條記錄</b></p><p>  fscanf(file,"index:%d time:%d-%d-%d type:%d name:%s price:%f num:%d sum:%f",\</p><p>  &

96、;record->index,&record->time.year,&record->time.month,&record->time.day,\</p><p>  &record->type,record->name,&record->price,&record->num,&record->sum);

97、</p><p>  //數(shù)組指針指向下一個(gè)地方,以讀取下一條記錄</p><p><b>  record++;</b></p><p><b>  //已存記錄數(shù)加一</b></p><p>  nCurrent++;</p><p><b>  }</b

98、></p><p><b>  }</b></p><p><b>  //關(guān)閉文件</b></p><p>  fclose(file);</p><p><b>  }</b></p><p><b>  //保存文件。</b&

99、gt;</p><p>  //file為文件指針,record消費(fèi)條目數(shù)組指針,nCurrent已存消費(fèi)條目條目個(gè)數(shù)</p><p>  void SaveFile(FILE*& file,ConsumeRecord* record,int nCurrent)</p><p><b>  {</b></p><p&

100、gt;  //打開文件data.txt</p><p>  file = fopen("data.txt","w");</p><p>  //遍歷每一個(gè)消費(fèi)條目直到結(jié)束</p><p>  for (int i=0;i<nCurrent;i++)</p><p><b>  {<

101、/b></p><p>  //將消費(fèi)條目寫入文件</p><p>  fprintf(file,"index:%d time:%d-%d-%d type:%d name:%s price:%f num:%d sum:%f",\</p><p>  record->index,record->time.year,record-&

102、gt;time.month,record->time.day,\</p><p>  record->type,record->name,record->price,record->num,record->sum);</p><p>  //消費(fèi)條目指針指向下一個(gè)消費(fèi)條目,用以將下一個(gè)消費(fèi)條目寫入文件</p><p><b&

103、gt;  record++;</b></p><p><b>  }</b></p><p><b>  //關(guān)閉文件</b></p><p>  fclose(file);</p><p><b>  }</b></p><p><b

104、>  //刪除消費(fèi)記錄</b></p><p>  //record消費(fèi)條目數(shù)組指針,nCurrent已存消費(fèi)條目的個(gè)數(shù),index即將刪除的記錄的索引號(hào)</p><p>  void DeleteRecord(ConsumeRecord* record,int& nCurrent,int index)</p><p><b> 

105、 {</b></p><p>  //遍歷現(xiàn)在已存的所有條目</p><p>  for (int i = 0;i<nCurrent;i++)</p><p><b>  {</b></p><p>  //如果消費(fèi)條目的索引號(hào)等于要?jiǎng)h除的索引號(hào)</p><p>  if (re

106、cord->index==index)</p><p><b>  {</b></p><p>  //刪除該索引號(hào)對(duì)應(yīng)的消費(fèi)條目,并將其后面的消費(fèi)條目依次往前移動(dòng)</p><p>  for (int j = i;j<nCurrent;j++)</p><p><b>  {</b>&

107、lt;/p><p>  record[j]=record[j+1];</p><p><b>  }</b></p><p>  //已存消費(fèi)條目減一</p><p>  nCurrent--;</p><p><b>  }</b></p><p>&l

108、t;b>  }</b></p><p><b>  }</b></p><p><b>  //查找消費(fèi)條目</b></p><p>  //record消費(fèi)條目記錄數(shù)組,nCurrent已存條目數(shù),需要查找的條目的索引號(hào)</p><p>  ConsumeRecord* Find

109、Record(ConsumeRecord* record,int& nCurrent,int index)</p><p><b>  {</b></p><p>  //遍歷所有已存的消費(fèi)條目,直到查找完或者找到</p><p>  for (int i = 0;i<nCurrent;i++,record++)</p>

110、;<p><b>  {</b></p><p>  //如果消費(fèi)條目的索引號(hào)為需要查找的索引號(hào)才,找到了,返回</p><p>  if (record->index==index)</p><p><b>  {</b></p><p>  return record;<

111、;/p><p><b>  }</b></p><p><b>  }</b></p><p>  //遍歷完了沒有找到,輸出“not found!”</p><p>  printf("not found!");</p><p><b>  ret

112、urn 0;</b></p><p><b>  }</b></p><p><b>  //顯示條目。</b></p><p>  //record需要顯示的條目的指針</p><p>  void ShowRecord(ConsumeRecord* record)</p>

113、<p><b>  {</b></p><p>  //輸出要顯示的條目</p><p>  printf("index:%d %d-%d-%d type:%d name:%s price:%f num:%d sum:%f\n",\</p><p>  record->

114、index,record->time.year,record->time.month,record->time.day,record->type,record->name,record->price,record->num,record->sum);</p><p><b>  }</b></p><p>  //顯示從

115、record指針開始的number個(gè)條目</p><p>  //record第一個(gè)要顯示的條目的指針,number需要顯示的條目的個(gè)數(shù)</p><p>  void ShowRecords(ConsumeRecord* record,int number)</p><p><b>  {</b></p><p>  /

116、/遍歷需要查找的條目,依次顯示</p><p>  for (int i=0;i<number;i++)</p><p><b>  {</b></p><p><b>  //顯示條目</b></p><p>  ShowRecord(record+i);</p><p&

117、gt;<b>  }</b></p><p><b>  }</b></p><p>  //交換兩個(gè)條目的內(nèi)容</p><p>  void swap(ConsumeRecord *pR1,ConsumeRecord *pR2)</p><p><b>  {</b><

118、/p><p>  ConsumeRecord temp;</p><p>  temp=*pR1;</p><p>  *pR1=*pR2;</p><p>  *pR2=temp;</p><p><b>  }</b></p><p>  //將record數(shù)組排序,選擇冒

119、泡排序</p><p>  //record排序數(shù)組頭指針,nCurrent數(shù)組的個(gè)數(shù),排序類型</p><p>  void SortRecord(ConsumeRecord* record,int nCurrent,char type)</p><p><b>  {</b></p><p><b>  i

120、nt i,j;</b></p><p><b>  //判斷排序類型</b></p><p>  switch(type)</p><p><b>  {</b></p><p><b>  //按時(shí)間排序</b></p><p><b

121、>  case 't':</b></p><p><b>  //遍歷數(shù)組</b></p><p>  for(i=0;i<nCurrent-1;i++)</p><p><b>  {</b></p><p>  for(j=0;j<nCurrent-

122、1-i;j++)</p><p><b>  { </b></p><p>  //比較兩個(gè)條目的年份,前一個(gè)年份大則交換</p><p>  if(record[j].time.year>record[j+1].time.year)</p><p><b>  {</b></p>

123、<p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p><p>  //年份相同,比較月份</p><p>  else if (record[j].time.year==record[j+1].time.year&&record[j

124、].time.month>record[j+1].time.month)</p><p><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p><p>  //年份月份相同,比較

125、日期</p><p>  else if (record[j].time.year==record[j+1].time.year&&record[j].time.month==record[j+1].time.month&&record[j].time.day>record[j+1].time.day)</p><p><b>  {<

126、/b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><

127、;b>  break;</b></p><p><b>  //按類型排序</b></p><p><b>  case 'l':</b></p><p>  for(i=0;i<nCurrent-1;i++)</p><p><b>  {<

128、/b></p><p>  for(j=0;j<nCurrent-1-i;j++)</p><p><b>  { </b></p><p>  //比較類型,前面的條目大就交換</p><p>  if(record[j].type>record[j+1].type)</p><p

129、><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b><

130、/p><p><b>  break;</b></p><p><b>  //按價(jià)格排序</b></p><p><b>  case 'p':</b></p><p>  for(i=0;i<nCurrent-1;i++)</p><p

131、><b>  {</b></p><p>  for(j=0;j<nCurrent-1-i;j++)</p><p><b>  { </b></p><p>  //遍歷價(jià)格,前面的大就交換</p><p>  if(record[j].price>record[j+1].pri

132、ce)</p><p><b>  {</b></p><p>  swap(&record[j],&record[j+1]);</p><p><b>  }</b></p><p><b>  }</b></p><p><b&

133、gt;  }</b></p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  //統(tǒng)計(jì)</b></p><p>  /

134、/已存條目指針,和已存?zhèn)€數(shù)</p><p>  void Statistic(ConsumeRecord* record,int nCurrent)</p><p><b>  {</b></p><p>  //如果已存條目小于等于零,退出</p><p>  if (nCurrent<=0)</p>

135、<p><b>  {</b></p><p><b>  return;</b></p><p><b>  }</b></p><p>  //將條目按時(shí)間排序</p><p>  SortRecord(record,nCurrent,'t')

136、;</p><p>  double sumYear = record->sum;//按年統(tǒng)計(jì)的總金額,將第一條記錄的金額付給他</p><p>  double sumMonth = record->sum;//按月統(tǒng)計(jì)的總金額,將第一條記錄的金額付給他</p><p>  double sumType = record->sum;//按類型統(tǒng)計(jì)

137、的總金額,將第一條記錄的金額付給他</p><p>  //如果只有一條記錄直接輸出</p><p>  if (nCurrent == 1)</p><p><b>  {</b></p><p>  //輸出按年統(tǒng)計(jì)的總金額</p><p>  printf("year:%d

138、sum:%f\n",record[0].time.year,sumYear);</p><p>  //輸出按月統(tǒng)計(jì)的總金額</p><p>  printf("year:%d--month%d: sum:%f\n",record[0].time.year,record[0].time.month,sumMonth);</p><p&

溫馨提示

  • 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)論