版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 信息科學(xué)與技術(shù)學(xué)院</b></p><p> 程序設(shè)計(jì)基礎(chǔ)課程設(shè)計(jì)報(bào)告</p><p> 題目名稱: 學(xué)生考勤管理系統(tǒng) </p><p> 學(xué)生姓名: </p><p> 學(xué) 號(hào):
2、 </p><p> 專業(yè)班級(jí): </p><p> 指導(dǎo)教師: </p><p><b> 2012年7月6日</b></p><p><b> 目錄</b></p><p><b
3、> 目錄1</b></p><p> 1. 課程設(shè)計(jì)題目與要求2</p><p> 1.1 課題目的和要求2</p><p> 1.3 課題意義2</p><p><b> 2 總體設(shè)計(jì)3</b></p><p> 2.1功能模塊設(shè)計(jì)3</p>
4、<p> 2.2系統(tǒng)設(shè)計(jì)方案3</p><p><b> 3 詳細(xì)設(shè)計(jì)4</b></p><p> 3.1 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)4</p><p> 3.2 主模塊設(shè)計(jì)5</p><p> 3.2.1建立學(xué)生缺課記錄子模塊5</p><p> 3.2.2修改學(xué)生缺課
5、記錄子模塊6</p><p> 3.2.3修改學(xué)生缺課記錄子模塊7</p><p> 3.2.4查看單科曠課記錄子模塊7</p><p> 3.2.5查看學(xué)生曠課記錄子模塊8</p><p> 3.2.6載入學(xué)生曠課記錄子模塊9</p><p> 3.2.7儲(chǔ)存學(xué)生曠課記錄子???0</p&
6、gt;<p> 4. 運(yùn)行結(jié)果12</p><p><b> 4.1運(yùn)行12</b></p><p> 5. 課程設(shè)計(jì)總結(jié)16</p><p><b> 結(jié)束語(yǔ)16</b></p><p><b> 參考文獻(xiàn)16</b></p>
7、<p><b> 附錄:源代碼17</b></p><p> 1. 課程設(shè)計(jì)題目與要求</p><p> 1.1 課題目的和要求</p><p> 設(shè)計(jì)目的:要求實(shí)現(xiàn)---“學(xué)生考勤管理程序”記錄學(xué)生的缺課情況,它包括:缺課日期、第幾節(jié)課、課程名稱、學(xué)生姓名、缺課類型(遲到、早退、請(qǐng)假及曠課)。</p><
8、;p> 1.2 設(shè)計(jì)要求: </p><p> 1.錄入學(xué)生的缺課記錄;</p><p> 2.修改某個(gè)學(xué)生的缺課記錄;</p><p> 3.查詢某個(gè)學(xué)生的缺課情況;</p><p> 4.統(tǒng)計(jì)某段時(shí)間內(nèi),某門課曠課學(xué)生姓名及曠課次數(shù),按曠課次數(shù)由多到少排序; </p><p> 5.統(tǒng)計(jì)某段時(shí)間內(nèi)
9、,有學(xué)生曠課的課程及曠課人次,按曠課人次由多到少排序;</p><p> 6.系統(tǒng)以菜單方式工作。</p><p><b> 1.3 課題意義</b></p><p> 程序?qū)嵺`是本科生重要教學(xué)環(huán)節(jié)之一。通過(guò)程序?qū)嵺`,強(qiáng)化學(xué)生的計(jì)算機(jī)應(yīng)用技能,使學(xué)生驗(yàn)證、鞏固和充實(shí)所學(xué)的理論知識(shí), 加深對(duì)相關(guān)內(nèi)容的理解,拓寬知識(shí)面,培養(yǎng)學(xué)生的創(chuàng)新精神和實(shí)
10、踐能力</p><p> 學(xué)生考勤管理程序可以大大減緩學(xué)生考勤人員的工作量, 方便了平時(shí)上課學(xué)生的出勤率的管理。</p><p><b> 2 總體設(shè)計(jì)</b></p><p><b> 2.1功能模塊設(shè)計(jì)</b></p><p> 根據(jù)分析整個(gè)系統(tǒng)主要?jiǎng)澐譃?個(gè)功能模塊,分別執(zhí)行要求中的功
11、能。數(shù)據(jù)管理中實(shí)現(xiàn)對(duì)學(xué)生的基本信息、課程的基本信息、學(xué)生缺課的查詢、添加、刪除和修改,以及具體缺課缺課內(nèi)容,是遲到、早退、請(qǐng)假、曠課。查詢管理通過(guò)根據(jù)學(xué)生姓名,課程姓名 時(shí)間段兒等信息,查詢單個(gè)學(xué)生的缺課記錄,單科課的曠課記錄,單個(gè)學(xué)生的曠課記錄。功能模塊圖如圖1所示。、</p><p><b> 圖1功能模塊圖</b></p><p><b> 2.2
12、系統(tǒng)設(shè)計(jì)方案</b></p><p> 此程序是過(guò)程性語(yǔ)言設(shè)計(jì)的。運(yùn)用多種條件語(yǔ)句,主體采用的是鏈表指針。系統(tǒng)的設(shè)計(jì)采用了數(shù)組語(yǔ)句、選擇語(yǔ)句和循環(huán)語(yǔ)句,在需要處理大量同類數(shù)據(jù)時(shí),這樣就使程序書寫更加簡(jiǎn)潔。程序使用了布爾函數(shù)。選擇語(yǔ)句多采用if多分支選擇結(jié)構(gòu)與switch語(yǔ)句。首先計(jì)算switch表達(dá)式,然后在caes子句中尋找值相等的常量表達(dá)式,并以此為入口符號(hào),由此開始順序執(zhí)行。循環(huán)語(yǔ)句采用了fo
13、r語(yǔ)句等、do-while語(yǔ)句,for語(yǔ)句用于已知循環(huán)次數(shù)的循環(huán)結(jié)構(gòu),括號(hào)中的三個(gè)量分別用來(lái)表示循環(huán)變量初值、循環(huán)終值和循環(huán)增量。do-while語(yǔ)句先循環(huán)后判斷, Break語(yǔ)句在switch語(yǔ)句中,保證多分支情況的正確執(zhí)行,在循環(huán)語(yǔ)句中,強(qiáng)制終止本層循環(huán)。保存和讀取函數(shù)是典型的函數(shù)功能,一個(gè)程序是由若干個(gè)函數(shù)組成的,保存和讀取函數(shù)是和其他函數(shù)互相調(diào)用的。</p><p><b> 3 詳細(xì)設(shè)計(jì)&l
14、t;/b></p><p> 3.1 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)</p><p> struct xueke</p><p> {char xueke_name[50];</p><p> int people_num;</p><p><b> };</b></p><p
15、> 這是定義了一個(gè)xueke結(jié)構(gòu)體,用來(lái)存放一個(gè)學(xué)科名及其相應(yīng)的曠課人數(shù);</p><p> struct student</p><p> {char name[50];</p><p> long time;</p><p> int lesson_time;</p><p> char les
16、son_name[50];</p><p> int chidao_num;</p><p> int zaotui_num;</p><p> int qingjia_num;</p><p> int kuangke_num;</p><p> struct student *next;</p>
17、;<p> };這是定義了一個(gè)student的結(jié)構(gòu)體,用來(lái)存放一個(gè)學(xué)生的考勤記錄,</p><p> 其中有,字符數(shù)組name[50],lesson_name[50],分別存放學(xué)生名字,</p><p> 缺課課程名字;int型變量lesson_time,chidao_num,zaotui_num,qingjia_num,
18、 kuangke_num,分別來(lái)存放,缺課節(jié)次,遲到次數(shù),早退次數(shù),請(qǐng)假次數(shù),曠課次數(shù) long型變量time,記錄時(shí)間。</p><p> 3.2 主模塊設(shè)計(jì)</p><p> 3.2.1建立學(xué)生缺課記錄子模塊</p><p> 要建立的學(xué)生人數(shù),學(xué)生基本信息(包括缺課時(shí)間、學(xué)生姓名、課程名稱、節(jié)次、遲到次數(shù)、早退次數(shù)、請(qǐng)假次數(shù)、曠課次
19、數(shù))可用creat()函數(shù)如圖1.</p><p><b> 圖1</b></p><p> 3.2.2修改學(xué)生缺課記錄子模塊</p><p> 根據(jù)要修改的學(xué)生姓名以及科目名稱找到相應(yīng)的信息,再選擇要修改的項(xiàng)目進(jìn)行單項(xiàng)修改 如圖2</p><p><b> 圖2</b></p>
20、<p> 3.2.3修改學(xué)生缺課記錄子模塊</p><p> 根據(jù)人名可以查出該學(xué)生的所有缺課記錄 如圖3</p><p><b> 圖3</b></p><p> 3.2.4查看單科曠課記錄子模塊</p><p> 根據(jù)學(xué)科名稱和時(shí)間范圍查出所有在該范圍內(nèi)曠課的學(xué)生以及次數(shù) 如圖4</p&
21、gt;<p><b> 圖4</b></p><p> 3.2.5查看學(xué)生曠課記錄子模塊</p><p> 根據(jù)要查詢的學(xué)科名稱及時(shí)間段查出在改時(shí)間段內(nèi)該門課上曠課的人數(shù) 如圖5</p><p><b> 圖5</b></p><p> 3.2.6載入學(xué)生曠課記錄子模塊<
22、;/p><p> 可以載入實(shí)現(xiàn)儲(chǔ)存在當(dāng)前文件夾中txt文件中所儲(chǔ)存的數(shù)據(jù) 如圖6</p><p><b> 圖6</b></p><p> 3.2.7儲(chǔ)存學(xué)生曠課記錄子???lt;/p><p> 進(jìn)入系統(tǒng)界面,順序的完成各項(xiàng)操作,進(jìn)行數(shù)據(jù)的輸入,信息的保存調(diào)用相應(yīng)的函數(shù)打開相應(yīng)的地址,查詢各項(xiàng)信息。如圖7</p&g
23、t;<p><b> 圖7</b></p><p><b> 4. 運(yùn)行結(jié)果</b></p><p><b> 4.1運(yùn)行</b></p><p><b> 開始菜單</b></p><p><b> 圖1 開始菜單&
24、lt;/b></p><p><b> 主菜單</b></p><p><b> 圖2 主菜單</b></p><p> 1.建立學(xué)生缺課記錄</p><p> 圖2建立學(xué)生缺課記錄</p><p><b> 修改學(xué)生缺課紀(jì)錄</b>&
25、lt;/p><p> 圖3修改學(xué)生缺課記錄</p><p> 3.查詢學(xué)生缺課記錄</p><p> 圖4查詢學(xué)生缺課記錄</p><p> 4.查看單科曠課記錄</p><p> 圖5查看單科曠課記錄</p><p> 5.查看學(xué)生曠課記錄</p><p>
26、圖6查看學(xué)生曠課記錄</p><p> 6.載入學(xué)生曠課記錄</p><p> 圖7載入學(xué)生曠課記錄</p><p> 7. 儲(chǔ)存學(xué)生曠課記錄</p><p> 圖8儲(chǔ)存學(xué)生曠課記錄</p><p><b> 5. 課程設(shè)計(jì)總結(jié)</b></p><p> 課程設(shè)
27、計(jì)順利完成,題目所要求的功能也都一一實(shí)現(xiàn),可以對(duì)學(xué)生的缺課信息進(jìn)行添加,修改,刪除以及查詢的顯示。不過(guò)這個(gè)程序還有些不夠完善,例如不能往當(dāng)前文件夾中的txt文件中添加記錄。</p><p><b> 結(jié)束語(yǔ)</b></p><p> 整個(gè)系統(tǒng)的設(shè)計(jì)過(guò)程對(duì)于我來(lái)說(shuō)算是個(gè)學(xué)習(xí)、探索的過(guò)程,通過(guò)實(shí)踐和對(duì)比別人開發(fā)程序的過(guò)程。在整個(gè)設(shè)計(jì)過(guò)程中,出現(xiàn)過(guò)很多的問題,很多繁瑣的
28、東西都需要反復(fù)的修改,主要是前期工作不徹底,對(duì)系統(tǒng)的需求分析的要求認(rèn)識(shí)不夠清楚,使得在后邊的工作中不得不經(jīng)常反復(fù)去修改。使我體會(huì)到設(shè)置中每一步的重要性。所以在分析一個(gè)問題時(shí),我們需要站在一個(gè)有遠(yuǎn)見的高度。</p><p> 通過(guò)此次設(shè)計(jì),我不但對(duì)C++語(yǔ)言編程有了更深刻的認(rèn)識(shí),積累了使用軟件工程的思想來(lái)開發(fā)軟件的經(jīng)驗(yàn),更重要的是學(xué)會(huì)了在對(duì)待問題時(shí)應(yīng)該考慮到哪些方面和怎么解決問題。</p><
29、p> 雖然時(shí)間緊迫但我學(xué)會(huì)了很多,也感到自身知識(shí)的貧乏,希望在日后的努力中能做出更完善的系統(tǒng)。</p><p><b> 參考文獻(xiàn)</b></p><p><b> 附錄:源代碼</b></p><p> #include<cstdio></p><p> #includ
30、e<iostream></p><p> #include<malloc.h></p><p> #include<cstring></p><p> #include<iomanip></p><p> #define NULL 0</p><p> #def
31、ine guding 10</p><p> #define LEN sizeof(struct student)</p><p> using namespace std;</p><p> int student_num;</p><p> FILE *fp1;</p><p> struct xueke
32、</p><p> {char xueke_name[50];</p><p> int people_num;</p><p><b> };</b></p><p> struct student</p><p> {char name[50];</p><p&
33、gt; long time;</p><p> int lesson_time;</p><p> char lesson_name[50];</p><p> int chidao_num;</p><p> int zaotui_num;</p><p> int qingjia_num;</p&
34、gt;<p> int kuangke_num;</p><p> struct student *next;</p><p><b> };</b></p><p> void chaxun(struct student *head)</p><p><b> {int i;<
35、/b></p><p> char chaxun_name[50];</p><p> cout<<"請(qǐng)輸入要查詢的人名:";</p><p> cin>>chaxun_name;</p><p> struct student *p;</p><p> if
36、(head==NULL)</p><p> cout<<"聯(lián)系人為空";</p><p><b> p=head;</b></p><p> for(i=0;i<student_num;i++)</p><p> {if(strcmp(chaxun_name,p->na
37、me)==0)</p><p> {cout<<"缺課時(shí)間:"<<p->time<<" 學(xué)生姓名:"<<p->name<<" 課程名稱:"<<p->lesson_name<<" 節(jié)次:"<<p
38、->lesson_time<<endl</p><p> <<"遲到次數(shù):"<<p->chidao_num<<" 早退次數(shù):"<<p->zaotui_num<<" 請(qǐng)假次數(shù):"<<p->qingjia_n
39、um<<" 曠課次數(shù):"<<p->kuangke_num<<endl;</p><p><b> }</b></p><p> p=p->next; }</p><p><b> }</b></p><p> st
40、ruct student *xiugai(struct student *head)</p><p> {char xiugai_name[50];</p><p> char xiugai_xueke_name[50];</p><p><b> int k;</b></p><p> cout<<
41、"請(qǐng)輸入要修改的學(xué)生姓名與學(xué)科名稱【格式:學(xué)生姓名(空格)學(xué)科名稱】:";</p><p> cin>>xiugai_name>>xiugai_xueke_name;</p><p> struct student *p1,*p2; </p><p> p2=(struct student *)malloc(LEN)
42、;</p><p><b> p1=head;</b></p><p> if(head==NULL)</p><p> {cout<<"沒有學(xué)生信息\n";</p><p> return head; }</p><p> while((strcmp(x
43、iugai_name,p1->name)!=0||strcmp(xiugai_xueke_name,p1->lesson_name)!=0)&&(p1->next!=NULL))</p><p> p1=p1->next;</p><p> if(strcmp(xiugai_name,p1->name)==0&&strcmp
44、(xiugai_xueke_name,p1->lesson_name)==0)</p><p> { cout<<"==================================== 修改信息 =================================\n"; </p><p> cout<<"
45、 1-修改缺課時(shí)間 \n";</p><p> cout<<" 2-修改學(xué)生姓名 \n";</p><p> cout<<"
46、 3-修改課程名稱 \n";</p><p> cout<<" 4-修改第幾節(jié)缺課 \n";</p><p> cout<<"
47、 5-修改遲到次數(shù) \n";</p><p> cout<<" 6-修改早退次數(shù) \n";</p><p> cout<<"
48、 7-修改請(qǐng)假次數(shù) \n";</p><p> cout<<" 8-修改曠課次數(shù) \n\n";</p><p> cout<<"=====================================
49、===========================================\n";</p><p><b> cin>>k;</b></p><p><b> switch(k)</b></p><p><b> {case 1:</b></p>
50、<p> cout<<"請(qǐng)輸入新的缺課時(shí)間:";</p><p> cin>>p1->time;</p><p><b> break;</b></p><p><b> case 2:</b></p><p> cout<
51、<"請(qǐng)輸入新的學(xué)生姓名:";</p><p> cin>>p1->name;</p><p><b> break;</b></p><p><b> case 3:</b></p><p> cout<<"請(qǐng)輸入新的課程名稱
52、:";</p><p> cin>>p1->lesson_name;</p><p><b> break;</b></p><p><b> case 4:</b></p><p> cout<<"請(qǐng)輸入新的缺課節(jié)次:";<
53、/p><p> cin>>p1->lesson_time;</p><p><b> break;</b></p><p><b> case 5:</b></p><p> cout<<"請(qǐng)輸入新的遲到次數(shù):";</p><
54、p> cin>>p1->chidao_num;</p><p><b> break;</b></p><p><b> case 6:</b></p><p> cout<<"請(qǐng)輸入新的早退次數(shù):";</p><p> cin>
55、;>p1->zaotui_num;</p><p><b> break;</b></p><p><b> case 7:</b></p><p> cout<<"請(qǐng)輸入新的請(qǐng)假次數(shù):";</p><p> cin>>p1->q
56、ingjia_num;</p><p><b> break;</b></p><p><b> case 8:</b></p><p> cout<<"請(qǐng)輸入新的曠課次數(shù):";</p><p> cin>>p1->kuangke_num;&
57、lt;/p><p><b> break; }</b></p><p><b> }</b></p><p> return head;</p><p><b> }</b></p><p> struct student *creat()<
58、/p><p><b> {</b></p><p><b> int i,b;</b></p><p> struct student *head,*p1,*p2; </p><p> cout<<"請(qǐng)輸入要建立資料的學(xué)生人數(shù):";</p>
59、<p><b> cin>>b;</b></p><p> head=p2=NULL;</p><p> p1=(struct student *)malloc(LEN);</p><p> cout<<"【輸入格式:缺課時(shí)間(空格)學(xué)生姓名(空格)課程名稱(空格)第幾節(jié)(空格)遲到次數(shù)(空
60、格)早退次數(shù)(空格)請(qǐng)假次數(shù)(空格)曠課次數(shù)】\n";</p><p> cout<<"請(qǐng)輸入第1名學(xué)生信息:";</p><p> cin>>p1->time>>p1->name>>p1->lesson_name>>p1->lesson_time>>p1-&g
61、t;chidao_num>>p1->zaotui_num>>p1->qingjia_num>>p1->kuangke_num;</p><p><b> head=p1;</b></p><p><b> p2=p1;</b></p><p> student_n
62、um+=1;</p><p> for(i=1;i<b;i++)</p><p><b> {</b></p><p> p1=(struct student*)malloc(LEN);</p><p> cout<<"請(qǐng)輸入第"<<i+1<<&quo
63、t;名學(xué)生信息:";</p><p> cin>>p1->time>>p1->name>>p1->lesson_name>>p1->lesson_time>>p1->chidao_num>>p1->zaotui_num>>p1->qingjia_num>>p1-&g
64、t;kuangke_num;</p><p> p2->next=p1;</p><p><b> p2=p1;</b></p><p> student_num+=1;</p><p><b> }</b></p><p> p2->next=NULL
65、; </p><p> return head;</p><p><b> }</b></p><p> void print(struct student *head)</p><p> {struct student *p;</p><p><b> p=head
66、;</b></p><p> if(p==NULL)</p><p> cout<<"沒有學(xué)生信息\n";</p><p> while(p!=NULL)</p><p> { cout<<"缺課時(shí)間:"<<p->time<<
67、;" 學(xué)生姓名:"<<setw(10)<<p->name<<" 課程名稱:"<<p->lesson_name<<" 節(jié)次:"<<p->lesson_time<<endl</p><p> <<"遲到次數(shù)
68、:"<<p->chidao_num<<" 早退次數(shù):"<<p->zaotui_num<<" 請(qǐng)假次數(shù):"<<p->qingjia_num<<" 曠課次數(shù):"<<p->kuangke_num<<endl
69、;</p><p> p=p->next;}</p><p><b> }</b></p><p> struct student *tongji_lesson(struct student *head)</p><p> {struct student *p1,*p2,*p3;</p>
70、<p> char lesson[50];</p><p> long look_time1,look_time2;</p><p> int xunhuan_num=0;</p><p> p3=(struct student *)malloc(LEN);</p><p> if(head==NULL)</p>
71、;<p> {cout<<"沒有學(xué)生信息";</p><p> return(head); }</p><p><b> p1=head;</b></p><p> p2=p1->next;</p><p> while(xunhuan_num<stud
72、ent_num)</p><p> {while(p2!=NULL)</p><p><b> {</b></p><p> if(p2->kuangke_num>p1->kuangke_num)</p><p><b> {</b></p><p>
73、; p3->chidao_num=p2->chidao_num;</p><p> p3->kuangke_num=p2->kuangke_num;</p><p> p3->qingjia_num=p2->qingjia_num;</p><p> p3->zaotui_num=p2->zaotui_num;
74、</p><p> p3->lesson_time=p2->lesson_time;</p><p> p3->time=p2->time;</p><p> strcpy(p3->lesson_name,p2->lesson_name);</p><p> strcpy(p3->name,p
75、2->name);</p><p> p2->chidao_num=p1->chidao_num;</p><p> p2->kuangke_num=p1->kuangke_num;</p><p> p2->qingjia_num=p1->qingjia_num;</p><p> p2-&
76、gt;zaotui_num=p1->zaotui_num;</p><p> p2->lesson_time=p1->lesson_time;</p><p> p2->time=p1->time;</p><p> strcpy(p2->lesson_name,p1->lesson_name);</p>
77、<p> strcpy(p2->name,p1->name);</p><p> p1->chidao_num=p3->chidao_num;</p><p> p1->kuangke_num=p3->kuangke_num;</p><p> p1->qingjia_num=p3->qingjia
78、_num;</p><p> p1->zaotui_num=p3->zaotui_num;</p><p> p1->lesson_time=p3->lesson_time;</p><p> p1->time=p3->time;</p><p> strcpy(p1->lesson_name
79、,p3->lesson_name);</p><p> strcpy(p1->name,p3->name);</p><p><b> }</b></p><p><b> p1=p2;</b></p><p> p2=p2->next;</p><
80、;p><b> }</b></p><p><b> p1=head;</b></p><p> p2=p1->next;</p><p> xunhuan_num++;</p><p><b> }</b></p><p> c
81、out<<"請(qǐng)輸入要查看的學(xué)科名稱:";</p><p> cin>>lesson;</p><p> cout<<"請(qǐng)輸入要查看的時(shí)間范圍【輸入格式:時(shí)間(空格)時(shí)間】";</p><p> cin>>look_time1>>look_time2;</p
82、><p> p1=head; </p><p> while(p1!=NULL)</p><p> {if(strcmp(lesson,p1->lesson_name)==0&&look_time1<=p1->time&&p1->time<=look_time2)</p><p&
83、gt; cout<<"學(xué)生姓名:"<<p1->name<<" 曠課次數(shù):"<<p1->kuangke_num<<endl;</p><p> p1=p1->next; }</p><p> return head;</p><p>&l
84、t;b> }</b></p><p> struct student *tongji_student(struct student *head)</p><p> { struct xueke a[10];</p><p> int n,i,j,zhongjian;</p><p> struct stude
85、nt *p1;</p><p> char zhongjian_name[50];</p><p> long look_time1,look_time2;</p><p> if(head==NULL)</p><p> {cout<<"沒有學(xué)生信息\n";</p><p>
86、 return head; </p><p><b> }</b></p><p> cout<<"請(qǐng)輸入一共的學(xué)科數(shù):";</p><p><b> cin>>n;</b></p><p> for(i=0;i<n;i++)</p&g
87、t;<p> {cout<<"請(qǐng)輸入第"<<i+1<<"個(gè)學(xué)科名稱:";</p><p> cin>>a[i].xueke_name;</p><p> a[i].people_num=0; </p><p><b> }</b><
88、;/p><p> cout<<"請(qǐng)輸入要查看的時(shí)間范圍由小到大【輸入格式:時(shí)間(空格)時(shí)間】";</p><p> cin>>look_time1>>look_time2;</p><p><b> p1=head;</b></p><p> for(i=0;i
89、<n;i++)</p><p> {while(p1!=NULL&&look_time1<=p1->time&&p1->time<=look_time2)</p><p> {if(a[i].xueke_name==p1->lesson_name)</p><p> a[i].people_n
90、um+=p1->kuangke_num;</p><p> p1=p1->next;}</p><p><b> p1=head; </b></p><p><b> }</b></p><p> for(j=0;j<n-1;j++)
91、 </p><p> for(i=0;i<n-1-j;i++)</p><p> {if(a[i].people_num<a[i+1].people_num)</p><p> {zhongjian=a[i+1].people_num;</p><p> a[i+1
92、].people_num=a[i].people_num;</p><p> a[i].people_num=zhongjian;</p><p> strcpy(zhongjian_name,a[i+1].xueke_name);</p><p> strcpy(a[i+1].xueke_name,a[i].xueke_name);</p>&
93、lt;p> strcpy(a[i].xueke_name,zhongjian_name);}</p><p> else if(a[i].people_num==a[i+1].people_num&&strcmp(a[i].xueke_name,a[i+1].xueke_name)>0)</p><p> { zhongjian=a[i+1].
94、people_num;</p><p> a[i+1].people_num=a[i].people_num;</p><p> a[i].people_num=zhongjian;</p><p> strcpy(zhongjian_name,a[i+1].xueke_name);</p><p> strcpy(a[i+1].xu
95、eke_name,a[i].xueke_name);</p><p> strcpy(a[i].xueke_name,zhongjian_name);}</p><p><b> }</b></p><p> for(i=0;i<n;i++)</p><p> {cout<<"學(xué)科名稱
96、:"<<a[i].xueke_name<<" 曠課次數(shù):"<<a[i].people_num<<endl;</p><p> return head;}</p><p> return head;</p><p><b> }</b></p>&l
97、t;p> struct student *zairu()</p><p> {struct student *p1=NULL,*p2=NULL,*head=NULL;</p><p> struct student student_ziliao[100];</p><p> int i=0,n=0;</p><p> if((
98、fp1=fopen("xueshengziliao.txt","rb+"))==NULL)</p><p> { printf("cannot open file\n");</p><p> return(head); } </p><p> while(!feof(fp1))</p>
99、<p> {if(fread(&student_ziliao[i],LEN,1,fp1)!=1)</p><p> {if(feof(fp1))</p><p> {fclose(fp1); </p><p><b> break; }</b></p><p> printf("f
100、ile read error\n");}</p><p><b> i++;</b></p><p><b> }</b></p><p><b> n=i;</b></p><p> student_num=n;</p><p>
101、p1=p2=(struct student *)malloc(LEN);</p><p><b> head=p1;</b></p><p> for(i=0;i<n;i++)</p><p> {p1->chidao_num=student_ziliao[i].chidao_num;</p><p>
102、; p1->kuangke_num=student_ziliao[i].kuangke_num;</p><p> strcpy(p1->lesson_name,student_ziliao[i].lesson_name);</p><p> p1->lesson_time=student_ziliao[i].lesson_time;</p><
103、p> strcpy(p1->name,student_ziliao[i].name);</p><p> p1->qingjia_num=student_ziliao[i].qingjia_num;</p><p> p1->time=student_ziliao[i].time;</p><p> p1->zaotui_num
104、=student_ziliao[i].zaotui_num;</p><p> p2->next=p1;</p><p><b> p2=p1;</b></p><p> p1=(struct student*)malloc(LEN); }</p><p> p2->next=NULL;</p&
105、gt;<p> return(head);</p><p><b> }</b></p><p> void chucun(struct student *head)</p><p> {struct student *p1;</p><p><b> p1=head;</b&g
106、t;</p><p> fp1=fopen("xueshengziliao.txt","wb+");</p><p> while(p1!=NULL)</p><p> {fwrite(p1,LEN,1,fp1);</p><p> p1=p1->next; }</p>&l
107、t;p> fclose(fp1);</p><p> cout<<" 儲(chǔ)存成功\n";</p><p><b> }</b></p><p> void main()</p><p><b> {</b></
108、p><p> struct student *head;</p><p> int a,b,c;</p><p> zhuye: cout<<"$$$$$$$$$$$$$$$$$$$$$$ 歡迎使用學(xué)生考勤管理系統(tǒng) V1.0.0 $$$$$$$$$$$$$$$$$$\n"; </p><p>
109、; cout<<" 1_進(jìn)入管理\n\n\n";</p><p> cout<<" 2_查看系統(tǒng)相關(guān)信息\n\n\n";</p><p> cout<<"$$$$$$$$$$$$$$$
110、$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$\n\n\n\n\n";</p><p><b> cin>>a;</b></p><p><b> if(a==1)</b></p><p><b> {
111、</b></p><p><b> do</b></p><p> { cout<<"********************************************************************************\n";</p><p> cout<&
112、lt;" 1_建立學(xué)生缺課記錄\n";</p><p> cout<<" 2_修改學(xué)生缺課記錄\n";</p><p> cout<<"
113、 3_查詢學(xué)生缺課記錄\n";</p><p> cout<<" 4_查看單科曠課記錄\n";</p><p> cout<<" 5_查看學(xué)生曠課記錄\n";</p>
114、<p> cout<<" 6_載入學(xué)生曠課記錄\n";</p><p> cout<<" 7_儲(chǔ)存學(xué)生曠課記錄\n";</p><p> cout<<"
115、 8_退出考勤管理程序\n";</p><p> cout<<"********************************************************************************\n";</p><p><b> cin>>b;&
116、lt;/b></p><p><b> switch(b)</b></p><p><b> {</b></p><p><b> case 1:</b></p><p> head=creat();</p><p> print(hea
117、d);</p><p><b> break;</b></p><p><b> case 2:</b></p><p> head=xiugai(head);</p><p> print(head);</p><p><b> break;</b
118、></p><p><b> case 3:</b></p><p> chaxun(head);</p><p><b> break;</b></p><p><b> case 4:</b></p><p> head=tongji
119、_lesson(head);</p><p><b> break;</b></p><p><b> case 5:</b></p><p> head=tongji_student(head);</p><p><b> break;</b></p>
120、<p><b> case 6:</b></p><p> head=zairu();print(head);</p><p><b> break;</b></p><p><b> case 7:</b></p><p> chucun(head);&l
121、t;/p><p><b> break;}</b></p><p> }while(b!=8);</p><p><b> }</b></p><p><b> else </b></p><p> {cout<<"*****
122、*************************本系統(tǒng)版權(quán)歸喻思遠(yuǎn)個(gè)人所有!***********************\n";</p><p> cout<<"******************************請(qǐng)聯(lián)系我:tel:18799760125,QQ:1010582011***********\n";</p><p> c
123、out<<"******************************返回主頁(yè)請(qǐng)按1*************************************\n";</p><p><b> cin>>c;</b></p><p><b> if(c==1)</b></p><
溫馨提示
- 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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 學(xué)生考勤管理系統(tǒng)課程設(shè)計(jì)報(bào)告1
- 學(xué)生考勤系統(tǒng)設(shè)計(jì)課程設(shè)計(jì)報(bào)告
- 學(xué)生考勤管理系統(tǒng)課程設(shè)計(jì)
- c++課程設(shè)計(jì)-學(xué)生考勤管理系統(tǒng)
- 課程設(shè)計(jì)---考勤管理系統(tǒng)報(bào)告書
- 考勤管理系統(tǒng)課程設(shè)計(jì)
- c++課程設(shè)計(jì)報(bào)告-學(xué)生考勤管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 考勤管理課程設(shè)計(jì)報(bào)告
- 學(xué)生考勤系統(tǒng)c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)學(xué)生考勤系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)學(xué)生考勤系統(tǒng)
- 《學(xué)生管理系統(tǒng)》課程設(shè)計(jì)報(bào)告
- 學(xué)生管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- 學(xué)生管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- 職工考勤管理信息系統(tǒng)-課程設(shè)計(jì)報(bào)告
- 職工考勤管理信息系統(tǒng)-課程設(shè)計(jì)報(bào)告
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)---學(xué)生考勤系統(tǒng)
- ic卡考勤管理系統(tǒng)課程設(shè)計(jì)
- 學(xué)生選課管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- java課程設(shè)計(jì)報(bào)告學(xué)生管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論