版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、C+課程設(shè)計(jì)報(bào)告班級(jí): 計(jì)網(wǎng)1003班 學(xué)號(hào): 1008040324 姓名: 白東海 時(shí)間: 2011-7-8 西安科技大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)學(xué)院題目:成績(jī)管理系統(tǒng) 一、設(shè)計(jì)內(nèi)容成績(jī)管理系統(tǒng)現(xiàn)有學(xué)生成績(jī)信息,內(nèi)容如下姓名 學(xué)號(hào) 語文 數(shù)學(xué) 英語張明明 01 67 78 82李成友 02 78 91 88李燦輝 03 68 82 56王露 04 56 45 77陳東明 05 67 38 47. . . . . . 請(qǐng)用C/C+編寫一系統(tǒng),實(shí)現(xiàn)學(xué)生信息管理,軟件的入口界面應(yīng)包括如下幾個(gè)方面:功能要求:(1)信息維護(hù)要求:學(xué)生信息數(shù)據(jù)要以文件的形式保存,能實(shí)現(xiàn)學(xué)生信息數(shù)據(jù)的維護(hù)。此模塊包括子模塊有:增
2、加學(xué)生信息、刪除學(xué)生信息、修改學(xué)生信息(2)信息查詢:要求:查詢時(shí)可實(shí)現(xiàn)按姓名查詢、按學(xué)號(hào)查詢(3)成績(jī)統(tǒng)計(jì):要求:任意輸入一個(gè)課程名(如數(shù)學(xué))和一個(gè)分?jǐn)?shù)段(如60-70),統(tǒng)計(jì)出在此分?jǐn)?shù)段的學(xué)生情況(4)單科排序:要求:能對(duì)用戶指定的任意課程名,按成績(jī)升序或降序排列學(xué)生數(shù)據(jù)并顯示排序結(jié)果(使用表格的形式顯示排序后的輸出結(jié)果)(使用多種方法排序者加分)二、設(shè)計(jì)目的1. 達(dá)到熟練掌握C+語言的基本知識(shí)和技能;2. 能夠利用所學(xué)的基本知識(shí)和技能,解決簡(jiǎn)單的面向?qū)ο蟪绦蛟O(shè)計(jì)問題。3.能夠讀寫程序三、系統(tǒng)分析與設(shè)計(jì)(確定程序功能模塊)1.用cout.cin來實(shí)現(xiàn)程序的輸入,輸出2.用了Statisti
3、s()計(jì)算平均成績(jī)3.用Lookup()實(shí)現(xiàn)查詢4用Modifk()實(shí)現(xiàn)修改5用Delete()實(shí)現(xiàn)刪除6用Output()實(shí)現(xiàn)輸出7用Sort()冒泡實(shí)現(xiàn)排序8用Insert()實(shí)現(xiàn)插入四、源程序代碼#include<iostream.h>#include<fstream.h>#include<stdlib.h>#include<string.h>#include<stdio.h>class Stu /構(gòu)建學(xué)生類public:friend void Input(Stu stud) ;friend void Statistic(Stu
4、 stud);friend void Lookup(Stu stud) ;friend void Modify(Stu stud) ;friend void Delete(Stu stud) ;friend void Output(Stu stud) ;friend void Sort(Stu stud) ;friend void Insert(Stu stud) ;friend void Write(Stu stud,int n); friend int Read(Stu stud);private:int num;char name8;float chinese; float math;f
5、loat english;float average;int order;stud100;void Write(Stu stud,int n) /向文件中寫入數(shù)據(jù)fstream myFile;myFile.open("C:student.txt",ios:out|ios:binary);if(!myFile)cout<<"C:student.txt can't open!"<<endl;abort();int count=n;myFile<<count<<endl<<endl;for(i
6、nt i=0;i<=count;i+)myFile<<studi.num<<" "<<<<" "<<studi.chinese<<" "<<studi.math<<" "<<studi.english<<" "<<studi.average<<endl; myFile.close();int Read(Stu stud) /從文
7、件中讀數(shù)據(jù) fstream myFile; myFile.open("C:student.txt",ios:in|ios:binary); if(!myFile)cout<<"C:student.txt can't open!"<<endl;abort(); int count; myFile.seekg(0); myFile>>count; for(int i=0;i<=count;i+) myFile>>studi.num>>>>studi.ch
8、inese>>studi.math>>studi.english>>studi.average; myFile.close(); return count ;void Input(Stu stud) /-輸入學(xué)生成績(jī)system("cls"); /*運(yùn)行前清屏*/int i=0;int flag;char sign;cout<<endl<<"=>> 請(qǐng)輸入學(xué)生成績(jī) <<="<<endl;while(sign!='n'&&sign
9、!='N') /*判斷*/ loop:cout<<"學(xué)號(hào):" cin>>studi.num;int c=0;while(c<i)c+;if(studi.num=studi-c.num)cout<<" 你輸入的學(xué)號(hào)已經(jīng)存在!請(qǐng)重新輸入。"<<endl;goto loop;cout<<"姓名:" cin>>; doflag=0; cout<<"語文成績(jī):" cin>>studi.ch
10、inese; if(studi.chinese>100 |studi.chinese<1) cout<<"對(duì)不起,請(qǐng)輸入1-100之間的數(shù)字!n" else flag=1;while(flag=0); do flag=0; cout<<"英語成績(jī):" cin>>studi.english; if(studi.english>100 |studi.english<1) cout<<"對(duì)不起,請(qǐng)輸入1-100之間的數(shù)字!n" else flag=1;while(fla
11、g=0); doflag=0;cout<<"數(shù)學(xué)成績(jī):" cin>>studi.math; if(studi.math>100 |studi.math<1) cout<<"對(duì)不起,請(qǐng)輸入1-100之間的數(shù)字!n" else flag=1;while(flag=0); studi.average=(studi.chinese+studi.math+studi.english)/3; cout<<"平均分為:"<<studi.average<<endl;
12、cout<<"=>提示:是否繼續(xù)寫入學(xué)生成績(jī)?(Y/N)" cin>>sign; /*輸入判斷*/ i+; Write(stud,i);void Statistic(Stu stud) /-統(tǒng)計(jì)學(xué)生數(shù)據(jù) system("cls"); /*運(yùn)行前清屏*/ int n=Read(stud);cout<<endl<<"=>> 輸出學(xué)生統(tǒng)計(jì)數(shù)據(jù) <<="<<endl; out<<"學(xué)號(hào)"<<"t&qu
13、ot;<<"姓名"<<"t"<<"語文"<<"t"<<"數(shù)學(xué)"<<"t"<<"英語"<<"t"<<"平均分"<<endl;for(int i=0;i<n;i+)cout<<studi.num<<"t"<<<<
14、;"t"<<studi.chinese<<"t"<<studi.math<<"t"<<studi.english<<"t"<<studi.average<<endl; system("pause"); void Lookup(Stu stud) /-查找學(xué)生成績(jī) system("cls"); /*運(yùn)行前清屏*/ int n=Read(stud);int s; int i=0;cou
15、t<<endl<<"=>> 查找學(xué)生成績(jī) <<="<<endl;cout<<"請(qǐng)輸入需要查找學(xué)生的學(xué)號(hào):"<<endl; cin>>s; while(studi.num-s)!=0&&i<n) i+; /*查找判斷*/ if(i=n) cout<<"=>提示:對(duì)不起,無法找到該學(xué)生的信息!"<<endl; /*輸入失敗信息*/ elsecout<<"-"&l
16、t;<endl; cout<<"學(xué)號(hào):"<<studi.num<<endl; /*輸出該學(xué)生信息*/ cout<<"姓名:"<<<<endl; cout<<"語文:"<<studi.chinese<<endl; cout<<"數(shù)學(xué):"<<studi.math<<endl; cout<<"英語:"<<stu
17、di.english<<endl; cout<<"平均分:"<<studi.average<<endl;void Modify(Stu stud) /-修改學(xué)生成績(jī) system("cls"); /*運(yùn)行前清屏*/ int n=Read(stud);int s; int i=0;cout<<endl<<"=>> 修改學(xué)生成績(jī) <<="<<endl;cout<<"請(qǐng)輸入需要修改成績(jī)學(xué)生的學(xué)號(hào):"&l
18、t;<endl; cin>>s; while(studi.num-s)!=0&&i<n) i+; /*查找判斷*/ if(i=n) cout<<"=>提示:對(duì)不起,無該學(xué)生的成績(jī)"<<endl; /*輸入失敗信息*/ elsecout<<"-該學(xué)生的信息-"<<endl; /*格式頭*/ cout<<"學(xué)號(hào)"<<"t"<<"姓名"<<"t&quo
19、t;<<"語文"<<"t"<<"數(shù)學(xué)"<<"t"<<"英語"<<"t"<<"平均分"<<endl;cout<<"-"<<endl; cout<<studi.num<<"t"<<<<"t"<<studi
20、.chinese<<"t"<<studi.math<<"t"<<studi.english<<"t"<<studi.average<<endl;cout<<"請(qǐng)重新輸入該學(xué)生的信息"<<endl;cout<<"學(xué)號(hào):"<<endl; cin>>studi.num; cout<<"姓名:"<<endl; cin&
21、gt;>; cout<<"語文成績(jī):"<<endl; cin>>studi.chinese; cout<<"數(shù)學(xué)成績(jī):"<<endl; cin>>studi.math; cout<<"英語成績(jī):"<<endl; cin>>studi.english;studi.average=(studi.chinese+studi.math+studi.english)/3; cout<<"平均
22、分為:"<<studi.average<<endl; char c; cout<<"是否保存數(shù)據(jù)?(y/n)"<<endl; cin>>c; if(c!='n'&&c!='N') Write(stud,n);void Delete(Stu stud) /-按學(xué)號(hào)查找,刪除學(xué)生信息 system("cls"); /*運(yùn)行前清屏*/ int n=Read(stud);int s; int i=0,j;cout<<endl<&
23、lt;"=>> 刪除學(xué)生成績(jī) <<="<<endl;cout<<"請(qǐng)輸入需要?jiǎng)h除學(xué)生的學(xué)號(hào):"<<endl; /*交互式問尋*/ cin>>s; while(studi.num-s)!=0&&i<n) i+; /*查找判斷*/ if(i=n) cout<<"=>提示:對(duì)不起,無法找到該學(xué)生"<<endl; /*返回失敗信息*/ elsefor(j=i;j<n-1;j+) /*刪除操作*/ strcpy(st
24、,studj+1.name); studj.num=studj+1.num; studj.chinese=studj+1.chinese; studj.math=studj+1.math; studj.english=studj+1.english;studj.average=studj+1.average;cout<<"=>提示:已成功刪除!"<<endl; /*返回成功信息*/ Write(stud,n-1); void Insert(Stu stud) /-增加學(xué)生成績(jī) system("cls"); /
25、*運(yùn)行前清屏*/int n=Read(stud);char s;cout<<endl<<"=>> 增加學(xué)生成績(jī)<<="<<endl;while(s!='n'&&s!='N')cout<<"學(xué)號(hào):"<<endl; /*交互輸入*/ cin>>studn.num; cout<<"姓名:" cin>>; cout<<"語文成績(jī):&qu
26、ot; cin>>studn.chinese; cout<<"數(shù)學(xué)成績(jī):" cin>>studn.math; cout<<"英語成績(jī):" cin>>studn.english; studn.average=(studn.chinese+studn.english+ studn.math)/3; cout<<"平均分"<<studn.average;n+; cout<<"=>提示:插入成功!"<<endl
27、; /*返回成功信息*/cout<<"是否繼續(xù)輸入(y/n)"<<endl;cin>>s;Write(stud,n); void Sort(Stu stud) /-按平均分對(duì)學(xué)生成績(jī)記錄項(xiàng)進(jìn)行降序排序 system("cls"); /*運(yùn)行前清屏*/ int i,j,k; float s; char t20;cout<<endl<<"=>> 降序排序成績(jī) <<="<<endl;int n=Read(stud);for(i=0;i<n-
28、1;i+) /*冒泡法排序*/ for(j=0;j<n-1-i;j+) if(studj.average<studj+1.average) strcpy(t,studj+1.name); strcpy(studj+1.name,); strcpy(,t); k=studj+1.num; studj+1.num=studj.num; studj.num=k; s=studj+1.chinese; studj+1.chinese=studj.chinese; studj.chinese=s; s=studj+1.math; studj+1.mat
29、h=studj.math; studj.math=s; s=studj+1.english; studj+1.english=studj.english; studj.english=s; s=studj+1.average; studj+1.average=studj.average; studj.average=s; cout<<"-"<<endl; /*格式頭*/ cout<<"學(xué)號(hào)"<<"t"<<"姓名"<<"t"&
30、lt;<"語文"<<"t"<<"數(shù)學(xué)"<<"t"<<"英語"<<"t"<<"平均分"<<"t"<<"名次"<<endl; cout<<"-"<<endl; for(i=0;i<n;i+) /*循環(huán)輸入*/ studi.order=i+1;cout<&
31、lt;studi.num<<"t"<<<<"t"<<studi.chinese<<"t"<<studi.math<<"t "<<studi.english<<studn.average<<"t"<<studi.order<<endl; Write(stud,n);void Output(Stu stud) /-顯示全部學(xué)生成績(jī) sys
32、tem("cls"); /*運(yùn)行前清屏*/int n=Read(stud);cout<<endl<<"=>> 顯示全部學(xué)生成績(jī) <<="<<endl;if(!stud)cout<<"沒有記錄" elsecout<<"-"<<endl; /*格式頭*/ cout<<"學(xué)號(hào)"<<"t"<<"姓名"<<"t&q
33、uot;<<"語文"<<"t"<<"數(shù)學(xué)"<<"t"<<"英語"<<"t"<<"平均分"<<"名次"<<endl;cout<<"-"<<endl; for(int i=0;i<n;i+) /*循環(huán)輸入*/ cout<<studi.num<<"t &
34、quot;<<<<"t "<<studi.chinese<<" t"<< studi.math<<" t"<<studi.english<<"t"<<studn.average<<"t"<<studi.order<<endl; cout<<"-"<<endl; int menu() /*菜單
35、函數(shù)*/ char c; do system("cls"); /*運(yùn)行前清屏*/ cout<<"*n"<<endl; cout<<" -<<歡迎您使用學(xué)生成績(jī)管理系統(tǒng)-n"<<endl; cout<<" *nn"<<endl;/*菜單選擇*/ cout<<" * 【1】增加學(xué)生成績(jī) * "<<endl; cout<<" * 【2】顯示統(tǒng)計(jì)數(shù)據(jù) * "<
36、<endl; cout<<" * 【3】查找學(xué)生成績(jī) * "<<endl; cout<<" * 【4】修改學(xué)生成績(jī) * "<<endl; cout<<" * 【5】刪除學(xué)生成績(jī) * "<<endl; cout<<" * 【6】插入學(xué)生成績(jī) * "<<endl; cout<<" * 【7】按平均分降序排列 * "<<endl; cout<<" * 【8】顯示全部學(xué)生成績(jī) * "<<endl; cout<<" * 【0】退出本系統(tǒng) * "<<endl<<endl
溫馨提示
- 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. 人人文庫網(wǎng)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年版企業(yè)并購與重組合同:股權(quán)收購合同版B版
- 2024年規(guī)范化人力資源委托管理合同
- 2024跨境電子商務(wù)平臺(tái)建設(shè)與運(yùn)營(yíng)合作協(xié)議
- 2024年高速路段交通安全設(shè)施采購合同
- 2024店鋪市場(chǎng)推廣合作合同2篇
- 2025年度文化創(chuàng)意產(chǎn)業(yè)財(cái)產(chǎn)抵押擔(dān)保投資合同3篇
- 2025年度大型物流樞紐承包經(jīng)營(yíng)合同典范3篇
- 2024年網(wǎng)絡(luò)云服務(wù)提供商托管協(xié)議
- 2024年新能源項(xiàng)目技術(shù)顧問聘任協(xié)議3篇
- 2024年度牙齒矯正前后口腔護(hù)理指導(dǎo)服務(wù)合同3篇
- 2022年四級(jí)反射療法師考試題庫(含答案)
- 新《安全生產(chǎn)法》培訓(xùn)測(cè)試題
- 政務(wù)禮儀-PPT課件
- 特種涂料類型——耐核輻射涂料的研究
- 化工裝置常用英語詞匯對(duì)照
- 隔膜壓縮機(jī)(課堂PPT)
- 物資采購管理流程圖
- 無牙頜解剖標(biāo)志
- 標(biāo)準(zhǔn)《大跨徑混凝土橋梁的試驗(yàn)方法》
- 格拉斯哥昏迷評(píng)分(GCS)--表格-改良自用
- ISO9001記錄保存年限一覽表
評(píng)論
0/150
提交評(píng)論