C語言課程設計 學生信息管理系統(tǒng)_第1頁
C語言課程設計 學生信息管理系統(tǒng)_第2頁
C語言課程設計 學生信息管理系統(tǒng)_第3頁
C語言課程設計 學生信息管理系統(tǒng)_第4頁
C語言課程設計 學生信息管理系統(tǒng)_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、 c語言及數(shù)據(jù)結構與算法課程設計題目 : 學生信息管理系統(tǒng) 專 業(yè): 姓 名: 學 號: 同組其他學生(學號): 2013年月 日目 錄一、需求分析3二、總體設計3三、詳細設計5四、調試與測試6五、測試結果7六、用戶手冊9七、附錄9一、需求分析每年九月份都有大量新生來到學校報道,使學校管理學生工作量增大,為此我們設計一學生信息管理系統(tǒng),學生信息包括:學號,姓名,年齡,性別,出生年月,地址,電話,E-mail等。使之能提供以下功能:(1)系統(tǒng)以菜單方式工作(2)學生信息錄入功能-輸入(3)學生信息瀏覽功能-輸出(4)查詢、排序功能-算法按學號查詢、按姓名查詢、學生信息的刪除與修改(可選項)二、總

2、體設計組成框圖主函數(shù)主菜單歡迎界面查詢按姓名按學號錄入刪除瀏覽修改退出錄入瀏覽查詢開始密碼是否正確主菜單1錄入學生信息2瀏覽學生信息3-查詢學生信息4-刪除學生信息5-修改學生信息0-退出系統(tǒng)重新輸入密碼是否正確確刪除修改退出結束流程圖NYY 開始申請新空間輸入各項數(shù)據(jù)顯示數(shù)據(jù)結束開始錄入 瀏覽指針p指向頭結點P=p-next輸出指針的數(shù)據(jù) P=NULL?NY結束查詢 修改&刪除 輸入要刪除或修改的學號輸入姓名或學號P指針的學號與輸入的是否相同P=p-nextP指針的學號與姓名是否與輸入的相同? NN Y Y輸出數(shù)據(jù) 修改p的各項數(shù)據(jù)或將p=p-next結束結束 三、詳細設計主函數(shù)通過在whi

3、le循環(huán)結構中嵌入switch分支結構實現(xiàn)操作選擇功能。(1)Record錄入函數(shù)建立一個包含學生全部信息的結構體,申請空間,其指針為p0,存入學生各項對應的數(shù)據(jù)。(2)Insert插入函數(shù):按輸入的數(shù)據(jù)存儲在一個stu類型的指針里,若原來鏈表里沒有元素,則將此作為第一個元素;若原來的鏈表里有元素,則將指向頭結點指針存儲的學號與頭指針下一個的學號大小進行比較,小的在前大的在后,之后指向頭結點處的指正后移,進行比較,直到尾結點為止。在進行比較的while函數(shù)內,每比較一次,計算總人數(shù)的TOTAL_NUM自加。(3)Display瀏覽函數(shù):將傳給Display函數(shù)的指針P所指向的結構體的各項數(shù)據(jù)輸

4、出以便核對信息。(4)DisplayAll瀏覽函數(shù):指針指向鏈表頭結點,在if語句中嵌套do-while語句將學生信息按學號從大到小進行逐一輸出。(5)Query查詢函數(shù):首先使用switch語句生成菜單,實現(xiàn)操作選擇功能。分三個部分按學號查詢、按姓名查詢和取消返回上一層。按學號查詢時調用while語句對學號檢索,再調用if語句進行判斷,最后輸出想要查詢的信息。按姓名查詢的方法跟按學號查詢的一樣。(6)Del刪除函數(shù):使用while語句進行檢索,直接刪除學生信息。(7)Change修改函數(shù):建立devise函數(shù),生成菜單,用switch語句進行分叉選擇功能,選擇項目進行相應的信息輸入。在Cha

5、nge函數(shù)中使用while語句進行檢索后再調用devise函數(shù)修改信息。實現(xiàn)學生信息修改。四、調試與測試1、進行多次運行,發(fā)現(xiàn)電話那欄的電話一打長就會顯示一樣的數(shù)字,打短的數(shù)字就可以。我們原本是使用長整型來定義電話號碼,想說空間不夠,后來改用字符型,用字符串記錄電話號碼程序運行結果正確。2、程序設計初就在考慮退出與返回有什么差別,如果返回了主菜單那退出用什么,關于這個問題看了許多網上的資料,發(fā)現(xiàn)許多程序都有exit(0)的函數(shù),所以去查了不少關于exit的函數(shù)內容,最后退出就用了exit(0),但是又提醒說要編寫exit函數(shù),之后發(fā)現(xiàn)要加入的頭文件,程序可以正常運行。3、程序在180行顯示說r

6、eadData函數(shù)不可以返回值,所以在if條件句中將return 0刪除了,不過這個程序在學校的機房即使不刪return 0也是可以運行的,關于這點很是不解,還有待解決。五、測試結果1、進入系統(tǒng)界面,輸入密碼,超過三次會自動退出。2、選1時錄入學生信息,編輯完后會繼續(xù)顯示菜單3、選2瀏覽學生信息 ,之后繼續(xù)返回菜單界面,為節(jié)省空間菜單界面暫不截圖4、選擇3查詢學生信息會有按學號與按姓名查詢。下圖是先按學號查詢的截圖。5、按姓名查詢時,如果查無此人會顯示“沒有該學生信息,請核對。”之后返回上一層,按姓名查詢。顯示學生信息后可以選擇取消返回主菜單。6、選擇4刪除學生,輸入學號刪除學生的信息。之后會

7、返回主菜單 7選擇5修改學生信息,按學號輸入,之后按顯示輸入即可。用幾組測試數(shù)據(jù)進行測試算法設計的正確性。(附上程序運行的截圖)六、用戶手冊1程序一開始會顯示歡迎界面,按要求輸入密碼,3次錯誤會退出程序。2 密碼正確后會顯示主菜單,按要求輸入您的需求。七、附錄源程序清單和結果:源程序要加注釋。結果要包括測試數(shù)據(jù)和運行結果。/* Note:Your choice is C IDE */#include #include #include #include #include #define NULL 0#define LEN sizeof(struct student)#define FILE_D

8、ATA_PATH c:student.txt struct student long int num; char name20; int age; char sex4; char birthday10; char address30; char tele_num13; char E_mail20; struct student *next;int TOTAL_NUM = 0;struct student *head = NULL;void welcome();void mainmenu();void record();void insert(struct student *stu);void

9、display(struct student *stu);void displayAll();void query();void query_by_num();void query_by_name();void readData();void writeData();void freeAll();void del();void change();void devise(struct student *p);int main() char userPWD7; int i;welcome(); for(i = 0; i 3; i+) printf(n密碼為123n); printf(n請輸入您的密

10、碼:); scanf(%s, userPWD); if (strcmp(userPWD,123)=0) /密碼正確,顯示主菜單 mainmenu(); break; else if (i num); printf(請輸入學生的姓名:); scanf(%s,p0-name); printf(請輸入學生的年齡:); scanf(%d,&p0-age); printf(請輸入學生的性別:); scanf(%s,p0-sex); printf(請輸入學生的出生年月:); scanf(%s,p0-birthday); printf(請輸入學生的地址:); scanf(%s,p0-address); pr

11、intf(請輸入學生的電話:); scanf(%s,p0-tele_num); printf(請輸入學生的E-mail:); scanf(%s,p0-E_mail); insert(p0); printf(該學生的信息為:n); printf(); printf(學號t姓名t年齡t性別t出生年月tt地址t電話tE-mailn); display(p0);void insert(struct student *stu)/根據(jù)學號對學生進行排序/ struct student *p0, *p1, *p2; p1 = head; p0 = stu; if(head = NULL) head = p0

12、; p0-next = NULL; else while(p0-num p1-num)&(p1-next != NULL) p2 = p1; p1 = p1-next; if(p0-num num) if(head = p1) head = p0; else p2-next = p0; p0-next = p1; else p1-next = p0; p0-next = NULL; TOTAL_NUM+;void display(struct student *p) printf(%ldt%st%dt%st%st%st%st%sn, p-num, p-name, p-age, p-sex, p

13、-birthday, p-address, p-tele_num, p-E_mail);/瀏覽學生信息void displayAll() struct student *p; printf(學生總數(shù):%dn, TOTAL_NUM); p = head; if(head != NULL) printf(n學號t姓名t年齡t性別t出生年月t地址t電話tE-mailn); printf(); do display(p); p = p-next; while(p != NULL); printf(n);/查詢學生信息void query() int choice; choice = -1; do pr

14、intf(n); printf(+-+n); printf(| 按學號查詢 請按 1 |n); printf(| 按姓名查詢 請按 2 |n); printf(| 取消 請按 0 |n); printf(+-+n); printf(請輸入您的選擇:); scanf(%d, &choice); switch(choice) case 0: return; case 1:query_by_num();break; case 2:query_by_name(); break; default: printf(n無效選項!);break; while(choice != 0);/按學號查詢學生信息vo

15、id query_by_num() int num; struct student *p1; printf(請輸入學生的學號:); scanf(%ld, &num); if(head=NULL) printf(無學生記錄!n); return; p1=head; while(num!=p1-num & p1-next!=NULL) p1=p1-next; if(num = p1-num) printf(n學號t姓名t年齡t性別t出生年月t地址t電話tE-mailn); printf(); display(p1); else printf(沒有該學生記錄,請核對!);/按姓名查詢學生信息void

16、 query_by_name() char name20; struct student *p1; printf(請輸入學生的姓名:); scanf(%s, name); if(head=NULL) printf(無學生記錄!n); return; p1=head; while(strcmp(name, p1-name) & p1-next!=NULL) p1=p1-next; if(!strcmp(name, p1-name) printf(n學號t姓名t年齡t性別t出生年月t地址t電話tE-mailn); printf(); display(p1); else printf(沒有該學生記錄

17、,請核對!);/寫入文件void writeData() FILE* fp;/文件指針 struct student *p; fp = fopen(FILE_DATA_PATH, w); if (!fp) printf(文件打開錯誤!); return; fprintf(fp,%dn, TOTAL_NUM); for(p = head; p!= NULL; p= p-next) fprintf(fp,%ldt%st%dt%st%st%st%st%sn, p-num, p-name, p-age, p-sex, p-birthday, p-address, p-tele_num, p-E_mai

18、l); fclose(fp); void freeAll() struct student *p1, *p2; p1=p2=head; while(p1) p2=p1-next; free(p1); p1=p2; /讀取文件void readData() FILE* fp;/文件指針 struct student *p1, *p2; fp = fopen(FILE_DATA_PATH, r); if (!fp) printf(文件打開錯誤!); fscanf(fp,%dn, &TOTAL_NUM); head = p1 = p2 = (struct student *)malloc(LEN);

19、 fscanf(fp,%ldt%st%dt%st%st%st%st%sn, &p1-num, p1-name, &p1-age, p1-sex, p1-birthday, p1-address, &p1-tele_num, p1-E_mail); while(!feof(fp) p1 = (struct student *)malloc(LEN); fscanf(fp,%ldt%st%dt%st%st%st%st%sn, &p1-num, p1-name, &p1-age, p1-sex, p1-birthday, p1-address, &p1-tele_num, p1-E_mail); p

20、2-next = p1; p2 = p1; p2-next = NULL; fclose(fp);/刪除學生信息void del() struct student *p1, *p2; long int num; if(head = NULL) printf(無學生記錄!n); return; printf(請輸入您要刪除的學生的學號:); scanf(%ld, &num); p1 = head; while(num != p1-num & p1-next != NULL) p2=p1; p1=p1-next; if(num=p1-num) if(p1=head) head=p1-next; e

21、lse p2-next=p1-next; free(p1); TOTAL_NUM-; else printf(沒有該學生記錄,請核對!n);/修改學生信息void change() struct student *p1, *p2; long int num; if(head = NULL) printf(無學生記錄!n); return; printf(請輸入您要修改的學生的學號:); scanf(%ld, &num); p1=head; while(num !=p1-num & p1-next != NULL) p2=p1; p1=p1-next; if(num=p1-num) devise(p1); else printf(沒有該學生記錄,請核對!n);void devise(struct student *p) int choice; choice=-1; do printf(請選擇您要修改的學生的信

溫馨提示

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

評論

0/150

提交評論