版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 1 概述</b></p><p> 1.1 課程設計背景</p><p> 隨著學生人數(shù)的不斷增加,需要設計一個簡單的學生成績管理系統(tǒng),以便于管理者方便的對學生成績進行管理,管理者可依據(jù)實際需求進行相關操作。</p><p> 1.2 課程設計目標</p><p> 對學生成績進行合
2、理的管理??梢罁?jù)學號以及姓名進行相關的操作。</p><p><b> 2 系統(tǒng)分析</b></p><p><b> 2.1 系統(tǒng)需求</b></p><p> ?。?)該學生成績管理系統(tǒng)要求有學生成績錄入,查詢,修改,刪除,保存文件。</p><p> (2)系統(tǒng)使用文字菜單,用戶通過選擇
3、菜單項的編號,實現(xiàn)系統(tǒng)對子模塊的調(diào)用.也可用windows界面下的菜單欄、彈出式菜單、下拉菜單。</p><p> ?。?)每個班級每門課程的成績可以從學生的成績總表提取出子表并存儲成一個文本文件,以便在windows的notebook或者Microsoft word下打印,規(guī)定該文本文件名由班級號和課程名拼音字符串構成.輸入班級號和課程名字符串后自動生成文件名.如1班,語文,則文件名為:c1yuwen.txt。
4、 </p><p> ?。?)每個學生學習的課程有語文,英語,數(shù)學,物理,化學,生物。</p><p> (5)學生的成績總表結構約定為(學號,姓名,課程名,平時成績,期末成績,總評成績).總評成績由程序自動計算,總評成績=平時成績﹡30%+期末成績﹡70%。</p><p> (6)學號是一個9位整數(shù)構成的字符串, 學號的編碼規(guī)則:入學年份+在讀年級+在讀班級
5、+班內(nèi)編號;入學年份用4位整數(shù)構成字符串,如2003年入學則表示為:“2003”;在讀年級用1位整數(shù)構成字符串,如正在1年級讀書則表示為:“1”;在讀班級用2位整數(shù)構成字符串,如正在1班讀書則表示為:“01”;班內(nèi)編號用2位整數(shù)構成字符串,如在班內(nèi)編號為23號則表示為:“23”。</p><p><b> 3 系統(tǒng)概要設計</b></p><p><b>
6、 3.1系統(tǒng)結構圖</b></p><p> 圖3-1 系統(tǒng)結構圖</p><p> 3.2 系統(tǒng)的功能劃分</p><p> 系統(tǒng)的功能分為對數(shù)據(jù)的輸入,查找,增添,刪除以及保存,過程如 2.1的系統(tǒng)需求。</p><p><b> 3.3系統(tǒng)運行過程</b></p><p&g
7、t; 學生成績錄入過程如圖3-2所示:</p><p> 圖3-2 學生成績錄入界面</p><p> 學生成績信息如圖3-3所示:</p><p> 圖3-3 學生成績界面</p><p> 學生成績修改過程如圖3-4所示:</p><p> 圖3-4 學生成績修改界面</p><p&
8、gt; 4 設計體會及今后的改進意見</p><p> 回顧起此次課程設計,至今我仍感慨頗多,的確,從從拿到題目到完成整個編程,從理論到實踐,在整整半個學期的日子里,可以學到很多很多的的東西,同時不僅可以鞏固了以前所學過的知識,而且學到了很多在書本上所沒有學到過的知識。通過這次課程設計使我懂得了理論與實際相結合是很重要的,只有理論知識是遠遠不夠的,只有把所學的理論知識與實踐相結合起來,從理論中得出結論,才能真
9、正為社會服務,從而提高自己的實際動手能力和獨立思考的能力。在設計的過程中遇到問題,可以說得是困難重重,這畢竟第一次做的,難免會遇到過各種各樣的問題,同時在設計的過程中發(fā)現(xiàn)了自己的不足之處,對以前所學過的知識理解得不夠深刻,掌握得不夠牢固,通過這次課程設計之后,一定把以前所學過的知識重新溫故。</p><p> 這次課程設計終于順利完成了,在設計中遇到了很多編程問題,最后在老師以及同學的辛勤指導下,終于游逆而解。
10、同時,在老師和同學的身上我學得到很多實用的知識。</p><p><b> 參 考 文 獻</b></p><p> [1]錢能.c++程序設計教程[M].清華大學出版社.1999.4.</p><p> [2]譚浩強.c++程序設計[M].清華大學出版社.2004.6.</p><p> [3]艾德才.c++程
11、序設計簡明教程[M].中國水利水電出版社.2000.6.</p><p><b> 附 錄</b></p><p> #include<iostream></p><p> #include<fstream></p><p> #include<string></p>
12、;<p> #include<ctime></p><p> #include<iomanip></p><p> #define NULL 0</p><p> using namespace std;</p><p> //定義全局變量n用來確定學生的人數(shù)</p><p&
13、gt;<b> int n;</b></p><p> //定義一個學生信息結構體</p><p> struct student </p><p><b> { </b></p><p> string num; //學生的學號用九位字符表示,為使用方便用strin
14、g類</p><p> char name[20]; </p><p> string subject[6];</p><p> float pingshi_score[6];</p><p> float qizhong_score[6];</p><p> student *next;</p>
15、;<p> }stud[100];</p><p><b> //各個模塊函數(shù)</b></p><p> void meun(int m); //菜單函數(shù) </p><p> student *creat() ; // 創(chuàng)建鏈表函數(shù)&
16、lt;/p><p> void print(student *head); // 輸出鏈表函數(shù) </p><p> void search(student *head); // 查找信息函數(shù)</p><p> void Insert(struct student *head); //插入信息函數(shù)</p><p
17、> student *del(student *head,string num) ;</p><p> void Correct(struct student *head) ; //修改信息函數(shù)</p><p> void Dele(student *head); // 刪除信息函數(shù)</p><p> //文件操作的兩個函數(shù)</p&g
18、t;<p> void save() ; //保存函數(shù) </p><p> void read(); //讀入函數(shù)</p><p><b> //菜單函數(shù)</b></p><p> void meun(int m)</p><p&
19、gt;<b> { </b></p><p> static student *head;</p><p><b> switch(m)</b></p><p><b> {</b></p><p> case 1: head=creat();print(head);
20、break;</p><p> case 2: read();break;</p><p> case 3: Insert(head);break;</p><p> case 4: search(head);break;</p><p> case 5: Correct(head);break;</p><p&g
21、t; case 6: Dele(head);break;</p><p> case 7: save();break;</p><p><b> }</b></p><p><b> }</b></p><p> void meun1()</p><p><b
22、> {</b></p><p><b> int m;</b></p><p><b> char c;</b></p><p><b> do</b></p><p><b> {</b></p><p&g
23、t; cout<<"**************************************************"<<endl;</p><p> cout<<" ***************菜單**************"<<endl;</p><p> cout<<
24、"***** 1輸入數(shù)據(jù) *****"<<endl;</p><p> cout<<"***** 2顯示數(shù)據(jù) ******"<<endl;</p><p> cout<<"***** 3插入信息
25、 ******"<<endl;</p><p> cout<<"***** 4查找信息 *****"<<endl;</p><p> cout<<"***** 5修改信息 *******"<<endl;</p
26、><p> cout<<"***** 6刪除信息 *******"<<endl;</p><p> cout<<"***** 7保存信息 ******"<<endl;</p><p> cout<<&q
27、uot;請輸入您想完成的操作:";</p><p><b> cin>>m;</b></p><p><b> meun(m);</b></p><p> cout<<"你要繼續(xù)操作嗎?(y/n):"<<endl;</p><p&g
28、t;<b> cin>>c;</b></p><p> system("cls");</p><p> }while(c=='y');</p><p> if(c=='n')</p><p> cout<<"謝謝使用,再見!&
29、quot;<<endl;</p><p><b> }</b></p><p><b> //主函數(shù)入口</b></p><p> int main()</p><p><b> {</b></p><p> system(&quo
30、t;cls");</p><p> time_t t; </p><p> time(&t); </p><p><b> //密碼設置</b></p><p> cout<<"*************歡迎進入學生管理系統(tǒng)**********\n"<<
31、;endl</p><p> << " 當前系統(tǒng)時間是: " << ctime(&t) << endl ;</p><p> cout<<"請輸入你的登錄密碼,只有四次機會!"<<endl; </p><p> string str
32、;int i=1;</p><p><b> cin>>str;</b></p><p> if(str=="123456")</p><p><b> {</b></p><p> cin.get();</p><p><b&g
33、t; meun1();</b></p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> for(i=1;i<=3;i++)</p><p>&l
34、t;b> {</b></p><p> cout<<i<<"次密碼錯誤,請重新輸入密碼!"<<endl;</p><p><b> cin>>str;</b></p><p><b> if(i==3)</b></p>
35、<p> cout<<"您無權使用本系統(tǒng)!"<<endl;</p><p><b> }</b></p><p><b> }</b></p><p><b> return 0;</b></p><p><
36、;b> }</b></p><p><b> //建立動態(tài)鏈表</b></p><p> student *creat() </p><p><b> { </b></p><p><b> int i;</b></p>&l
37、t;p> student *head,*p1,*p2;</p><p><b> n=0;</b></p><p> p1=p2=new student;</p><p> cout<<"輸入學生學號和成績(要結束學號輸入000000000):"<<endl;</p>&l
38、t;p> cout<<"請輸入第"<<n+1<<"個學生的信息:"<<endl;</p><p> cout<<"學號:";</p><p> cin>>p1->num;</p><p> cout<<&
39、quot;姓名:" ; </p><p> cin>>p1->name;</p><p> cout<<endl;</p><p> for(i=0;i<6;i++)</p><p><b> {</b></p><p> cout<
40、<"科目:";</p><p> cin>>p1->subject[i];</p><p> cout<<"平時成績:";</p><p> cin>>p1->pingshi_score[i];</p><p> cout<<&q
41、uot;期末成績:";</p><p> cin>>p1->qizhong_score[i];</p><p> cout<<endl;</p><p><b> }</b></p><p> head=NULL;</p><p> while(p
42、1->num!="000000000")</p><p><b> {</b></p><p><b> n=n+1;</b></p><p><b> if(n==1)</b></p><p><b> head=p1;</b
43、></p><p><b> else </b></p><p> p2->next=p1;</p><p><b> p2=p1;</b></p><p> p1=new student;</p><p> cout<<"請輸入第
44、"<<n+1<<"個學生的數(shù)據(jù):"<<endl;</p><p> cout<<"學號:";</p><p> cin>>p1->num;</p><p> if(p1->num == "000000000")</
45、p><p><b> {</b></p><p><b> break;</b></p><p><b> }</b></p><p> cout<<"姓名:"; </p><p> cin>>p1-&g
46、t;name;</p><p> for(i=0;i<6;i++)</p><p><b> {</b></p><p> cout<<"科目:";</p><p> cin>>p1->subject[i];</p><p> co
47、ut<<"平時成績:";</p><p> cin>>p1->pingshi_score[i];</p><p> cout<<"期末成績:";</p><p> cin>>p1->qizhong_score[i];</p><p>
48、cout<<endl;</p><p><b> }</b></p><p><b> }</b></p><p> p2->next=NULL;</p><p> return(head);</p><p><b> }</b&g
49、t;</p><p><b> // 鏈表的輸出</b></p><p> void print(student *head) </p><p><b> { </b></p><p> student *p;</p><p><b> p=hea
50、d;</b></p><p> int i,j=0;</p><p> if(head != NULL) </p><p><b> do</b></p><p><b> { </b></p><p> cout<<"學號 &q
51、uot;<<" 姓名 "<<endl;</p><p> cout<<endl;</p><p> cout<<p->num<<" ";</p><p> stud[j].num=p->num;</p><p>
52、 cout<<p->name<<" ";</p><p> strcpy(stud[j].name,p->name);</p><p> cout<<endl;</p><p> for(i=0;i<6;i++)</p><p> { cout&l
53、t;<" 科目 "<<" 平時成績 "<<" 期末成績"<<" 最終成績"<<endl;</p><p> cout<<p->subject[i]<<" "; stud[j].subject[i]=p->su
54、bject[i];</p><p> cout<<p->pingshi_score[i]<<" ";stud[j].pingshi_score[i]=p->pingshi_score[i];</p><p> cout<<p->qizhong_score[i]<<"
55、 "; stud[j].qizhong_score[i]=p->qizhong_score[i];</p><p> cout<<((p->pingshi_score[i])*0.3+(p->qizhong_score[i])*0.7)<<endl;</p><p><b> }</b></p>
56、<p><b> j++;</b></p><p> p=p->next;</p><p> cout<<setw(100)<<endl;</p><p> }while(p!=NULL);</p><p><b> save();</b></
57、p><p><b> }</b></p><p><b> //刪除結點</b></p><p> student *del(student *head,string num) </p><p><b> {</b></p><p>
58、student *p1,*p2;</p><p> if(head==NULL)</p><p><b> {</b></p><p> cout<<"空鏈表,無刪的對象"<<endl;meun1();</p><p><b> }</b><
59、/p><p> p1 = head;</p><p> while(num!=p1->num&&p1->next!=NULL)</p><p><b> {</b></p><p><b> p2 = p1;</b></p><p> p1=
60、p1->next;</p><p><b> }</b></p><p> if(num==p1->num)</p><p><b> {</b></p><p> if(p1==head)</p><p> head = p1->next;<
61、;/p><p><b> else </b></p><p> p2->next = p1->next;</p><p> n = n - 1;</p><p><b> }</b></p><p> else cout<<"查無此人&
62、quot;;</p><p> return(head);</p><p><b> }</b></p><p> //判斷是否能夠刪除信息</p><p> void Dele(student *head) </p><p><b> {</b&g
63、t;</p><p> string del_num;</p><p> print(head);</p><p> cout<<"請輸入你想刪除的學號:";</p><p> cin>>del_num;</p><p> while(del_num != &quo
64、t;000000000")</p><p><b> {</b></p><p> head = del(head,del_num);</p><p> print(head);</p><p> cout<<"請輸入你想刪除的學號:";</p><p
65、> cin>>del_num;</p><p><b> }</b></p><p><b> }</b></p><p><b> //查詢信息</b></p><p> void search(student *head) <
66、/p><p><b> {</b></p><p> print(head);</p><p> if(head==NULL)</p><p><b> {</b></p><p> cout<<"這是一個空鏈表,無查找項"<<
67、;endl;</p><p><b> meun1();</b></p><p><b> }</b></p><p><b> int i;</b></p><p> string num;</p><p> student *p1;<
68、/p><p> cout<<"請輸入你想查找的學生號:";</p><p><b> cin>>num;</b></p><p><b> p1=head;</b></p><p> while(p1->num!="000000000&
69、quot;)</p><p><b> {</b></p><p> if(p1->num==num)</p><p><b> { </b></p><p> cout<<p1->num<<" ";</p>
70、;<p> cout<<p1->name<<" ";</p><p> for(i=0;i<6;i++)</p><p><b> {</b></p><p> cout<<p1->subject[i]<<"
71、";</p><p> cout<<p1->pingshi_score[i]<<" ";</p><p> cout<<p1->qizhong_score[i]<<" ";</p><p> cout<<(p
72、1->pingshi_score[i])*0.3+(p1->qizhong_score[i])*0.7<<endl;</p><p><b> }</b></p><p><b> }break;</b></p><p> if(p1->num!=num&&p1->
73、next==NULL)</p><p> cout<<"沒有該學生的信息!";</p><p> else p1=p1->next;}</p><p><b> }</b></p><p><b> //插入結點</b></p><p
74、> struct student *insert(struct student *head,struct student *stud)</p><p><b> {</b></p><p> struct student *p0,*p1,*p2;</p><p> p1 = head;</p><p>
75、p0 = stud;</p><p> if(head == NULL)</p><p><b> {</b></p><p> head = p1;</p><p> p0->next=NULL;</p><p><b> }</b></p>
76、<p><b> else</b></p><p><b> {</b></p><p> while((p0->num != p1->num)&&(p1->next!=NULL))</p><p><b> {</b></p><
77、;p><b> p2=p1;</b></p><p> p1=p1->next;</p><p><b> }</b></p><p> if(p0->num<=p1->num)</p><p><b> {</b></p>
78、<p> if(head == p1)</p><p> head = p0;</p><p> else p2->next = p0;</p><p> p0->next = p1;</p><p><b> }</b></p><p><b> e
79、lse</b></p><p><b> {</b></p><p> p1->next = p0;</p><p> p0->next = NULL;</p><p><b> }</b></p><p><b> }</b
80、></p><p><b> n = n+1;</b></p><p> return(head);</p><p><b> }</b></p><p><b> //插入判斷</b></p><p> void Insert(stru
81、ct student *head)</p><p><b> {</b></p><p> struct student *stu;</p><p><b> int i;</b></p><p> cout<<"輸入你想插入的數(shù)據(jù):"<<endl
82、;</p><p> stu = new student ;</p><p> cout<<"學號:";</p><p> cin>>stu->num;</p><p> cout<<"姓名:";</p><p> cin>
83、;>stu->name;</p><p> for(i=0;i<6;i++)</p><p><b> {</b></p><p> cout<<"科目:";</p><p> cin>>stu->subject[i];</p>&
84、lt;p> cout<<"平時成績:";</p><p> cin>>stu->pingshi_score[i];</p><p> cout<<"期末成績:";</p><p> cin>>stu->qizhong_score[i];</p>
85、;<p> cout<<endl;</p><p><b> }</b></p><p> head = insert(head,stu);</p><p> print(head);</p><p> while(stu->num !="000000000"
86、)</p><p><b> {</b></p><p> cout<<"輸入你想插入的數(shù)據(jù):";</p><p> stu = new student ;</p><p> cout<<"學號:";</p><p> ci
87、n>>stu->num;</p><p> if(stu->num =="000000000")</p><p><b> {</b></p><p><b> break;</b></p><p><b> }</b><
88、;/p><p> cout<<"姓名:";</p><p> cin>>stu->name;</p><p> for(i=0;i<6;i++)</p><p><b> {</b></p><p> cout<<"
89、;科目:";</p><p> cin>>stu->subject[i];</p><p> cout<<"平時成績:";</p><p> cin>>stu->pingshi_score[i];</p><p> cout<<"期末成
90、績:";</p><p> cin>>stu->qizhong_score[i];</p><p> cout<<endl;</p><p><b> }</b></p><p> head = insert(head,stu);</p><p>
91、 print(head);</p><p><b> }</b></p><p><b> }</b></p><p><b> //修改信息</b></p><p> void Correct(struct student *head)</p><
92、p><b> {</b></p><p> struct student *stu;</p><p> string del_num;</p><p><b> int i;</b></p><p> print(head);</p><p> cout&l
93、t;<"請輸入你想修改的學號:";</p><p> cin>>del_num;</p><p> while(del_num != "000000000")</p><p><b> {</b></p><p> head = del(head,del_
94、num);</p><p> cout<<"請重輸入此學生的數(shù)據(jù):";</p><p> stu = new student ;</p><p> stu->num = del_num;</p><p> cout<<"姓名:";</p><p&
95、gt; cin>>stu->name;</p><p> for(i=0;i<6;i++)</p><p><b> {</b></p><p> cout<<"科目:";</p><p> cin>>stu->subject[i];&l
96、t;/p><p> cout<<"平時成績:";</p><p> cin>>stu->pingshi_score[i];</p><p> cout<<"期末成績:";</p><p> cin>>stu->qizhong_score[i
97、];</p><p> cout<<endl<<setw(10);</p><p><b> }</b></p><p> head = insert(head,stu);</p><p> print(head);</p><p> cout<<&
98、quot;請輸入你想修改的學號:";</p><p> cin>>del_num;</p><p><b> }</b></p><p><b> }</b></p><p><b> //信息保存</b></p><p>
99、 void save()</p><p><b> {</b></p><p> ofstream outfile("e:\\stud.txt",ios::out);</p><p><b> int i,j;</b></p><p> if(!outfile)<
100、/p><p><b> {</b></p><p> cerr<<"open error";</p><p><b> exit(1);</b></p><p><b> }</b></p><p> for(j=0
101、;j<n;j++)</p><p><b> {</b></p><p> outfile<<stud[j].num<<" ";</p><p> outfile<<stud[j].name<<" ";</p>&
102、lt;p> for(i=0;i<6;i++)</p><p><b> { </b></p><p> outfile<<stud[j].subject[i]<<" ";</p><p> outfile<<stud[j].pingshi_score[i]&
103、lt;<" ";</p><p> outfile<<stud[j].qizhong_score[i]<<" ";</p><p> outfile<<((stud[j].pingshi_score[i])*0.3+(stud[j].qizhong_score[i])*0.7)&l
104、t;<endl;</p><p><b> }</b></p><p> cout<<setw(50)<<endl; </p><p><b> }</b></p><p> outfile.close();</p><p><b&
105、gt; }</b></p><p><b> //讀入信息</b></p><p> void read()</p><p><b> {</b></p><p><b> int i,j;</b></p><p> ifstre
106、am infile("e:\\stud.txt",ios::in);</p><p> if(!infile)</p><p><b> {</b></p><p> cerr<<"open error!"<<endl;</p><p><b&g
107、t; }</b></p><p> for(j=0;j<n;j++)</p><p><b> {</b></p><p> cout<<stud[j].num<<" ";</p><p> cout<<stud[j].nam
108、e<<" "<<endl;</p><p> for(i=0;i<6;i++)</p><p> { cout<<stud[j].subject[i]<<" ";</p><p> cout<<stud[j].pingshi_scor
109、e[i]<<" ";</p><p> cout<<stud[j].qizhong_score[i]<<" ";</p><p> cout<<((stud[j].pingshi_score[i])*0.3+(stud[j].qizhong_score[i])*0.7)&l
110、t;<endl;</p><p><b> }</b></p><p> cout<<setw(50)<<endl; </p><p><b> }</b></p><p> infile.close();</p><p><b&g
溫馨提示
- 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- c++程序設計課程設計---學生成績管理系統(tǒng)
- c++程序設計課程設計 ----學生成績管理系統(tǒng)實驗報告
- c++程序課程設計報告—學生成績管理系統(tǒng)
- c語言程序設計課程設計---學生成績管理系統(tǒng)
- c語言課程設計---學生成績管理系統(tǒng)程序設計
- c++課程設計----學生成績管理系統(tǒng)
- c++課程設計----學生成績管理系統(tǒng)
- 學生成績管理系統(tǒng)c++課程設計
- c++課程設計-學生成績管理系統(tǒng)
- c++課程設計---學生成績管理系統(tǒng)
- c++課程設計---學生成績管理系統(tǒng)
- c++課程設計——學生成績管理系統(tǒng)
- c++課程設計--學生成績管理系統(tǒng)
- c++學生成績管理系統(tǒng)課程設計
- c++課程設計--學生成績管理系統(tǒng)
- c++課程設計--- 學生成績管理系統(tǒng)設計
- c++程序設計課程設計---學生成績管理信息系統(tǒng)設計與開發(fā)
- c++課程設計--學生成績管理
- 程序設計課程設計---學生成績管理系統(tǒng)
- c++課程設計--學生成績管理
評論
0/150
提交評論