c語言課程設計---班級成績管理系統(tǒng)_第1頁
已閱讀1頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  目錄</b></p><p>  第一章 緒論--------------------------------------------------------</p><p>  第二章 需求分析--------------------------------------------------</p><p&

2、gt;  2.1 程序的功能------------------------------------------</p><p>  2.2 輸入輸出的要求------------------------------------</p><p>  第三章 概要設計--------------------------------------------------</p>

3、<p>  3.1程序的模塊組成-------------------------------------</p><p>  3.2學生信息結構數(shù)組----------------------------------</p><p>  3.3各個程序的功能介紹-------------------------------</p><p>  第四章

4、 詳細設計--------------------------------------------------</p><p>  4.1總流程圖----------------------------------------------</p><p>  4.2統(tǒng)計函數(shù)流程圖-------------------------------------</p><p&

5、gt;  第五章 測試--------------------------------------------------------</p><p>  5.1系統(tǒng)調(diào)試----------------------------------------------</p><p>  5.2結果分析---------------------------------------------

6、-</p><p>  第六章 使用說明--------------------------------------------------</p><p>  第七章 總結--------------------------------------------------------</p><p>  附錄------------------------

7、---------------------------------------------</p><p>  評分表------------------------------------------------------------------</p><p><b>  第一章:緒論</b></p><p>  一. 成績管理系統(tǒng)的背景

8、分析:</p><p>  當今時代是飛速發(fā)展的信息時代,在各行各業(yè)中離不開信息處理, 正是計算機被廣泛應用于信息管理系統(tǒng)的環(huán)境.計算機的最大好處在于利用它能夠進行信息管理.使用計算機進行信息控制,不僅提高了工作效率,而且大大的提高了其安全性.尤其對于復雜的信息管理,計算機能夠充分發(fā)揮它的優(yōu)越性.</p><p>  隨著科學技術的不斷提高,計算機科學日漸成熟,其強大的功能在人類社會的各個

9、領域并發(fā)揮著越來越重要的作用. 學生成績管理系統(tǒng)提供了強大的學生成績管理管理功能,方便系統(tǒng)管理員對學生成績等信息的添加,修改,刪除,查詢,留言等操作,同時一樣的方面學生對自己各科成績查詢,學習的交流.</p><p>  二.開發(fā)學生成績管理的必要性</p><p>  開發(fā)一個學生成績管理系統(tǒng),采用計算機對學生成績進行管理,進一步提高了辦學效益和現(xiàn)代化水平.為廣大教師和學生提高工作效率,

10、實現(xiàn)學生成績信息管理工作流程的系統(tǒng)化,規(guī)范化和自動化.現(xiàn)在我國的大中專院校的學生成績檔案管理水平普遍都不是很高,有的還停留在全用紙介質(zhì)基礎上,這種管理方式已不能適應時代的發(fā)展,社會的需求,因為它浪費了大量的人力物力,也存在著許多不足的因素.在今天信息時代這種傳統(tǒng)的管理方法必然會被計算機為基礎的信息管理系統(tǒng)所代替.一個高效的學生成績管理系統(tǒng)可以存儲歷屆的學生成績檔案,不需要大量的人力,只需要幾名專門錄入員即可操作系統(tǒng),節(jié)省大量人力,可以迅

11、速查到所需信息,高效,安全,學生在能方便的查看自己的成績.</p><p><b>  三.課程設計內(nèi)容</b></p><p><b>  ⑴問題描述:</b></p><p>  一個有N個學生的班級,每個學生有M門課程。該系統(tǒng)實現(xiàn)對班級成績的錄入、顯示、修改、排序、保存等操作的管理。</p><p

12、><b> ?、乒δ芤螅?lt;/b></p><p>  ①、本系統(tǒng)采用一個結構體數(shù)組,每個數(shù)據(jù)的結構應當包括:學號、姓名、M門課程名稱。</p><p> ?、?、本系統(tǒng)顯示這樣的菜單:</p><p><b>  請選擇系統(tǒng)功能項:</b></p><p><b>  成績錄入<

13、;/b></p><p><b>  成績顯示</b></p><p><b>  成績保存</b></p><p><b>  成績排序</b></p><p>  成績修改(要求先輸入密碼)</p><p><b>  成績統(tǒng)計<

14、;/b></p><p>  Ⅰ、顯示每門課程成績最高的學生的基本信息</p><p>  Ⅱ、顯示每門課程的平均成績</p><p><b>  退出系統(tǒng)</b></p><p>  ③、執(zhí)行一個具體的功能之后,程序?qū)⒅匦嘛@示菜單。</p><p> ?、?、將學生成績保存到文件中。<

15、/p><p><b> ?、撬惴ㄌ崾荆?lt;/b></p><p> ?、?、數(shù)據(jù)結構:結構體類型數(shù)組。</p><p>  ②、數(shù)據(jù)庫結構:下表構成該系統(tǒng)的基本數(shù)據(jù)庫。</p><p><b> ?、葴y試數(shù)據(jù):</b></p><p><b>  學生人數(shù)N=10</

16、b></p><p><b>  課程門數(shù)M=4</b></p><p>  課程名:數(shù)學、語文、英語、政治</p><p><b>  ⑸其它</b></p><p>  該系統(tǒng)有興趣的同學可以在實現(xiàn)上述基本功能后,完善系統(tǒng)的其它功能。</p><p>  四.課程設

17、計要求及分組安排。</p><p><b>  1. 課程設計要求</b></p><p>  1).設計正確,方案合理。</p><p>  2).界面友好,使用方便。</p><p>  3).程序精煉,結構清晰。</p><p>  4).設計報告5000字以上,含程序設計說明、用戶使用說明

18、,系統(tǒng)的功能框圖、流程圖、源程序清單等。</p><p><b>  5).上機演示。</b></p><p>  6).每個學生在規(guī)定的時間內(nèi)獨自完成相關課題的C源程序編寫,調(diào)整和運行。源程序及編譯生成各文件均保存在軟盤中;</p><p>  7).實際操作過程中遇到的問題及解決方法:設計總結及心得體會.</p><p&

19、gt;  8).按任務書的要求,按附錄的要求編寫《課程設計報告》(Word文檔格式)。并用A4的復印紙打印并裝訂。</p><p><b>  2.分組及安排</b></p><p>  所選題目(共8題)根據(jù)學生學號順序選課題號,四個人一道題,相鄰四個學號的同學選同一道題,32號以后的同學按學號每人選一題。如你的學號為15,則所選題目號為:第四題。</p>

20、;<p><b>  3.成績評定</b></p><p>  程序設計方案是否合理;程序設計是否正確;調(diào)試結果;設計說明書的質(zhì)量高低;答辯時回答問題情況;課程設計周表現(xiàn)情況;總評成績記入“課程設計成績評分表”。</p><p><b>  五. 進度安排</b></p><p>  第 一 周 星期四 :課

21、題講解,查閱資料。</p><p>  第 二 周 星期一 :總體設計,詳細設計。</p><p>  星期二 :編程,上機調(diào)試,修改程序。</p><p>  星期三:上機調(diào)試,完善程序。</p><p>  星期四:上機調(diào)試,完善程序。</p><p><b>  星期五:答辯。</b><

22、;/p><p>  星期六—星期天:撰寫課程設計報告。</p><p>  第二章:系統(tǒng)需求分析</p><p><b>  1.程序的功能:</b></p><p>  對一個有N個學生的班級,每個學生有M門課程。該系統(tǒng)實現(xiàn)對班級成績的錄入、顯示、修改、排序、保存等操作的管理。本系統(tǒng)采用一個包含N個結構的數(shù)組,每個數(shù)據(jù)結構

23、應當包括:學號、姓名、M個課程名稱。</p><p>  2. 輸入輸出要求:</p><p>  在菜單選項中1-7,選擇功能項,進行對應選項的函數(shù)調(diào)用.</p><p>  輸入1,輸入學生的基本信息存入磁盤文件中;</p><p>  輸入2,輸出已存盤的學生信息;</p><p>  輸入3,輸出用戶所要選擇科

24、目的提問,輸入科目后輸出該科目一排好的學生成績;</p><p>  輸入4,修改功能,輸入密碼.錯誤輸出是否繼續(xù)輸入密碼.正確則逐個輸出是否想要修改學生信息;</p><p>  輸入5,輸出三項功能的介紹,輸入你的選擇后輸出實現(xiàn)的結果;</p><p>  每執(zhí)行一個具體的程序后都要重新顯示菜單。</p><p>  第三章:系統(tǒng)概要設計

25、</p><p><b>  1.程序的模塊組成</b></p><p>  第一個模塊:先定義好一些必要的全局變量以及調(diào)用的函數(shù)和結構體數(shù)組。</p><p>  第二個模塊:設計一個菜單函數(shù)menu();實現(xiàn)能供用戶選擇功能項。</p><p>  第三個模塊:用enter()函數(shù)實現(xiàn)成績的輸入。</p>

26、<p>  第四個模塊:用save()函數(shù)實現(xiàn)成績的保存。</p><p>  第五個模塊:用print()函數(shù)實現(xiàn)成績輸出。</p><p>  第六個模塊:用cort()函數(shù)實現(xiàn)成績排序功能。</p><p>  第七個模塊:用modify()函數(shù)實現(xiàn)成績修改功能。</p><p>  第八個模塊:用count()函數(shù)實現(xiàn)成

27、績統(tǒng)計功能。</p><p>  2.學生信息結構數(shù)組</p><p>  struct stu</p><p><b>  {</b></p><p>  char name[20];</p><p><b>  int num;</b></p><p&

28、gt;  int score[M];</p><p><b>  };</b></p><p>  3.各個程序的功能介紹</p><p>  1:為便于用戶使用,先定義一個常數(shù)N表示人數(shù),學生信息的結構體數(shù)組,以及調(diào)用功能項的函數(shù)。</p><p>  2:在menu()函數(shù)中,用switch來選擇要執(zhí)行的功能項用do

29、…while實現(xiàn)每種具體功能后能返回菜單。</p><p>  3:Enter()函數(shù),用scanf依次輸入學生信息,在輸入多門成績成績時,用for循環(huán)來實現(xiàn),結尾調(diào)用save()函數(shù)保存。</p><p>  4:Print()函數(shù)中為使界面美觀對學生成績用%5d輸出,且用換行實現(xiàn),學生信息整齊排列。</p><p>  5:Save()函數(shù)使用文件保存。<

30、/p><p>  6:Cort()函數(shù)先定義choice1,輸出想要排序的 科目的 序號,用選擇排序法實現(xiàn)函數(shù)學生成績的排序。</p><p>  7:Modify()函數(shù),先定義好 一個密碼以及flag=0;如果輸入的密碼錯誤則flag=1,用do ..while實現(xiàn)是否重新輸入密碼,密碼準確后調(diào)用modi()函數(shù),實現(xiàn)修改功能。 </p><p>  8:Count

31、()函數(shù)用menu1函數(shù)實現(xiàn)一個菜單功能。用switch實現(xiàn),用戶選擇想執(zhí)行的功能,從而調(diào)用Show1()Show2()Show3();</p><p>  第四章:系統(tǒng)詳細設計</p><p><b>  1.總流程圖</b></p><p><b>  2.統(tǒng)計函數(shù)流程圖</b></p><p>

32、;<b>  第五章:測試</b></p><p><b>  1.系統(tǒng)調(diào)試</b></p><p>  1:在enter()函數(shù)中對學生成績的輸入用scanf(“%d”,s);當輸入一門成績后就會跳回,使接下來的程序無法運行,改為for(j=1;j<=M;j++) scanf(“%d”,&s[i].score[j]);將錯誤解決.

33、</p><p>  2:在enter函數(shù)中,輸入姓名用scanf(“%s”,&s[i].name);錯誤,在scanf函數(shù)中的輸入項如果是字符數(shù)組名代表該數(shù)組的起始地址.則應改為scanf(“%d”,s[i].name);</p><p>  3:在運行print()函數(shù)時,第四門課顯示出來的分數(shù)并非輸入項:錯誤,在定義時將j=1,應改為j=0。 </p><

34、p>  4:學生成績定義為浮點型,但與scanf連接不起來。是 由于所使用的系統(tǒng)不支持該項操作。</p><p>  5:在count( )函數(shù)中,show3( );輸出的人數(shù)比 實際的多一人,因為b++:在循環(huán)結束之后會自增一次,則比 實際的大一。</p><p><b>  2. 結果分析</b></p><p>  1:為了使調(diào)試程

35、序簡便,先定義班級的人數(shù)N為3人,編譯連接后,顯示出菜單桌面,先輸入學生成績保存起來.</p><p>  2:選擇2.在用循環(huán)輸出學生的基本信息的最后加printf(“\n”);,則輸出學生的基本信息是每行顯示一位同學的信息.</p><p>  3:選擇5.修改函數(shù)中用getchar()來覆蓋原有的,則就可輸出修改的信息.</p><p>  4:選擇6.用一個

36、選擇菜單</p><p>  int menu1()</p><p><b>  {</b></p><p>  int choice1;</p><p>  printf("\n*******\n");</p><p>  printf("1:xian shi me

37、i ke cheng ji zui gao de xue sheng xin xi\n");</p><p>  printf("2:xian shi mei ke ping jun cheng ji\n");</p><p>  printf("3:xian shi chao gou ping jun cheng ji de ren shu\n&q

38、uot;);</p><p>  printf("4:quit\n");</p><p>  printf("********\n");</p><p><b>  }</b></p><p>  選擇<1>.輸入選擇的科目用標記法找出成績最高的的學生則輸出其基本信息.

39、</p><p>  選擇<2>.用for循環(huán),先求出了每門的總成績再除以人數(shù)的到平均成績用一個數(shù)組接收.再用循環(huán)則的到結果.</p><p>  選擇<3>.先定義了一個數(shù)組b[M].用循環(huán)如果出現(xiàn)超過平均成績的人就自增一次,接收到b[M]中,用循環(huán)輸出b[M]則得到每門超過平均成績的人數(shù).</p><p>  5:在modify( )函數(shù)

40、中,當輸入一個錯誤的密碼時會出現(xiàn)死循環(huán),因為跳出的 位置錯誤了</p><p>  第六章:該系統(tǒng)使用說明</p><p>  1.運行時進入主界面,系統(tǒng)根據(jù)輸入的數(shù)字選項來調(diào)用相應的函數(shù)。主要實現(xiàn)“功能選擇”的界面,在這個界面里有顯示系統(tǒng)的七大功能,根據(jù)每個功能前面的序號進行選擇。以下為該介面;</p><p>  2.當錄入完成輸入顯示學生成績功能時,運行結果如

41、下圖:</p><p>  3. 當輸入輸入成績統(tǒng)計功能時,運行結果如下圖:</p><p>  3.成績修改時需要輸入密碼才能進行,密碼錯誤時不能進行該操作,只有輸入正確的密碼才能運行,運行結果如下圖:</p><p><b>  第七章:總結</b></p><p>  不經(jīng)一番寒徹骨,哪得梅花撲鼻香。</p&

42、gt;<p>  一周的C語言課程設計已接近尾聲了,現(xiàn)在回想起來真是五味俱全,從開</p><p>  始的懵懂無知到現(xiàn)在做出一本挺有厚度的資料,我不但實踐了課本的知識,還編出小程序,雖然很多人幫了我的忙,仍舊感覺自己對C語言有了深入的了解,還是有所成長,有所收獲,在實踐中,自己編程常會犯錯誤,并總結一些克服缺點的方法。深刻體會到程序設計中最重要的一部分不是編寫源程序,而是調(diào)試過程。只有經(jīng)過調(diào)試程序

43、,我們才能掌握正確的語法知識及把問題的解決方法用程序語言來表達。 在這段時間里,我門匆匆忙忙為了它準備了很多,其中不免有嘆息聲,但是總的來說讓我么學到了很多,也懂得了很多,不僅在知識方面,還在有人的生活態(tài)度,目標上。這次的C語言課程設計充分展示了C的魅力,用一些小小的實現(xiàn)合成一個系統(tǒng)從而融入到生活中解決實際問題。同時也教會了我應站在用戶的角度去設計程序。在此次設計過程中必不可少的出現(xiàn)了 很多問題,整體規(guī)劃,模塊與模塊之間的調(diào)用與劃分,

44、標識符的使用。單詞的拼寫錯誤,結構體數(shù)組的使用,正確的使用循環(huán)的限制條件….。</p><p>  這些問題大多是因為平時上課很少聽講的原因,以至于很多概念混淆不清 。這次的課程設計讓我看到自己對C語言研究地少之又少。這次的班級成績管理系統(tǒng)仍舊存在著不足。</p><p>  記得開始課設的第一天,我糊里糊涂地在機房呆了一個上午,對老師要求做的課程設計束手無策,上網(wǎng)搜了幾個,但覺得沒點意思

45、,最后還是沒有用。但相對于別人的做的系統(tǒng),我的好像簡單多了。但后來還是不得不去看書,因為很多東西還牛毛都不知道。比如,做這個課程設計時候,最好使用鏈表,而鏈表我們還沒有深入去熟悉它,在說這個課程設計牽涉到前面我們學過的所有內(nèi)容,如,一些基本函數(shù)的運用,函數(shù)的調(diào)用及指針,結構體。內(nèi)容多而復雜,如果沒有對教材有個很好的了解掌握,是不可能篇好這個程序的。我還在把書本重新溫習了一遍,對照程序一一翻書,試圖找到一中解釋來說明程序當中一些函數(shù)的作用

46、和結構。</p><p>  接下來的一段時間里對這段程序進行了修改,經(jīng)過東湊西湊,拼拼剪剪,終于可以在電腦上運行了,但是它的功能不是很完善,需要進一步完善。后來懷著疑問去詢問老師才發(fā)現(xiàn)其實很多問題都想比較簡單的,比如在運行程序時發(fā)現(xiàn)無論我怎么輸入成績,第四門課的成績都與我輸入的分數(shù)不同,自己也嘗試用很多方法去解決,最終不了了之。同學看過以后告訴我是我在定義的時候把初始值定義錯了。在修該以后,再次運行便沒看見以前

47、的錯誤了。后來有用這種方法把后面的兩個警告解決了一個。</p><p>  在這個過程中,也試圖自己獨立完成這個課程,偶爾發(fā)現(xiàn)書本上第11章節(jié)里面,有介紹鏈表的使用,而且書本上關于這個課程的一些基本函數(shù)功能在本章節(jié)都有說明,比如,鏈表的創(chuàng)建,節(jié)點的插入,刪除,一些基本信息的修改都有。</p><p>  最終完成的課程的設計,馬馬虎虎的,完成的,但是還是受益匪淺。其中老</p>

48、<p>  師與同學的教導讓我刻苦銘心。不管其結果怎么樣,但至少這個過程,讓我們明白了,懂得了很多。雖然有點挫折很艱辛在里面,但是那都是短暫的,美麗的,它教會了我們不經(jīng)過自己的努力,是達不到預期的結果的,不經(jīng)過自己的實踐操作,是體驗不到其中的美妙的。不僅如此,還給了我們一個警告,對待學習不可馬馬虎虎,否則完成不了應有的任務,得不到理想的結果,半途而廢是失敗的首要原因,不要什么事情都覺得滿不在乎,踏踏實實的學習,踏踏實實的工

49、作,擁有積極樂觀的態(tài)度去應對一切挫折,最終會讓你走想成功的前沿。因為:“勝利永遠是屬于永不放棄的人!</p><p><b>  附錄</b></p><p><b>  1. 參考文獻</b></p><p>  《C程序設計(第三版)》 譚浩強 著 清華大學出版社</p>&l

50、t;p>  《C語言程序設計實用指南》 譚浩強 著 清華大學出版社</p><p>  《C語言大學實用教程學習指導》 蘇小紅 著 電子工業(yè)出版社</p><p><b>  源代碼</b></p><p>  #include <stdio.h> /*I/O函數(shù)*/</

51、p><p>  #include <string.h> /*字符串函數(shù)*/</p><p>  #define M 4 /*課程數(shù)*/</p><p>  #define NUM 3 /*人數(shù)*/ </p><p>  #define NULL 0</p><p>  #include<stdio

52、.h></p><p>  #include<string.h></p><p>  int avar[M];</p><p>  struct stu</p><p><b>  {</b></p><p>  char name[20];</p><p&g

53、t;<b>  int num;</b></p><p>  int score[M];</p><p><b>  };</b></p><p>  void enter(struct stu s[],int n); /*進入*/</p><p>  void print(struct stu

54、 s[],int n); /*輸入文件*/</p><p>  void save(struct stu s[],int n); /*保存文件*/</p><p>  void sort(struct stu s[],int n); /*排序*/</p><p>  void modify(struct stu s[],int n); /*修改*/</

55、p><p>  void count(struct stu s[],int n); /*統(tǒng)計*/</p><p>  int menu();</p><p>  void main()</p><p><b>  {</b></p><p>  void clrscr();</p>&

56、lt;p>  struct stu student[NUM];</p><p>  for( ; ; )</p><p>  switch(menu())</p><p><b>  {</b></p><p>  case 1:enter(student,NUM);break;</p><p&

57、gt;  case 2:print(student,NUM);break;</p><p>  case 3:save(student,NUM);break;</p><p>  case 4:sort(student,NUM);break;</p><p>  case 5:modify(student,NUM);break;</p><p&g

58、t;  case 6:count(student,NUM);break;</p><p>  case 7:return;</p><p><b>  }</b></p><p><b>  }</b></p><p>  int menu()</p><p><b&g

59、t;  {</b></p><p>  int choice;</p><p>  printf("\n**************************級成績管理***************************\n");</p><p>  printf(" 1

60、成績錄入\n");</p><p>  printf(" 2 成績顯示\n");</p><p>  printf(" 3 成績保存\n");</p><p>  printf("

61、 4 成績排序\n");</p><p>  printf(" 5 成績修改\n");</p><p>  printf(" 6 成績統(tǒng)計\n");</p><p>  printf(&

62、quot; 7 退出系統(tǒng)\n");</p><p>  printf(" 學生人數(shù)級 NUM 課程 數(shù)學0 語文1 英語2 政治3\n");</p><p>  printf("**********************************************

63、*****************\n");</p><p><b>  do</b></p><p><b>  {</b></p><p>  printf("\nchoice1-7:");</p><p>  scanf("%d",&c

64、hoice);</p><p><b>  }</b></p><p>  while(choice<1||choice>7);</p><p>  return choice;</p><p><b>  }</b></p><p>  void enter(s

65、truct stu s[],int n) //成績錄入</p><p><b>  {</b></p><p><b>  char c;</b></p><p><b>  int i=0;</b></p><p><b>  int j;</b

66、></p><p><b>  do </b></p><p><b>  {</b></p><p>  printf("please enter the message:\n");</p><p>  getchar();</p><p>  p

67、rintf("enter name:\n");</p><p>  scanf("%s",s[i].name);</p><p>  printf("enter num:\n");</p><p>  scanf("%d",&s[i].num);</p><p

68、>  printf("enter score:\n");</p><p>  for(j=0;j<M;j++)</p><p>  scanf("%d",&s[i].score[j]);</p><p>  printf("按Y繼續(xù)錄入,按N結束錄入!");</p><

69、;p>  getchar();</p><p>  scanf("%c",&c);</p><p>  if(c!='Y'&&c!='y') //可以選擇是否繼續(xù)錄入</p><p><b>  break;</b></p>

70、;<p><b>  ++i;</b></p><p>  }while(i!=n);</p><p><b>  }</b></p><p>  void save(struct stu s[],int n) //文件存儲數(shù)據(jù)</p><

71、;p><b>  {</b></p><p><b>  FILE *fp;</b></p><p><b>  int i;</b></p><p>  char save[20];</p><p>  printf("enter the file name:

72、");</p><p>  scanf("%s",save); /*輸入選擇項*/</p><p>  if((fp=fopen("stu-list","wb"))==NULL)</p><p><b>  {<

73、/b></p><p>  printf("can not open file\n");</p><p><b>  return;</b></p><p><b>  }</b></p><p><b>  else</b></p>&

74、lt;p><b>  {</b></p><p>  for (i=0;i<n;i++)</p><p>  if(fwrite (&s[i],sizeof(struct stu),1,fp)!=1);</p><p>  printf("file write error\n");</p>

75、<p>  fclose(fp);</p><p>  printf("success\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  void print (struct stu s[],int n)

76、 //成績顯示</p><p><b>  {</b></p><p><b>  int i,j;</b></p><p>  for(i=0;i<n;i++)</p><p><b>  { </b></p&g

77、t;<p>  printf(" 數(shù)學 語文 英語 政治\n");</p><p>  printf("%s",s[i].name);</p><p>  printf("%d",s[i].num);</p><p>  for(j=0;j<M;j++)</p>&l

78、t;p>  printf("%5d",s[i].score[j]);</p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  void sort(struct s

79、tu s[],int n) /*排序*/</p><p><b>  {</b></p><p>  int i,j,min,temp,k; </p><p>  printf("please choice subject 1-4:\n");</p><p>  scanf("%d&q

80、uot;,&k);</p><p>  for(i=0;i<n-1;i++)</p><p><b>  {</b></p><p><b>  min=i;</b></p><p>  for(j=i+1;j<n;j++)</p><p>  if(s[

81、min].score[k]>s[j].score[k])</p><p><b>  {</b></p><p>  temp=s[min].score[k];</p><p>  s[min].score[k]=s[j].score[k];</p><p>  s[j].score[k]=temp;</p&

82、gt;<p><b>  }</b></p><p><b>  }</b></p><p>  printf("\n The sorted numbers:\n");</p><p>  for(i=0;i<n;i++)</p><p>  printf(&

83、quot;%5d",s[i].score[k]);</p><p>  printf("\n");</p><p><b>  }</b></p><p>  void count(struct stu s[],int n)</p><p><b>  {</b><

84、;/p><p>  void show1(struct stu a[],int n1);</p><p>  void show2(struct stu a[],int n1);</p><p>  int menu1();</p><p>  for( ; ;) </p><p>  switch(menu1())&l

85、t;/p><p><b>  {</b></p><p>  case 1:show1(s,n);break;</p><p>  case 2:show2(s,n);break;</p><p>  case 3:return;</p><p><b>  }</b></

86、p><p><b>  }</b></p><p>  int menu1()</p><p>  {int choice1;</p><p>  printf("\n**********************************\n");</p><p>  printf(

87、"1:顯示每科成績最高的學生信息\n");</p><p>  printf("2:顯示每科平均成績\n");</p><p>  printf("3:退出\n");</p><p>  printf("**********************************\n");<

88、;/p><p>  do {printf("\n Enter tou choice1 (1-3):");</p><p>  scanf("%d",&choice1);}while(choice1<1||choice1>3);</p><p>  return choice1;</p><p

89、><b>  }</b></p><p>  void show1(struct stu a[],int n1)</p><p><b>  {</b></p><p>  int k,i,j,c=0;</p><p>  printf("please enter the subje

90、ct num:");</p><p>  scanf("%d",&k);</p><p>  for(i=0;i<n1;i++)</p><p>  if(a[c].score[k]<a[i].score[k])</p><p><b>  c=i;</b></p&

91、gt;<p>  printf("%s,%d",a[c].name,a[c].num);</p><p>  for(j=0;j<M;j++)</p><p>  printf("%5d",a[c].score[j]);</p><p><b>  }</b></p>&

92、lt;p>  void show2(struct stu a[],int n1)</p><p><b>  {</b></p><p>  int i,j,sum;</p><p>  for(j=0;j<M;j++)</p><p><b>  {</b></p>&l

93、t;p><b>  sum=0;</b></p><p>  for(i=0;i<n1;i++)</p><p>  sum=sum+a[i].score[j];</p><p>  avar[j]=sum/n1;</p><p>  printf("The %d avarage is:%d\n&q

94、uot;,j,avar[j]);</p><p><b>  }</b></p><p><b>  }</b></p><p>  void modify(struct stu s[],int n)</p><p><b>  {</b></p><p&g

95、t;  void modi(struct stu c[],int n1);</p><p>  int flag=0;</p><p>  char a[10],c,code[10]="1234a";/*密碼*/</p><p><b>  do</b></p><p><b>  {<

96、;/b></p><p>  printf("please enter you code:\n");</p><p>  scanf("%s",&a);</p><p>  if(strcmp(code,a)==0)break;</p><p><b>  else</b&

97、gt;</p><p><b>  {</b></p><p>  printf("You code is wrong,enter again?y\n\n");</p><p>  scanf("%c\n",&c);</p><p>  if(c=='n'|

98、|c=='N')</p><p><b>  {</b></p><p>  flag=1;break;</p><p><b>  }</b></p><p><b>  }</b></p><p>  }while(1);</p

99、><p>  if(flag==0)</p><p>  modi(s,n);</p><p><b>  }</b></p><p>  void modi (struct stu c[],int n1)</p><p><b>  {</b></p><p

100、>  int num,ch;</p><p><b>  int i,j;</b></p><p>  printf("please input modify No:");</p><p>  scanf("%d",&num );</p><p>  getchar(

101、);</p><p>  for(i=0;i<n1;i++)</p><p>  if(c[i].num==num)</p><p><b>  break;</b></p><p><b>  if(i>=n1)</b></p><p>  printf(&qu

102、ot;\n list No %d student\n",c[i].num);</p><p><b>  else</b></p><p><b>  {</b></p><p>  printf("modify(y/n)?\n");</p><p>  ch=getc

103、har();getchar();</p><p>  if(ch=='y'||ch=='Y')</p><p><b>  {</b></p><p>  printf("enter num\n");</p><p>  scanf("%d",&am

104、p;c[i].num);</p><p>  getchar();</p><p><b>  }</b></p><p>  printf("modify name(y/n)?\n");</p><p>  // ch=getchar();getchar();</p><p>

105、;  if(ch=='y'||ch=='Y')</p><p><b>  {</b></p><p>  printf("enter name:\n");</p><p>  scanf("%s",c[i].name);</p><p>  get

106、char();</p><p><b>  }</b></p><p>  printf("modify record(y/n)?\n");</p><p>  ch=getchar();getchar();</p><p>  if(ch=='y'||ch=='Y')

107、</p><p><b>  {</b></p><p>  printf("enter record:\n");</p><p>  for(j=0;j<M;j++)</p><p><b>  {</b></p><p>  scanf(&quo

108、t;%d",&c[i].score[j]);</p><p>  getchar();</p><p><b>  }</b></p><p><b>  }return;</b></p><p><b>  }</b></p><p>

109、;<b>  }</b></p><p>  應用技術學院課程設計評分表</p><p>  課題名稱: </p><p>  教師簽名: </p><p>  日 期: </p><p>

溫馨提示

  • 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

提交評論