九九热最新网址,777奇米四色米奇影院在线播放,国产精品18久久久久久久久久,中文有码视频,亚洲一区在线免费观看,国产91精品在线,婷婷丁香六月天

C 語言課程設計 學生選課系統(tǒng)

上傳人:仙*** 文檔編號:86475192 上傳時間:2022-05-07 格式:DOC 頁數(shù):30 大?。?77KB
收藏 版權(quán)申訴 舉報 下載
C 語言課程設計 學生選課系統(tǒng)_第1頁
第1頁 / 共30頁
C 語言課程設計 學生選課系統(tǒng)_第2頁
第2頁 / 共30頁
C 語言課程設計 學生選課系統(tǒng)_第3頁
第3頁 / 共30頁

下載文檔到電腦,查找使用更方便

10 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《C 語言課程設計 學生選課系統(tǒng)》由會員分享,可在線閱讀,更多相關《C 語言課程設計 學生選課系統(tǒng)(30頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、word*實踐教學* 理工大學計算機與通信學院2011年春季學期 C程序設計 課程設計題 目:學生選課系統(tǒng) 專業(yè)班級:姓 名:學 號:指導教師:成 績:27 / 30摘 要 學生選課系統(tǒng)是一個教育單位不可缺少的重要系統(tǒng)組成局部,它對于學校的決策者、管理者管理、查看課程來說都有至關重要,所以學生選課管理系統(tǒng)應該能夠為廣闊學、師生提供充足的信息和快捷的課程選擇過程,有助于學生選好每一門課程,此系統(tǒng)系統(tǒng)選課方便、快捷,用簡單的界面來展示學生的選課信息,應用簡單明了、存儲量大、可靠性高、性好、壽命長、本錢低等優(yōu)點,可以極大的提高對學生信息管理的效率。利用C語言開發(fā),實現(xiàn)了簡單的學生課程信息的錄入、修改

2、、查詢、刪除等操作,并且能夠利用文件系統(tǒng)長久的保存原始數(shù)據(jù)。目 錄一、需求分析1二、總體設計1三、詳細設計21、數(shù)據(jù)定義32、算法流程圖3四、編碼6五、調(diào)試7六、設計總結(jié)10致11參考文獻12附錄13一、需求分析語言文字描述系統(tǒng)要做什么數(shù)據(jù)結(jié)構(gòu)可用結(jié)構(gòu)體,包括課程和選修兩個結(jié)構(gòu)體,其中課程結(jié)構(gòu)體成員結(jié)構(gòu)體成員包括課程編號,課程名稱,課程性質(zhì),總學時,授課學時,實驗或上機學時,學分,開課學期。選修結(jié)構(gòu)體成員包括學號,課程編號,該結(jié)構(gòu)體的建立主要是為了查詢某門課程學生選修情況。二、總體設計系統(tǒng)由哪幾個功能模塊構(gòu)成,給出功能模塊圖。C中模塊化的工具是函數(shù)根據(jù)上面的需求分析,可以將這個系統(tǒng)的設計分為如

3、下七大模塊:選課模塊、按學分查找模塊、按編號查找模塊、查看課程模塊、查看選課情況模塊、課程輸入模塊、完成選擇模塊。菜單項選擇擇模塊學生選課錄入課程信息課程管理學生信息管 理系統(tǒng)信息查看與儲存退出系統(tǒng)錄入學生信息完成選擇模塊三、詳細設計1根據(jù)n的值調(diào)用各功能模塊函數(shù)輸入n,判斷n是否是1-7顯示一系列功能選項.數(shù)據(jù)定義2,算法流程圖1錄入課程信息表錄入課程信息顯示錄入成功,轉(zhuǎn)入完成選擇菜單輸入課程編號從文件輸入新 增 課 程2課程管理輸入課程 信息 Y顯示失敗保 存3錄入課程信息錄入課程信息輸 入 數(shù) 據(jù)Y 保 存4學生信息管理新增學生信息或刪除學生信息輸入某某,考號.YY保 存5學生選課學 生

4、 選 課查詢可選課 程查詢已選課 程返回主菜 單輸 入 學 號輸 入 學 號6系統(tǒng)信息與查看系統(tǒng)主菜單系統(tǒng)信息與查看系統(tǒng)查看課程信息查看學生信息存儲信息返回主菜單存儲課程信息存儲學生信息返回主菜單輸 入 路 徑,保存完成選擇菜單模塊7退出系統(tǒng)退出系統(tǒng)四、編碼1.struct couse * head1;結(jié)構(gòu)2.void keyboardc()/錄入課程子函數(shù)(從鍵盤錄入)3.void filec()/錄入鍵盤子函數(shù)(從文件錄入)4.void inputc()/錄入課程主函數(shù)5.void insertc(struct couse *incouse)/課程管理子函數(shù)(增加課程)6.void del

5、c(int num1)/課程管理子函數(shù)(刪除課程)7.void elect(struct student * s)/選課8.void cheak()/學生選課子函數(shù)(查詢可選課程)9.void back(struct student * p)/退課10.void hcheak()/學生選課子函數(shù)查詢已選課程)11.void elective()/學生選課主函數(shù)12.void listc()/輸出課程信息13.void lists()/輸出學生信息14.void intoc()/存儲課程信息15.void intos()/存儲學生信息16.void into()/存儲信息17.void stor

6、e()/信息主函數(shù)18.int main()/主函數(shù)五、測試1主菜單2錄入課程信息3,從文件輸入4,學生選課菜單 5,學生信息管理 6,管理員輸入課程信息界面:六、設計總結(jié)問題一:無法讀取文txt文件。困難就是txt 無法讀取,輸入路徑后沒有文件顯示。解決方法是,向教師求助。最后,在教師細心的指導下,才知道是自己的計算機操作水平緣故,沒有很好的了解計算機路徑結(jié)構(gòu),最后做出了一定的修改,才得以實現(xiàn)。問題二:程序錯誤。這是一個比擬典型的錯誤,通過查閱書本相關資料。才覺察是函數(shù)相關問題,沒有能夠很好的理解函數(shù)思想,導致程序運行錯誤。致在這次c語言課程設計中,首先得感周教師給予我們指導與幫助,在她的指

7、導幫助下,才使得我們能夠順利的完成課程設計,更重要的是在這次課程設計中,極大的提高我的c語言設計能力,也讓我深刻的了解到自己在這方面的諸多不足,使得我能更清楚的了解自己的水平,加強了我對這門學科的認識。同時也感和我一起完成這課設的王云龍同學,我們在互相交流幫助中也相互學習到許多小的應用技巧,解決了一些列問題。還要感那些給予我們幫助的同學,也給了我很大的幫助。參考文獻1靈芝,余健. C語言課程設計案例精編.:清華大學,20082王新,雷. C語言課程設計.:清華大學,20093游洪躍、駿、譚斌.C語言程序設計實驗與課程設計教程.:清華大學,20114王連相.C/C+程序設計上機指導與測試. :中

8、國鐵道,20065C語言函數(shù)手冊,機械工業(yè),1999附錄#include #includeint N1,N2,kk1,kk2,kk3;struct couse * head1;struct student * head2;struct couse/課程信息結(jié)構(gòu)體 int num1;/課程編號char name120;/課程名稱char xinzhi30;/課程性質(zhì)iint ztime;/課程總學時int stime;/授課學時int shiyan;/實驗學時int score;/學分long int date;/開學學期 int nelepeo;/課程已選人數(shù) int Melepeo;/課程人

9、數(shù)上限 struct couse * next;struct student/學生信息結(jié)構(gòu)體 int num2; char name220; int nelenum50;/已選課程編號 int nelen;/已選課程數(shù)量 struct student * next;void Ms() for(kk1=0;kk11100;kk1+) for(kk2=0;kk21200;kk2+) for(kk3=0;kk3num1,p1-name1,&p1-xinzhi,&p1-ztime,&p1-stime,&p1-shiyan,&p1-score,&p1-date,&p1-Melepeo); p1-nele

10、peo=0; head1=NULL; while(p1-num1!=0) N1=N1+1; if(N1=1)head1=p1; else p2-next=p1; p2=p1; p1=(struct couse * )malloc(sizeof(struct couse); scanf(%d%s%s%d%d%d%d%d,&p1-num1,p1-name1,&p1-xinzhi,&p1-ztime,&p1-stime,&p1-shiyan,&p1-score,&p1-date,&p1-Melepeo); p1-nelepeo=0; p2-next=NULL;void filec()/錄入鍵盤子函數(shù)

11、(從文件錄入) FILE * fp; char filepath20; struct couse *p1,*p2; N1=0; printf(輸入要讀入的文件路徑:); getchar(); gets(filepath); if(fp=fopen(filepath,r)=NULL) printf(找不到%s文件!n,filepath); exit(0); p1=p2=(struct couse*)malloc(sizeof(struct couse); fscanf(fp,%d%s%s%d%d%d%d%d,&p1-num1,&p1-name1,&p1-xinzhi,&p1-ztime,&p1-

12、stime,&p1-shiyan,&p1-score,&p1-date,&p1-Melepeo); printf(課程編號 課程名稱 課程性質(zhì) 總學時 授課學時 實驗學時 學分 開課學期 人數(shù)上限n);fprintf(stdout,%dt %st%st %dt%dt%dt%dt%dt%dn,p1-num1,p1-name1,p1-xinzhi,p1-ztime,p1-stime,p1-shiyan,p1-score,p1-date,p1-Melepeo); head1=NULL; while(!feof(fp) N1=N1+1; if(N1=1)head1=p1; else p2-next=p

13、1; p2=p1; p1=(struct couse * )malloc(sizeof(struct couse); fscanf(fp,%d%s%s%d%d%d%d%d,&p1-num1,p1-name1,&p1-xinzhi,&p1-ztime,&p1-stime,&p1-shiyan,&p1-score,&p1-date,&p1-Melepeo);fprintf(stdout,%d %s %s %d %d %d %d %d %dn,p1-num1,p1-name1,p1-xinzhi,p1-ztime,p1-stime,p1-shiyan,p1-score,p1-date,p1-Mele

14、peo); p2-next=NULL;void inputc()/錄入課程主函數(shù) int i; printf(ttt錄入課程信息n); printf(n1.從鍵盤錄入n); printf(2.從文件錄入n); printf(3.返回主菜單n); printf(請選擇(13):n); scanf(%d,&i); switch(i) case(1):keyboardc();break; case(2):filec();break; case(3):break; void insertc(struct couse *incouse)/課程管理子函數(shù)(增加課程) struct couse *p0,*p

15、1,*p2; p1=head1; p0=incouse; if(head1=NULL) head1=p0; p0-next=NULL; else while(p0-num1 p1-num1) & (p1-next!=NULL) p2=p1; p1=p1-next; if(p0-num1 num1) if(head1=p1) head1=p0; else p2-next=p0; p0-next=p1; else p1-next=p0; p0-next=NULL; N1=N1+1;void delc(int num1)/課程管理子函數(shù)(刪除課程) struct couse *p1,*p2; if(

16、head1=NULL) printf(n沒有課程,無法刪除!n); goto end; p1=head1; while(num1!=p1-num1 & p1-next!=NULL) p2=p1; p1=p1-next; if(num1=p1-num1) if(p1=head1) head1=p1-next; else p2-next=p1-next; printf(已刪除該編號課程!n); N1=N1-1; else printf(無該編號的課程!n); end:;void managementc()/課程管理主函數(shù) struct couse * incouse; int i,num1; pr

17、intf(ttt課程管理n); printf(1.新增課程n); printf(2.刪除課程n); printf(3.返回主菜單n); printf(請選擇(13):n); scanf(%d,&i); switch(i) case(1): incouse=(struct couse *)malloc(sizeof(struct couse); printf(課程編號 課程名稱 課程性質(zhì) 總學時 授課學時 實驗學時 學分 開課學期 人數(shù)上限n); scanf(%dn%sn%sn%dn%dn%dn%dn%dn%dn,&incouse-num1,&incouse-name1,&incouse-xin

18、zhi,&incouse-ztime,&incouse-stime,&incouse-score,&incouse-date,&incouse-Melepeo); incouse-nelepeo=0; insertc(incouse); break; case(2): printf(請輸入要刪除課程的編號:n); scanf(%d,&num1); delc(num1); break; case(3):break; void keyboards()/錄入學生信息子函數(shù)從鍵盤錄入 int i; struct student *p1,*p2; N2=0; p1=p2=(struct student

19、*)malloc(sizeof(struct student); printf(學生學號t學生n); scanf(%d%s,&p1-num2,p1-name2); p1-nelen=0; for(i=0;inelenumi=0; head2=NULL; while(p1-num2!=0) N2=N2+1; if(N2=1)head2=p1; else p2-next=p1; p2=p1; p1=(struct student * )malloc(sizeof(struct student); scanf(%d%s,&p1-num2,p1-name2); p1-nelen=0; for(i=0;

20、inelenumi=0; p2-next=NULL;void files()/錄入學生信息子函數(shù)從文件錄入 int i=0; FILE * fp; char filepath20; struct student *p1,*p2; N2=0; printf(輸入要讀入的文件路徑:); getchar(); gets(filepath); if(fp=fopen(filepath,r)=NULL) printf(找不到%s文件!n,filepath); exit(0); p1=p2=(struct student*)malloc(sizeof(struct student); fread(p1,s

21、izeof(struct student),1,fp); head2=NULL; while(!feof(fp) i=0; N2=N2+1; if(N2=1)head2=p1; else p2-next=p1; p2=p1; p1=(struct student * )malloc(sizeof(struct student); fread(p1,sizeof(struct student),1,fp); p2-next=NULL;void inputs()/錄入學生信息主函數(shù) int i; printf(ttt錄入學生信息n); printf(n1.從鍵盤錄入n); printf(2.從文件

22、錄入n); printf(3.返回主菜單n); printf(請選擇(13):n); scanf(%d,&i); switch(i) case(1):keyboards();break; case(2):files();break; case(3):break; void inserts(struct student * incouse)/學生信息管理子函數(shù)(填加學生信息) struct student *p0,*p1,*p2; p1=head2; p0=incouse; if(head2=NULL) head2=p0; p0-next=NULL; else while(p0-num2 p1-

23、num2) & (p1-next!=NULL) p2=p1; p1=p1-next; if(p0-num2 num2) if(head2=p1) head2=p0; else p2-next=p0; p0-next=p1; else p1-next=p0; p0-next=NULL; N2=N2+1;void dels(int num2)/學生信息管理子函數(shù)刪除學生信息) struct student *p1,*p2; if(head2=NULL) printf(n沒有該學生信息,無法刪除!n); goto end; p1=head2; while(num2!=p1-num2 & p1-nex

24、t!=NULL) p2=p1; p1=p1-next; if(num2=p1-num2) if(p1=head2) head2=p1-next; else p2-next=p1-next; printf(已刪除該學生信息!n); N2=N2-1; else printf(無該學號的學生!n); end:;void managements()/學生信息管理主函數(shù) struct student * incouse; int i,num2; printf(ttt學生信息管理n); printf(1.新增學生信息n); printf(2.刪除學生信息n); printf(3.返回主菜單n); prin

25、tf(請選擇(13):n); scanf(%d,&i); switch(i) case(1): incouse=(struct student *)malloc(sizeof(struct student); incouse-nelen=0; incouse-nelenum0=0; printf(學生學號t學生n); scanf(%d%s,&incouse-num2,incouse-name2); inserts(incouse); break; case(2): printf(請輸入要刪除學生的學號:n); scanf(%d,&num2); dels(num2); break; case(3

26、):break; void elect(struct student * s)/選課 struct couse * p; int num1,i; printf(請輸入要選課的編號:n); scanf(%d,&num1); for(i=0;s-nelenumi!=0;i+); s-nelenumi=num1; (s-nelen)+; p=head1; while(p-num1!=num1) p=p-next; (p-nelepeo)+;void cheak()/學生選課子函數(shù)(查詢可選課程) char e; struct couse * c; struct student * s; int nu

27、m2,i,j=0,t=0; printf(請輸入你的學號:); scanf(%d,&num2); s=head2; while(s-num2!=num2 & s-next!=NULL) s=s-next; if(s-num2!=num2) printf(不存在你的信息,請進入主菜單錄入你的信息!n); goto end; c=head1; printf(你的可選課程編號:n); while(c!=NULL) for(t=0,i=0;s-nelenumi!=0;i+) if(c-num1=s-nelenumi) t=1; if(t=0 & (c-nelepeo!=c-Melepeo) print

28、f(%dn,c-num1); j+; c=c-next; if(j=0) printf(你已選完所有課程,無法再多項選擇!n); goto end; printf(選課(y/n)?:n); getchar(); e=getchar(); i=0; while(e=y) elect(s); printf(繼續(xù)選課(y/n)?:n); getchar(); e=getchar(); end:;void back(struct student * p)/退課 struct couse * p1; int num1,i,j; printf(請輸入你要退掉的課程編號:n); scanf(%d,&num1

29、); p1=head1; while(p1-num1!=num1) p1=p1-next; for(i=0;p-nelenumi!=num1;i+); for(j=i;p-nelenumj!=0;j+) p-nelenumj=p-nelenumj+1; p-nelenum-j=0; (p1-nelepeo)-; printf(退課成功!n);void hcheak()/學生選課子函數(shù)查詢已選課程) char c; struct couse * p0; struct student * p; int num2,i,f=0; printf(請輸入學號:n); scanf(%d,&num2); p=

30、head2; while(p-num2!=num2 & p!=NULL) p=p-next; if(p=NULL) printf(不存在你的信息,請回主菜單錄入信息:n); goto end; printf(已選課程編號:n); if(p-nelenum0=0) printf(你還沒選課!n); goto end; for(i=0;p-nelenumi!=0;i+) printf(%dn,p-nelenumi); p0=head1; while(p0-num1!=p-nelenumi) p0=p0-next; f=f+p0-score; printf(總學分:%dn,f); printf(是否

31、進展退課(y/n)?); getchar(); c=getchar(); while(c=y) back(p); printf(繼續(xù)退課(y/n)?); getchar(); c=getchar(); (p-nelen)-; end:;void elective()/學生選課主函數(shù) int i; printf(ttt學生選課n); printf(1.查詢可選課程n); printf(2.查詢已選課程n); printf(3.返回主菜單n); printf(請輸入(13):n); scanf(%d,&i); switch(i) case(1):cheak();break; case(2):hch

32、eak();break; case(3):break; void listc()/輸出課程信息 struct couse * p; p=head1; printf(課程編號 名稱 性質(zhì) 總學時 授課學時 實驗學時 學分 開課學期 已選人數(shù) 人數(shù)上限n); while(p!=NULL) printf(%d %s %s %d %d %d %d %d %d %dn,p-num1,p-name1,p-xinzhi,p-ztime,p-stime,p-shiyan,p-score,p-date,p-nelepeo,p-Melepeo); p=p-next; void lists()/輸出學生信息 str

33、uct student * p; p=head2; printf(學生學號 學生 已選課程數(shù)量n); while(p!=NULL) printf(%-4d %10s %6dn,p-num2,p-name2,p-nelen); p=p-next; void intoc()/存儲課程信息 FILE * fp; struct couse * p; char filepath30; printf(輸入課程信息要保存的文件路徑:); getchar(); gets(filepath); if(fp=fopen(filepath,w)=NULL) printf(n保存失敗!); exit(0); p=he

34、ad1; while(p!=NULL) fprintf(fp,%d %s %s %d %d %d %d %d %d %dn,p-num1,p-name1,p-xinzhi,p-ztime,p-stime,p-shiyan,p-score,p-date,p-nelepeo,p-Melepeo); p=p-next; fclose(fp); printf(課程信息已保存在%s中!n,filepath); void intos()/存儲學生信息 FILE * fp; struct student * p; char filepath30; printf(輸入學生信息要保存的文件路徑:); getch

35、ar(); gets(filepath); if(fp=fopen(filepath,w)=NULL) printf(n保存失敗!); exit(0); p=head2; while(p!=NULL) fwrite(p,sizeof(struct student),1,fp); p=p-next; fclose(fp); printf(學生信息已保存在%s中!n,filepath); void into()/存儲信息 int i; printf(1.存儲課程信息n); printf(2.存儲學生信息n); printf(3.返回主菜單n); printf(請輸入(13)n); scanf(%d

36、,&i); switch(i) case(1):intoc();break; case(2):intos();break; case(3):break; void store()/信息主函數(shù) int i; printf(tt系統(tǒng)信息查看與存儲n); printf(1.查看課程信息n); printf(2.查看學生信息n); printf(3.存儲信息n); printf(4.返回主菜單n); printf(請輸入(14):n); scanf(%d,&i); switch(i) case(1):listc();break; case(2):lists();break; case(3):into(

37、);break; case(4):break; int main()/主函數(shù) int i; start: printf(nttt歡迎使用學生選課系統(tǒng)!n); printf(菜單:n); printf(1.錄入課程信息n); printf(2.課程管理n); printf(3.錄入學生信息n); printf(4.學生信息管理n); printf(5.學生選課n); printf(6.系統(tǒng)信息查看與存儲n); printf(7.退出系統(tǒng)n); printf(n請輸入菜單項選擇項(17):n); scanf(%d,&i); if(i7) printf(輸入錯誤,請重輸:n); goto start

38、; switch(i) case(1): system(cls); inputc(); goto start; break; case(2): system(cls); managementc(); goto start; break; case(3): system(cls); inputs(); goto start; break; case(4): system(cls); managements(); goto start; break; case(5): system(cls); elective(); goto start; break; case(6): system(cls); store(); goto start; break; case(7): system(cls); printf(感使用本系統(tǒng)!nn再見!n); return(0);

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

相關資源

更多
正為您匹配相似的精品文檔
關于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!