版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 課程設(shè)計(jì)報(bào)告</b></p><p> 題 目: 學(xué)生成績(jī)管理系統(tǒng) </p><p> 姓 名: </p><p> 學(xué) 院: 理學(xué)與信息科學(xué)學(xué)院
2、 </p><p> 專 業(yè): 通信工程 </p><p> 班 級(jí): 1班 </p><p> 學(xué) 號(hào): </p><p> 指導(dǎo)教師:
3、 </p><p><b> 2013年9月4日</b></p><p><b> 目 錄</b></p><p> 一 設(shè)計(jì)目的…………………………………………………………….3</p><p> 二 課程設(shè)計(jì)的內(nèi)容.
4、.......................................3</p><p> 三 課程設(shè)計(jì)的要求與數(shù)據(jù)..................................3</p><p> 四 課程設(shè)計(jì)應(yīng)完成的工作..................................4</p><p> 五 總體設(shè)計(jì)(包含幾大
5、功能模塊)...........................4</p><p> 六 詳細(xì)設(shè)計(jì)(各功能模塊的具體實(shí)現(xiàn)算法——流程圖)………….5</p><p> 七 調(diào)試分析(包含各模塊的測(cè)試用例,及測(cè)試結(jié)果)…………….6</p><p> 八 總結(jié)………………………………………………………………...16</p><p
6、> 九 參考資料…………………………………………………………….17</p><p><b> 一 設(shè)計(jì)目的</b></p><p> 進(jìn)一步加深、鞏固所學(xué)專業(yè)課程(《C語(yǔ)言程序設(shè)計(jì)》)的基本理論知識(shí),理論聯(lián)系實(shí)際,進(jìn)一步培養(yǎng)自己綜合分析問(wèn)題和解決問(wèn)題的能力。掌握運(yùn)用C語(yǔ)言獨(dú)立地編寫、調(diào)試應(yīng)用程序和進(jìn)行其它相關(guān)設(shè)計(jì)的技能。</p>&l
7、t;p> 二 課程設(shè)計(jì)的內(nèi)容</p><p> 對(duì)學(xué)生信息(包括學(xué)號(hào)、語(yǔ)文、數(shù)學(xué)、英語(yǔ)、平均分)進(jìn)行管理,包括學(xué)生成績(jī)的信息輸入、輸出、查詢、刪除、排序、統(tǒng)計(jì)、退出.將學(xué)生的成績(jī)信息進(jìn)行記錄,信息內(nèi)容包含:(1)學(xué)生的學(xué)號(hào)(2)學(xué)生的姓名(3)學(xué)生的成績(jī)。假設(shè),現(xiàn)收集到了一個(gè)班學(xué)生的所有成績(jī)信息,要求用C語(yǔ)言編寫一個(gè)簡(jiǎn)單的成績(jī)管理系統(tǒng),可進(jìn)行錄入、查詢、修改和瀏覽等功能。學(xué)習(xí)相關(guān)開發(fā)工具和應(yīng)用軟件,熟
8、悉系統(tǒng)建設(shè)過(guò)程。</p><p> 三 課程設(shè)計(jì)的要求與數(shù)據(jù)</p><p> 1、用C語(yǔ)言實(shí)現(xiàn)系統(tǒng);</p><p> 2、對(duì)學(xué)生信息(包括學(xué)號(hào)、姓名、語(yǔ)文、數(shù)學(xué)、英語(yǔ)、平均分)進(jìn)行管理,包括學(xué)生成績(jī)的信息輸入、輸出、查詢、刪除、排序、統(tǒng)計(jì)、退出.</p><p> 3、學(xué)生信息包括:其內(nèi)容較多,為了簡(jiǎn)化討論,要求設(shè)計(jì)的管理系統(tǒng)能
9、夠完成以下功能:</p><p> 1)輸入記錄模塊。輸入記錄模塊主要完成將數(shù)據(jù)存入單鏈表中的工作。在此成績(jī)管理系統(tǒng)中,記錄可以從以二進(jìn)制形式存儲(chǔ)的數(shù)據(jù)文件中讀入,也可從鍵盤逐個(gè)輸入學(xué)生記錄。學(xué)生記錄由學(xué)生的基本信息和成績(jī)信息字段構(gòu)成。當(dāng)從數(shù)據(jù)文件中讀入記錄時(shí),它就是在以記錄為單位存儲(chǔ)的數(shù)據(jù)文件中,將記錄逐條復(fù)制到單鏈表中。</p><p> 2)查詢記錄模塊。查詢記錄模塊主要完成在單
10、鏈表中查找滿足相關(guān)條件的學(xué)生記錄。在此成績(jī)管理系統(tǒng)中,用戶可以按照學(xué)生的學(xué)號(hào)或姓名在單鏈表中進(jìn)行查找。若找打該學(xué)生的記錄,則返回指向該學(xué)生的指針。否則,返回一個(gè)值為NULL的空指針,并打印出未找到該學(xué)生記錄的提示信息。</p><p> 3)更新記錄模塊。更新記錄模塊主要完成對(duì)學(xué)生記錄的維護(hù)。在此成績(jī)管理系統(tǒng)中,它 實(shí)現(xiàn)了對(duì)學(xué)生記錄的修改、刪除、插入和排序操作。一般而言,系統(tǒng)進(jìn)行論文這些操作之后,需要將修改的數(shù)
11、據(jù)存入源數(shù)據(jù)文件。</p><p> 4)統(tǒng)計(jì)記錄模塊。統(tǒng)計(jì)記錄模塊主要完成對(duì)各門功課最高分和不及格人數(shù)的統(tǒng)計(jì)。</p><p> 5)輸出記錄模塊。輸出記錄模塊主要完成兩個(gè)任務(wù)。第一,它實(shí)現(xiàn)對(duì)學(xué)生記錄的存盤操作,即將單鏈表中的各節(jié)點(diǎn)中存儲(chǔ)的學(xué)生記錄信息寫入數(shù)據(jù)文件中。第二,它實(shí)現(xiàn)將單鏈表中存儲(chǔ)的學(xué)生記錄信息以表格的形式在屏幕上打印出來(lái)。</p><p> 四
12、 課程設(shè)計(jì)應(yīng)完成的工作</p><p><b> (1)編寫算法;</b></p><p> (2)算法測(cè)試,并有具體的測(cè)試結(jié)果和結(jié)果分析;</p><p> (3)撰寫課程設(shè)計(jì)報(bào)告。內(nèi)容包括:</p><p><b> 封面扉頁(yè)</b></p><p><b
13、> 設(shè)計(jì)任務(wù)書</b></p><p><b> 目錄</b></p><p> 總體設(shè)計(jì)方案(包括流程圖)</p><p> 使用說(shuō)明及運(yùn)行實(shí)例(包括界面)</p><p><b> 成員設(shè)計(jì)內(nèi)容簡(jiǎn)介</b></p><p> 項(xiàng)目源程序代碼(
14、注意注釋的使用)</p><p><b> 指導(dǎo)教師評(píng)語(yǔ)</b></p><p> 五 總體設(shè)計(jì)(包含幾大功能模塊)</p><p><b> 1、成績(jī)錄入功能</b></p><p><b> 2、成績(jī)查詢功能</b></p><p><
15、;b> 3、成績(jī)更新功能</b></p><p><b> 4、統(tǒng)計(jì)功能</b></p><p><b> 5、輸出功能 </b></p><p><b> 6、退出系統(tǒng)</b></p><p> 六 詳細(xì)設(shè)計(jì)(各功能模塊的具體實(shí)現(xiàn)算法——流程圖
16、)</p><p> 6.1各函數(shù)的功能和實(shí)現(xiàn)</p><p> 1、輸入初始的學(xué)生信息:輸入信息包括學(xué)生的姓名、學(xué)號(hào)以及學(xué)生的成績(jī)等相關(guān)信息;可用函數(shù)void input(STUDENT *data, int *len)來(lái)實(shí)現(xiàn)此操作。 </p><p> 2、成績(jī)輸出模塊:輸出學(xué)生的信息以及成績(jī)void output(STUDENT *data, int
17、len):通過(guò)學(xué)生的姓名來(lái)查看學(xué)生的相關(guān)成績(jī),同時(shí)也可以分別通過(guò)caverage() 、maverage() 、eaverage() 和comaverage() 來(lái)輸出成績(jī)的平均分?jǐn)?shù)、最高和最低分?jǐn)?shù)。</p><p> 3、成績(jī)查詢模塊:可用void find(STUDENT *data, int len) 來(lái)實(shí)現(xiàn)。找到就輸出此學(xué)生全部信息。</p>
18、<p> 4、刪除模塊:用函數(shù)void delete_item(STUDENT *data, int *len)來(lái)實(shí)現(xiàn)</p><p> 5、排序模塊:用函數(shù)void sort(STUDENT *data, int len)來(lái)實(shí)現(xiàn)</p><p> 6、統(tǒng)計(jì)功能能:用函數(shù)void stat(STUDENT *data, int len) 來(lái)實(shí)現(xiàn)</p>&
19、lt;p> 7、退出系統(tǒng):可用一個(gè)函數(shù)exit()來(lái)實(shí)現(xiàn),首先將信息保存到文件中,釋放動(dòng)態(tài)創(chuàng)建的內(nèi)存空間,再退出此程序。</p><p> 如圖七 調(diào)試分析(包含各模塊的測(cè)試用例,及測(cè)試結(jié)果)</p><p><b> 7.1源程序</b></p><p> #include <stdio.h></p>
20、<p> #include<string.h></p><p> #include <stdlib.h></p><p> #include <malloc.h></p><p> #define LEN sizeof(Student)</p><p> typedef struct
21、student</p><p><b> {</b></p><p><b> int num;</b></p><p> char name[20];</p><p> int score[4];</p><p><b> int sum;</b&
22、gt;</p><p> struct student *next;</p><p><b> }Student;</b></p><p><b> int n;</b></p><p> Student *cin(void); </p><p> Student
23、*sort_1(Student *head,int); </p><p> void sort_2(Student *head);</p><p> void print(Student *head);</p><p> Student *sort_all(Student *head);</p><p> void find(Stud
24、ent *head);</p><p> Student *add_new(Student *head);</p><p> Student *cin()</p><p><b> {</b></p><p> int flag; </p><p> Student *head,*p1,
25、*p2;</p><p><b> n=0;</b></p><p> head=(Student *)malloc(LEN);</p><p><b> p2=head;</b></p><p> printf("\n請(qǐng)輸入第%d名學(xué)生的學(xué)號(hào),學(xué)號(hào)為0表示結(jié)束輸入:",
26、n+1); </p><p> scanf("%d",&flag);</p><p> while(getchar()!='\n');</p><p> for(;flag;)</p><p><b> {</b></p><p><b&g
27、t; n++;</b></p><p> p1=(Student *)malloc(LEN);</p><p> p1->num=flag;</p><p> printf("請(qǐng)輸入第%d名學(xué)生的姓名:",n);</p><p> scanf("%s",p1->name
28、); </p><p> printf("請(qǐng)輸入第%d名學(xué)生的高數(shù)成績(jī):",n);</p><p> scanf("%d",&p1->score[0]);</p><p> printf("請(qǐng)輸入第%d名學(xué)生的英語(yǔ)成績(jī):",n);</p><p> scanf(
29、"%d",&p1->score[1]);</p><p> printf("請(qǐng)輸入第%d名學(xué)生的計(jì)算機(jī)成績(jī):",n);</p><p> scanf("%d",&p1->score[2]);</p><p> printf("請(qǐng)輸入第%d名學(xué)生的物理成績(jī):&quo
30、t;,n);</p><p> scanf("%d",&p1->score[3]);</p><p> p1->sum=p1->score[0]+p1->score[1]+p1->score[2]+p1->score[3];</p><p> p2->next=p1;</p>
31、<p><b> p2=p1;</b></p><p> printf("\n請(qǐng)輸入第%d名學(xué)生的學(xué)號(hào),沒(méi)有此學(xué)生則輸入0表示結(jié)束:",n+1); </p><p> scanf("%d",&flag);</p><p><b> }</b></p&g
32、t;<p> p2->next=NULL;</p><p> printf("\n\n");</p><p> return head;</p><p><b> }</b></p><p> Student *sort_all(Student *head)</p&
33、gt;<p><b> {</b></p><p> int choose;</p><p><b> for(;;) </b></p><p><b> {</b></p><p> printf("\n\t\t# # # # # 學(xué)生成績(jī)統(tǒng)
34、計(jì)排序 # # # #\n");</p><p> printf("\t\t#\t1.按學(xué)生學(xué)號(hào)排序\t #\n");</p><p> printf("\t\t#\t2.按學(xué)生總分排序\t #\n");</p><p> printf("\t\t#\t3.按學(xué)生高數(shù)成績(jī)排序\t #\n")
35、;</p><p> printf("\t\t#\t4.按學(xué)生英語(yǔ)成績(jī)排序\t #\n");</p><p> printf("\t\t#\t5.按學(xué)生計(jì)算機(jī)成績(jī)排序\t #\n");</p><p> printf("\t\t#\t6.按學(xué)生物理成績(jī)排序\t #\n");</p>&l
36、t;p> printf("\t\t#\t7.單科高分及均分\t #\n");</p><p> printf("\t\t#\t8.顯示當(dāng)前學(xué)生成績(jī)\t #\n");</p><p> printf("\t\t#\t0.返回上一級(jí)菜單\t #\n");</p><p> printf("
37、;\t\t# # # # # # ^-^ # # # #\n\n"); </p><p> printf("請(qǐng)輸入你要執(zhí)行的操作:");</p><p> scanf("%d",&choose);</p><p> while(getchar()!='\n');</p>&
38、lt;p> switch(choose)</p><p><b> {</b></p><p><b> case 1:</b></p><p><b> case 2:</b></p><p><b> case 3:</b></p
39、><p><b> case 4:</b></p><p><b> case 5:</b></p><p> case 6:head=sort_1(head,choose);break;</p><p> case 7:print(head);sort_2(head);break;</p
40、><p> case 8:print(head);break;</p><p> case 0:return head;</p><p> default: printf("\n\n您的輸入有誤!請(qǐng)重新輸入:\n\n");break;</p><p><b> }</b></p>&
41、lt;p><b> }</b></p><p><b> }</b></p><p> Student *sort_1(Student *head,int choose)</p><p><b> {</b></p><p> Student *p1,*p2=h
42、ead->next,*pm,*px;</p><p> Student mid;</p><p> if (!p2) return head;</p><p> for(p1=p2;p1->next!=NULL;p1=p1->next)</p><p><b> {</b></p>
43、<p><b> pm=p1;</b></p><p> for(p2=p1->next;p2!=NULL;p2=p2->next)</p><p> switch(choose)</p><p><b> {</b></p><p> case 1:if (pm-
44、>num>p2->num) pm=p2;break;</p><p> case 2:if (pm->sum<p2->sum) pm=p2;break;</p><p> case 3:if (pm->score[0]<p2->score[0]) pm=p2;break;</p><p> case 4:i
45、f (pm->score[1]<p2->score[1]) pm=p2;break;</p><p> case 5:if (pm->score[2]<p2->score[2]) pm=p2;break;</p><p> case 6:if (pm->score[3]<p2->score[3]) pm=p2;break;</
46、p><p><b> }</b></p><p> if (pm!=p1)</p><p><b> {</b></p><p><b> mid=*pm;</b></p><p><b> *pm=*p1;</b></
47、p><p><b> *p1=mid;</b></p><p> px=pm->next;</p><p> pm->next=p1->next;</p><p> p1->next=px;</p><p><b> }</b></p>
48、;<p><b> }</b></p><p> printf("\n排序后的成績(jī)表為:\n");</p><p> print(head); </p><p> return head;</p><p><b> }</b></p><
49、;p> void sort_2(Student *head)</p><p><b> {</b></p><p> Student *p=head->next;</p><p> int max_1,max_2,max_3,max_4,min_1,min_2,min_3,min_4;</p><p>
50、; int max_sum,min_sum;</p><p> int sum_1=0,sum_2=0,sum_3=0,sum_4=0;</p><p> float aver_1,aver_2,aver_3,aver_4,aver_sum;</p><p> if (!p) return;</p><p> max_1=min_1
51、=p->score[0];max_2=min_2=p->score[1];</p><p> max_3=min_3=p->score[2];max_2=min_2=p->score[3];</p><p> max_sum=min_sum=p->sum;</p><p> for(;p;p=p->next)</p&g
52、t;<p><b> {</b></p><p> if (max_1<p->score[0]) max_1=p->score[0];</p><p> else if (min_1>p->score[0]) min_1=p->score[0];</p><p> if (max_2&l
53、t;p->score[1]) max_2=p->score[1];</p><p> else if (min_2>p->score[1]) min_2=p->score[1];</p><p> if (max_3<p->score[2]) max_3=p->score[2];</p><p> else if
54、 (min_3>p->score[2]) min_3=p->score[2];</p><p> if (max_4<p->score[3]) max_4=p->score[3];</p><p> else if (min_4>p->score[3]) min_4=p->score[3];</p><p>
55、 if (max_sum<p->sum) max_sum=p->sum;</p><p> else if (min_sum>p->sum) min_sum=p->sum; </p><p> sum_1+=p->score[0];sum_2+=p->score[1];sum_3+=p->score[2];sum_4+=p->
56、;score[3];</p><p><b> }</b></p><p> aver_1=1.0*sum_1/n;aver_2=1.0*sum_2/n;aver_3=1.0*sum_3/n;aver_4=1.0*sum_4/n;</p><p> aver_sum=aver_1+aver_2+aver_3+aver_4;</p&g
57、t;<p> printf("總共%d名學(xué)生,具體數(shù)據(jù)為:\n",n); </p><p> printf("高數(shù)最高分為%d,最低分為%d,平均分為%.2f\n",max_1,min_1,aver_1);</p><p> printf("英語(yǔ)最高分為%d,最低分為%d,平均分為%.2f\n",max_2,m
58、in_2,aver_2);</p><p> printf("計(jì)算機(jī)最高分為%d,最低分為%d,平均分為%.2f\n",max_3,min_3,aver_3); </p><p> printf("物理最高分為%d,最低分為%d,平均分為%.2f\n",max_4,min_4,aver_4);</p><p> prin
59、tf("總分最高分為%d,最低分位%d,平均分為%.2f\n",</p><p> max_sum,min_sum,aver_sum);</p><p><b> } </b></p><p> void find(Student *head)</p><p><b> {</
60、b></p><p> Student *p;</p><p> int choose,fnum;</p><p> char tem[20];</p><p> if (n==0) {printf("\n當(dāng)前系統(tǒng)沒(méi)有任何學(xué)生數(shù)據(jù),您就別費(fèi)勁了!\n ");return;}</p><p&
61、gt;<b> for(;;)</b></p><p><b> {</b></p><p> printf("\n請(qǐng)輸入您要查詢學(xué)生的方式:\n\n");</p><p> printf("1、按學(xué)號(hào)查詢;2、按姓名查詢;0、我不查詢了。\n\n");</p>
62、<p> printf("請(qǐng)選擇:");</p><p> scanf("%d",&choose);</p><p> while(getchar()!='\n');</p><p> if (choose==1) </p><p><b> {&
63、lt;/b></p><p> printf("\n請(qǐng)輸入您要查詢的學(xué)生的學(xué)號(hào),輸入0退出學(xué)號(hào)查詢:");</p><p> scanf("%d",&fnum);</p><p> for(;fnum;)</p><p><b> {</b></p>
64、;<p> for(p=head->next;p!=NULL&&p->num!=fnum;p=p->next);</p><p><b> if (!p) </b></p><p><b> {</b></p><p> printf("\n\n沒(méi)有找到您要
65、查詢的學(xué)號(hào),請(qǐng)重新輸入,輸入0表示結(jié)束:");</p><p> scanf("%d",&fnum);</p><p><b> }</b></p><p> else if (p->num==fnum)</p><p><b> {</b><
66、;/p><p> printf("\n學(xué)號(hào)為%d學(xué)生的數(shù)據(jù)為:\n",p->num);</p><p> printf("學(xué)號(hào)\t姓名\t高數(shù)成績(jī) 英語(yǔ)成績(jī) 計(jì)算機(jī)成績(jī) \</p><p> 物理成績(jī) 總分\n");</p><p> printf("%d\t%s\t %d %d %
67、d %d \</p><p> %d\n",p->num,</p><p> p->name,p->score[0],p->score[1],p->score[2],p->score[3],</p><p><b> p->sum);</b></p><p>
68、printf("\n\n請(qǐng)輸入您還要查詢的學(xué)生的學(xué)號(hào),輸入0表示不按學(xué)\</p><p><b> 號(hào)查詢了:");</b></p><p> scanf("%d",&fnum);</p><p><b> }</b></p><p><b
69、> }</b></p><p><b> } </b></p><p> else if (choose==2)</p><p><b> {</b></p><p> printf("\n請(qǐng)輸入您要查詢的學(xué)生的姓名,輸入0退出姓名查詢:");<
70、/p><p> scanf("%s",tem); </p><p> for(;strcmp(tem,"0");)</p><p><b> {</b></p><p> for(p=head->next;p!=NULL&&strcmp(p->nam
71、e,tem);p=p->next);</p><p><b> if (!p)</b></p><p><b> {</b></p><p> printf("\n\n沒(méi)有找到您要查詢的姓名,請(qǐng)重新輸入,輸入0表\</p><p><b> 示結(jié)束:");
72、</b></p><p> scanf("%s",tem);</p><p><b> }</b></p><p> else if (!strcmp(p->name,tem))</p><p><b> {</b></p><p&g
73、t; printf("\n姓名為%s學(xué)生的數(shù)據(jù)為:\n",p->name);</p><p> printf("學(xué)號(hào)\t姓名\t高數(shù)成績(jī) 英語(yǔ)成績(jī) 計(jì)算機(jī)成績(jī) \</p><p> 物理成績(jī) 總分\n");</p><p> printf("%d\t%s\t %d %d %d \</p>
74、<p><b> %d %d\n",</b></p><p> p->num,p->name,p->score[0],p->score[1],p->score[2],</p><p> p->score[3],p->sum);</p><p> printf("\n
75、\n請(qǐng)輸入您還要查詢的學(xué)生的姓名,輸入0表\</p><p> 示不按姓名查詢了:");</p><p> scanf("%s",tem);</p><p><b> }</b></p><p><b> }</b></p><p>&l
76、t;b> } </b></p><p> else if (choose==0) {printf("\n您選擇了不查詢!\n");break;}</p><p> else {printf("\n您以其他方式選擇了不查詢!\n");break;}</p><p><b> }</b&g
77、t;</p><p><b> }</b></p><p> Student *add_new(Student *head)</p><p><b> {</b></p><p> Student *p;</p><p> int flag; </p>
78、<p> printf("\n\n請(qǐng)輸入您要新加入學(xué)生的學(xué)號(hào),學(xué)號(hào)為0表示結(jié)束輸入:"); </p><p> scanf("%d",&flag);</p><p> while(getchar()!='\n');</p><p> for(;flag;)</p>&l
79、t;p><b> {</b></p><p> p=(Student *)malloc(LEN);</p><p> p->num=flag;</p><p> printf("請(qǐng)輸入新加入學(xué)生的姓名:",n);</p><p> scanf("%s",p-&
80、gt;name); </p><p> printf("請(qǐng)輸入新加入學(xué)生的高數(shù)成績(jī):",n);</p><p> scanf("%d",&p->score[0]);</p><p> printf("請(qǐng)輸入新加入學(xué)生的英語(yǔ)成績(jī):",n);</p><p> sc
81、anf("%d",&p->score[1]);</p><p> printf("請(qǐng)輸入新加入學(xué)生的計(jì)算機(jī)成績(jī):",n);</p><p> scanf("%d",&p->score[2]);</p><p> printf("請(qǐng)輸入第%d名學(xué)生的物理成績(jī):&qu
82、ot;,n);</p><p> scanf("%d",&p->score[3]);</p><p> p->sum=p->score[0]+p->score[1]+p->score[2]+p->score[3];</p><p> p->next=head->next;</p&
83、gt;<p> head->next=p;</p><p><b> n++;</b></p><p> printf("\n請(qǐng)輸入還要加入學(xué)生的學(xué)號(hào),沒(méi)有此學(xué)生則輸入0表示結(jié)束:"); </p><p> scanf("%d",&flag);</p>&
84、lt;p><b> }</b></p><p> head=sort_1(head,1);</p><p> printf("加入后的成績(jī)表為:\n");</p><p> print(head); </p><p> return head;</p><p>
85、<b> }</b></p><p> void print(Student *head)</p><p><b> {</b></p><p> Student *p=head->next;</p><p> if (!p) {printf("\n\n此系統(tǒng)目前沒(méi)有任何學(xué)
86、生數(shù)據(jù)!\n\n\n");return;}</p><p> printf("此系統(tǒng)目前共計(jì)學(xué)生%d名:\n",n); </p><p> printf("**************************學(xué)生成績(jī)總匯************************\</p><p> *****\n");&
87、lt;/p><p> printf("學(xué)號(hào)\t姓名\t高數(shù)成績(jī) 英語(yǔ)成績(jī) 計(jì)算機(jī)成績(jī) 物理成績(jī) 總分\n");</p><p> for(;p;p=p->next)</p><p> printf("%d\t%s\t %d %d %d %d %d\n",</p><p> p->num,
88、p->name,</p><p> p->score[0],p->score[1],p->score[2],p->score[3],</p><p> p->sum=p->score[0]+p->score[1]+p->score[2]+p->score[3]); </p><p> printf(&
89、quot;************************ ^-^ *************************\</p><p><b> *\n\n");</b></p><p><b> }</b></p><p> int main()</p><p><b>
90、; {</b></p><p> Student *head;</p><p> int choose,i;</p><p> head=(Student *)malloc(LEN);</p><p> head->next=NULL; </p><p><b> for(;;)
91、</b></p><p><b> {</b></p><p> printf("\n\t\t* * * * * 學(xué)生成績(jī)管理系統(tǒng) * * * *\n");</p><p> printf("\t\t*\t1.學(xué)生數(shù)據(jù)鍵盤錄入\t *\n");</p><p>
92、 printf("\t\t*\t2.學(xué)生數(shù)據(jù)統(tǒng)計(jì)排序\t *\n");</p><p> printf("\t\t*\t3.查詢學(xué)生數(shù)據(jù)\t\t *\n");</p><p> printf("\t\t*\t4.插入學(xué)生數(shù)據(jù)\t\t *\n");</p><p> printf("\t\t*
93、\t5.顯示當(dāng)前成績(jī)表\t *\n");</p><p> printf("\t\t*\t0.退出成績(jī)管理系統(tǒng)\t *\n");</p><p> printf("\t\t* * * * * * * * ^-^ * * * * * * * \n\n"); </p><p> printf("\n請(qǐng)輸
94、入你要執(zhí)行的操作:");</p><p> scanf("%d",&choose);</p><p> while(getchar()!='\n');</p><p> switch(choose)</p><p><b> {</b></p>
95、<p> case 1:printf("\n\t\t\t\t****注意****"); </p><p> printf("\n\n 此選項(xiàng)將會(huì)建立新的學(xué)生數(shù)據(jù)系統(tǒng) ,原來(lái)的數(shù)據(jù)將\</p><p> 不再存在,你確信要?jiǎng)h除原來(lái)的數(shù)據(jù)并建立新的數(shù)據(jù)系統(tǒng)么?\n\n");</p><p> printf(&qu
96、ot;1、建立新的數(shù)據(jù)系統(tǒng);0、放棄建立新的數(shù)據(jù)系統(tǒng)。\n\n");</p><p> printf("請(qǐng)選擇:");</p><p> scanf("%d",&i);</p><p> if (i==1) {head=cin();print(head);break;}</p><p
97、> else if (i==0) </p><p><b> {</b></p><p> printf("\n您選擇了放棄建立新的數(shù)據(jù)系統(tǒng)!\n");</p><p><b> break;</b></p><p><b> }</b>&l
98、t;/p><p><b> else {</b></p><p> printf("\您做出了別的選擇,當(dāng)作放棄建立!\n");</p><p><b> break;</b></p><p><b> } </b></p><p&g
99、t; case 2:head=sort_all(head);break;</p><p> case 3:find(head);break;</p><p> case 4:head=add_new(head);</p><p> case 5:print(head);break;</p><p> case 0:system(&q
100、uot;pause");return 0;</p><p> default: printf("\n\n您的輸入有誤!請(qǐng)重新輸入:\n\n");break; </p><p><b> }</b></p><p><b> }</b></p><p><b&
101、gt; }</b></p><p> 7.2.2主要程序運(yùn)行結(jié)果</p><p> (1)運(yùn)行開始,如圖。</p><p> (2)輸入數(shù)字1,然后按Enter鍵,如圖。</p><p> ?。?)輸入數(shù)字1,然后按下Enter鍵,就可以輸入考生數(shù)據(jù),如圖。</p><p> ?。?)輸入數(shù)字鍵2,
102、然后按下Enter鍵,即可得到學(xué)生成績(jī)的排序,如圖。</p><p> ?。?)輸入數(shù)字鍵0,按下Enter鍵,最后按任意鍵即可退出系統(tǒng)了,如圖。</p><p><b> 八 總結(jié)</b></p><p> 由于本課題中的許多知識(shí)點(diǎn)都沒(méi)有學(xué)過(guò)都要靠自己到課外的資料中去查找。在用的時(shí)候難免出現(xiàn)這樣那樣的錯(cuò)誤。如開始設(shè)計(jì)出來(lái)的菜單不是預(yù)想的
103、那樣,而是總個(gè)窗中出現(xiàn)混亂。解決的這個(gè)問(wèn)題的辦法是調(diào)整。一個(gè)系統(tǒng)的菜單和提示信息非常重要。如果沒(méi)有這些用戶根本不知道怎么用你設(shè)計(jì)的這個(gè)系統(tǒng)。在設(shè)計(jì)的調(diào)試過(guò)程中也無(wú)法順利的完成調(diào)試工作。有了一個(gè)清晰簡(jiǎn)單的菜單和一些提示信息這后,調(diào)試過(guò)程完成的非常順利。</p><p> 回顧起此次課程設(shè)計(jì),我感慨頗多,的確,從拿到題目到完成整個(gè)編程,從理論到實(shí)踐,在整整兩個(gè)禮拜的日子里,可以學(xué)到很多很多的東西,同時(shí)不僅可以鞏固了
104、以前所學(xué)過(guò)的知識(shí),而且學(xué)到了很多在書本上所沒(méi)有學(xué)到過(guò)的知識(shí)。通過(guò)這次課程設(shè)計(jì)使我們懂得了理論與實(shí)際相結(jié)合是很重要的,只有理論知識(shí)是遠(yuǎn)遠(yuǎn)不夠的,只有把所學(xué)的理論知識(shí)與實(shí)踐相結(jié)合起來(lái),從理論中得出結(jié)論,才能真正為社會(huì)服務(wù),從而提高自己的實(shí)際動(dòng)手能力和獨(dú)立思考的能力。在設(shè)計(jì)的過(guò)程中遇到問(wèn)題,可以說(shuō)得是困難重重,這畢竟第一次做的,難免會(huì)遇到過(guò)各種各樣的問(wèn)題,同時(shí)在設(shè)計(jì)的過(guò)程中發(fā)現(xiàn)了自己的不足之處,對(duì)以前所學(xué)過(guò)的知識(shí)理解得不夠深刻,掌握得不夠牢固
105、,比如說(shuō)結(jié)構(gòu)體……通過(guò)這次課程設(shè)計(jì)之后,一定把以前所學(xué)過(guò)的知識(shí)熟悉了,本次課程設(shè)計(jì)結(jié)束了,我們通過(guò)這次實(shí)踐學(xué)到了許多知識(shí)。學(xué)到了設(shè)計(jì)一個(gè)簡(jiǎn)單的系統(tǒng)。要注意哪些方面。也使我們知道自己哪些方面做得還不夠。這不僅是程序設(shè)計(jì),更是鍛煉我們處理問(wèn)題的能力,同時(shí)也使我們了解到團(tuán)隊(duì)合作的可貴.編寫程序是件細(xì)心活,稍不留神就會(huì)出錯(cuò),這就必須要求我們對(duì)待事情要認(rèn)真!在編寫程序的過(guò)程中,錯(cuò)誤不斷出現(xiàn),不同的類型(如少寫了一個(gè)符號(hào),寫</p>
106、<p> 但我們總結(jié)出了一點(diǎn)點(diǎn)的經(jīng)驗(yàn)如下:</p><p> 1、要對(duì)系統(tǒng)的功能和要求做出詳細(xì)的分析,并合理分解任務(wù)。</p><p> 2、把分解出來(lái)的子任務(wù),做給一個(gè)相對(duì)獨(dú)立的模塊。</p><p> 3、在設(shè)計(jì)一個(gè)模塊之前,要簡(jiǎn)單構(gòu)想一下總界面的顯視情況。</p><p> 4、針對(duì)構(gòu)想出來(lái)的界面進(jìn)行程序的編寫。&l
107、t;/p><p><b> 九 參考資料</b></p><p> [1]譚浩強(qiáng). C程序設(shè)計(jì)(第三版) . 北京:清華大學(xué)出版社, 2005 </p><p> [2]譚浩強(qiáng). C程序設(shè)計(jì)題解與上機(jī)指導(dǎo)(第三版) . 北京:清華大學(xué)出版社, 2005</p><p> [3]李春葆,張植民,肖忠付.C語(yǔ)言設(shè)計(jì)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- c語(yǔ)言課程設(shè)計(jì)學(xué)生成績(jī)管理系統(tǒng) (2)
- c語(yǔ)言課程設(shè)計(jì)----學(xué)生成績(jī)管理系統(tǒng) (2)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng) (2)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng) (2)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)---學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)-學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)----學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)-學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)-學(xué)生成績(jī)管理系統(tǒng)
- 學(xué)生成績(jī)管理系統(tǒng)--c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)---學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)-學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)———學(xué)生成績(jī)管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)學(xué)生成績(jī)管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論