歡迎來到裝配圖網(wǎng)! | 幫助中心 裝配圖網(wǎng)zhuangpeitu.com!
裝配圖網(wǎng)
ImageVerifierCode 換一換
首頁 裝配圖網(wǎng) > 資源分類 > DOC文檔下載  

程序設(shè)計語言課程設(shè)計-通訊錄.doc

  • 資源ID:116825775       資源大?。?span id="7nsnwmm" class="font-tahoma">103.50KB        全文頁數(shù):16頁
  • 資源格式: DOC        下載積分:20積分
快捷下載 游客一鍵下載
會員登錄下載
微信登錄下載
三方登錄下載: 微信開放平臺登錄 支付寶登錄   QQ登錄   微博登錄  
二維碼
微信掃一掃登錄
下載資源需要20積分
郵箱/手機:
溫馨提示:
用戶名和密碼都是您填寫的郵箱或者手機號,方便查詢和重復下載(系統(tǒng)自動生成)
支付方式: 支付寶    微信支付   
驗證碼:   換一換

 
賬號:
密碼:
驗證碼:   換一換
  忘記密碼?
    
友情提示
2、PDF文件下載后,可能會被瀏覽器默認打開,此種情況可以點擊瀏覽器菜單,保存網(wǎng)頁到桌面,就可以正常下載了。
3、本站不支持迅雷下載,請使用電腦自帶的IE瀏覽器,或者360瀏覽器、谷歌瀏覽器下載即可。
4、本站資源下載后的文檔和圖紙-無水印,預覽文檔經(jīng)過壓縮,下載后原文更清晰。
5、試題試卷類文檔,如果標題沒有明確說明有答案則都視為沒有答案,請知曉。

程序設(shè)計語言課程設(shè)計-通訊錄.doc

課程設(shè)計文檔課程名稱: 程序設(shè)計語言課程設(shè)計 設(shè)計題目 : 通訊錄 一、 文檔的結(jié)構(gòu)(1).課程設(shè)計目的和要求:通訊錄1. 添加2. 查詢3. 刪除4. 修改5. 排序6. 輸出全部信息7. 寫入文件8. 讀取文件0. 退出程序的主界面1. 設(shè)計要求:基本功能:a) 添加個人信息b) 查詢個人信息c) 刪除個人信息d) 修改個人信息e) 信息排序f) 輸出全部信息 拓展功能: 采用文件形式對通訊錄進行操作,包括:a) 寫入文件b) 讀取文件 創(chuàng)新(自擬)功能:程序?qū)崿F(xiàn)的其它功能由個人自擬。2. 設(shè)計要求具體說明通訊錄至少應(yīng)該有以下數(shù)據(jù)項:姓名,家庭住址,手機號碼,郵編,E-mail。輸入信息時要檢查數(shù)據(jù)項手機、郵編、E-mail的合法性,手機號碼:11位數(shù)字;郵編:6位數(shù)字;E-mail:包含字符,且兩邊都非空。對通訊錄應(yīng)該包含有以下操作(包括基本功能和拓展功能):a) 向通訊錄中添加信息;b) 在通訊錄中按姓名或手機號查找個人信息;c) 刪除通訊錄中的個人信息;d) 修改通訊錄中的個人信息,并保存入文件;e) 按不同數(shù)據(jù)項排序后列表輸出通訊錄中所有人的信息。通訊錄中記錄的數(shù)量沒有限制。f) 將通訊錄中的數(shù)據(jù)寫入文件和從文件讀入數(shù)據(jù)。程序啟動時先從文件讀入數(shù)據(jù),如果文件中沒有數(shù)據(jù)則給出提示;寫入文件時有兩種方式,一為覆蓋所有原有的內(nèi)容; 二為只將本次操作所修改的個人信息寫入文件g) 程序啟動時先從文件讀入數(shù)據(jù),如果文件中沒有數(shù)據(jù)則給出提示退出程序。(2).課程設(shè)計任務(wù)內(nèi)容;本程序分成讀取,排序,寫入等十個部分。其中排序分為按姓名排序和按序號排序。其他模塊如其名稱所示,功能分別為:讀取,排序,寫入,插入,刪除,查詢,修改,保存,拷貝,退出。(程序結(jié)構(gòu)功能如圖1所示)數(shù)據(jù)項:姓名,家庭住址,手機號碼,郵編,E-mail。對通訊錄應(yīng)該包含有以下操作(包括基本功能和拓展功能):h) 向通訊錄中添加信息;i) 在通訊錄中按姓名或手機號查找個人信息;j) 刪除通訊錄中的個人信息;k) 修改通訊錄中的個人信息,并保存入文件;l) 按不同數(shù)據(jù)項排序后列表輸出通訊錄中所有人的信息。通訊錄中記錄的數(shù)量沒有限制。m) 將通訊錄中的數(shù)據(jù)寫入文件和從文件讀入數(shù)據(jù)。(3).詳細設(shè)計說明;通訊錄讀取排序?qū)懭氩迦雱h除查詢修改保存拷貝退出圖1圖1程序結(jié)構(gòu)功能程序(標識符)設(shè)計說明 寫入編號姓名性別電話生日郵編地址圖21 寫入模塊:寫入模塊下包括編號,姓名等七個模塊。由用戶輸入信息。(模塊圖如圖2所示)Y寫入輸入編號,姓名,性別,電話,生日,郵編,地址是否繼續(xù)退出N2 讀取模塊:輸出由先前用戶輸入全部的信息。3排序模塊:將先前用戶所輸入的信息進行排序,有按姓名進行排序和按序號進行排序兩種選擇。排序輸入1.按姓名2.按序號3.返回按姓名進行排序按序號進行排序1.按姓名2.按序號3返回結(jié)束主菜單4插入模塊:在已有的信息中插入新的信息。5刪除模塊:將已輸入的信息進行刪除。6查詢模塊:查找已輸入信息。查詢輸入姓名是否存在輸出結(jié)束是否7修改模塊:將已有的信息進行修改并保存。修改輸入修改學生序號輸出新資料結(jié)束處理符合YN 8保存即讀入模塊:將用戶所輸入的信息進行保存。9拷貝模塊:將用戶所輸入的信息進行有選擇性的拷貝復制。10退出模塊:即退出程序。 (4).軟件使用說明;此軟件有讀取,排序,寫入,插入,刪除,查詢,修改,保存,拷貝,退出時項功能。可以將用戶輸入的信息進行兩種排序,并且可以進行修改,刪除,拷貝等。而且根據(jù)姓名進行查找和刪除。并將用戶所輸入的信息進行保存。(5).課程設(shè)計總結(jié);經(jīng)過這兩個星期的課程設(shè)計讓我對C語言有了一個更深的了解,雖然我現(xiàn)在不能夠熟練的掌握無法在短時間內(nèi)編成一個完美的程序,但是通過看資料,查詢相關(guān)信息以及和同學們的討論還是可以進一步的完善自己的知識,對C語言有個進一步的了解。這兩個星期以來的學習,編程中遇到了不少問題,尤其是在排序這一塊,遇到了不少問題,無法順利進行。終于在和同學們一起努力以及問老師終于將問題解決了。兩個星期的學習讓我受益匪淺,這兩星期讓我過的很充實。附錄1 參考文獻參考文獻1譚浩強. C程序設(shè)計(第三版) . 北京:清華大學出版社, 2005 2譚浩強. C程序設(shè)計題解與上機指導(第三版) . 北京:清華大學出版社, 20053 Herbert Schildt. C語言大全(第四版). 北京:電子工業(yè)出版社, 20044Samuel P.Harbison ,Guy L.Steele. C語言參考手冊(第5版). 北京:機械工業(yè)出版社,2003 5張建勛. C語言程序設(shè)計教程. 北京:清華大學出版社, 2008.26崔武子. C程序設(shè)計教程(第2版). 北京:清華大學出版社, 2007.6(第2版)1. 附錄2 程序清單(有較詳細的注釋)/-#include stdlib.h#include string.h#include conio.h #include stdio.h#include dos.h /-FILE *fp;int i;struct address int inumber; /編碼char postnum7; /郵編 char a40; /家庭地址;struct ffriend int num; /序號char name20; /姓名 char tmp50; char emil30; /郵箱 char telephone12; /電話號碼 struct address address;struct record; friends50; /-void Load() int j;long k;fp=fopen(friend.txt,a+); /打開文件friend.txt if(fp!=NULL) for(i=1;i50;i+) j=fgetc(fp);if(j=EOF) /判斷是否到了文件尾return;k=i-1;fseek(fp,k*sizeof(struct ffriend),SEEK_SET);fread(&friendsi,sizeof(struct ffriend),1,fp); /從文件中讀取一條記錄else fp=fopen(friend.txt,w);i=1;/-void Show(int j) /顯示 / friendsj.num=i;printf(nnt編號-Nnumber: %3d,friendsj.num);printf(nt姓名-Name:%-20s,friendsj.name);printf(nt手機號-Telephone:%-13s,friendsj.telephone);printf(nt郵編-Postnum:%-10s,friendsj.address.postnum);printf(nt通信地址-address:%-40s,friendsj.address.a);printf(nt郵件-emil:%-10s,friendsj.emil); /-void Copy() /拷貝 int j,num1; char name120,telephone112,a140,postnum17,emil130; printf(輸入拷貝的序號:);scanf(%d,&j); if(0j&j=i)void Append(int j); num1=i+1;strcpy(name1,friendsj.name); strcpy(telephone1,friendsj.telephone); strcpy(postnum1,friendsj.address.postnum);strcpy(a1,friendsj.address.a);strcpy(emil1,friendsj.emil);printf(n已經(jīng)拷貝編號為%d的通訊錄n,num1);printf(n按回車鍵回到主菜單.); getchar(); getchar(); return ; elseprintf(輸入序號不合適!); /- void listbyname()/按姓名排序 int j;for (j=1;ji;j+) if(strcmp(friendsj.name,friendsj+1.name)0) printf(nt排序為:);printf(nnt編號-Nnumber: %3d,friendsj.num);printf(nt姓名-Name:%-20s,friendsj.name);printf(nt手機號-Telephone:%-13s,friendsj.telephone);printf(nt郵編-Postnum:%-10s,friendsj.address.postnum);printf(nt通信地址-address:%-40s,friendsj.address.a);printf(nt郵件-emil:%-10s,friendsj.emil); printf(nnt編號-Nnumber: %3d,friendsj+1.num);printf(nt姓名-Name:%-20s,friendsj+1.name);printf(nt手機號-Telephone:%-13s,friendsj+1.telephone);printf(nt郵編-Postnum:%-10s,friendsj+1.address.postnum);printf(nt通信地址-address:%-40s,friendsj+1.address.a);printf(nt郵件-emil:%-10s,friendsj+1.emil); else if(strcmp(friendsj.name,friendsj+1.name)=0)printf(nt排序為:);printf(nnt編號-Nnumber: %3d,friendsj.num);printf(nt姓名-Name:%-20s,friendsj.name);printf(nt手機號-Telephone:%-13s,friendsj.telephone);printf(nt郵編-Postnum:%-10s,friendsj.address.postnum);printf(nt通信地址-address:%-40s,friendsj.address.a);printf(nt郵件-emil:%-10s,friendsj.emil); printf(nnt編號-Nnumber: %3d,friendsj+1.num);printf(nt姓名-Name:%-20s,friendsj+1.name);printf(nt手機號-Telephone:%-13s,friendsj+1.telephone);printf(nt郵編-Postnum:%-10s,friendsj+1.address.postnum);printf(nt通信地址-address:%-40s,friendsj+1.address.a);printf(nt郵件-emil:%-10s,friendsj+1.emil); elseprintf(nt排序為:);printf(nnt編號-Nnumber: %3d,friendsj+1.num);printf(nt姓名-Name:%-20s,friendsj+1.name);printf(nt手機號-Telephone:%-13s,friendsj+1.telephone);printf(nt郵編-Postnum:%-10s,friendsj+1.address.postnum);printf(nt通信地址-address:%-40s,friendsj+1.address.a);printf(nt郵件-emil:%-10s,friendsj+1.emil);printf(nt排序為:n);printf(nnt編號-Nnumber: %3d,friendsj.num);printf(nt姓名-Name:%-20s,friendsj.name);printf(nt手機號-Telephone:%-13s,friendsj.telephone);printf(nt郵編-Postnum:%-10s,friendsj.address.postnum);printf(nt通信地址-address:%-40s,friendsj.address.a);printf(nt郵件-emil:%-10s,friendsj.emil); /-void listbyid()/按序號排序 int j; for (j=1;j=i;j+) if(friendsj.numfriendsj+1.num) printf(nt排序為:);printf(nnt編號-Nnumber: %3d,friendsj.num);printf(nt姓名-Name:%-20s,friendsj.name);printf(nt手機號-Telephone:%-13s,friendsj.telephone);printf(nt郵編-Postnum:%-10s,friendsj.address.postnum);printf(nt通信地址-address:%-40s,friendsj.address.a);printf(nt郵件-emil:%-10s,friendsj.emil); printf(nnt編號-Nnumber: %3d,friendsj+1.num);printf(nt姓名-Name:%-20s,friendsj+1.name);printf(nt手機號-Telephone:%-13s,friendsj+1.telephone);printf(nt郵編-Postnum:%-10s,friendsj+1.address.postnum);printf(nt通信地址-address:%-40s,friendsj+1.address.a);printf(nt郵件-emil:%-10s,friendsj+1.emil); elseprintf(nt排序為:);printf(nnt編號-Nnumber: %3d,friendsj+1.num);printf(nt姓名-Name:%-20s,friendsj+1.name);printf(nt手機號-Telephone:%-13s,friendsj+1.telephone);printf(nt郵編-Postnum:%-10s,friendsj+1.address.postnum);printf(nt通信地址-address:%-40s,friendsj+1.address.a);printf(nt郵件-emil:%-10s,friendsj+1.emil);printf(排序為:n);printf(nnt編號-Nnumber: %3d,friendsj.num);printf(nt姓名-Name:%-20s,friendsj.name);printf(nt手機號-Telephone:%-13s,friendsj.telephone);printf(nt郵編-Postnum:%-10s,friendsj.address.postnum);printf(nt通信地址-address:%-40s,friendsj.address.a);printf(nt郵件-emil:%-10s,friendsj.emil); /-void Append(int j) int x,n=0; char *p,*q,*r;fflush(stdin); friendsj.num=j;printf(nttt序號-Number:%d,j);printf(nttt姓名-Name:); scanf(%s,friendsj.name);fflush(stdin); printf(ttt聯(lián)系電話-telephone:); scanf(%s,friendsj.telephone);p=friendsj.telephone; for(x=0;x=0&px=9) ; else printf(輸入的手機號不合理,請重新輸入:); scanf(%s,friendsj.telephone); printf(ttt郵編-Postnumber:); scanf(%d,friendsj.address.postnum);q=friendsj.address.postnum; for(x=0;x=0&qx=9) ; else printf(輸入的郵編不合理,請重新輸入:); scanf(%s,friendsj.address.postnum); printf(ttt通信地址-Address:); scanf(%s,friendsj.address.a);printf(ttt郵件-Emil:);scanf(%s,&friendsj.emil);r=friendsj.emil; for(x=0;rx!=0;x+) /*判斷是否包含且兩邊非空*/ if(rx=) n+; if(n!=1) printf(輸入的郵編不合理,請重新輸入:); scanf(%s,friendsj.emil);/-void Delete() /刪除 int k;printf(ntDelete 序號-Number:); /輸出刪除序號 scanf(%d,&k);if(k=i)for(int j=k;ji+1;j+) /插入位置后的元素順序后移strcpy(friendsj.name,friendsj+1.name); /交換元素內(nèi)容friendsj.telephone=friendsj+1.telephone;friendsj.address.postnum=friendsj+1.address.postnum;strcpy(friendsj.address.a,friendsj+1.address.a);strcpy(friendsj.emil,friendsj+1.emil);i-; elseprintf(輸入的序號太大!); /-void Modify(int j) Append(j);/-void Save() int j;fp=fopen(friend.txt,w);for(j=1;j=i;j+) fwrite(&friendsj,sizeof(struct ffriend),1,fp);fclose(fp);/-void main()int j,num;char grade;char searchname10;Load();i-;do printf(tttt簡易通訊錄nn);printf(tt*n); printf(tt* 功能選擇(Function choose) *n);printf(tt* 1 1.讀取(Read) *n);printf(tt* 2 2.排序(List) *n);printf(tt* 6 3.寫入(Append) *n);printf(tt* 3 4.插入(Insert) *n);printf(tt* 4 5.刪除(Delete) *n);printf(tt* 5 6.查詢(Search) *n);printf(tt* 6 7.修改(Modify) *n);printf(tt* 2 8.保存(Save) *n);printf(tt* 3 9.拷貝(Copy) *n);printf(tt* 1 0.退出(Quit) *n);printf(tt*n); printf(tt請選擇(Choice)ntt注:輸入09:);scanf(%s,&grade); switch(grade) case 1: j=1; /讀取功能 while(getchar()!=0 x1b&j=i) Show(j+);printf(n請按回車鍵繼續(xù)!);if(j-11)printf(nt空文檔,無任何記錄-Empty Noten);printf(n請按回車鍵繼續(xù)!);getchar();printf(nttttttt此次操作結(jié)束);printf(nt-ttn);break;case 2: /排序功能 char grade; if(i=0) printf(ntt對不起,文件中無任何紀錄); printf(ntt按任意鍵返回主菜單); getchar(); system(cls); printf(nt*); printf(nt* 1.按序號排序 *);printf(nt* 2.按姓名排序 *);printf(nt* 3.返回主菜單 *); printf(nt*); printf(nt請選擇(Choice)nt注:輸入13:); scanf(%s,&grade);switch(grade) case 1:listbyid();printf(nt-ttn);main();break; case 2:listbyname();printf(nt-ttn);main();break; case 3:main();break;default :printf(ntt輸入有誤,請輸入正確的選擇!);printf(nt-ttn);main(); case 3: /寫入功能while(ik;j-) strcpy(friendsj.name,friendsj-1.name); /數(shù)據(jù)后移friendsj.telephone=friendsj-1.telephone;friendsj.address.postnum=friendsj-1.address.postnum;strcpy(friendsj.address.a,friendsj-1.address.a);strcpy(friendsj.emil,friendsj-1.emil);Append(k);i+; printf(nttttttt此次操作結(jié)束);printf(nt-ttn);break; case 5: /刪除功能 /增添隨意刪除多條記錄的功能Delete();printf(tt已刪除!); if(i1)printf(ntt沒有記錄-No recordsn);printf(ntt請按回車鍵繼續(xù)!);getchar();getchar(); printf(nttttttt此次操作結(jié)束);printf(nt-ttn);break;case 6: /查詢功能 printf(nt請輸入要查詢記錄的相關(guān)姓名:); /增添查詢按列號的scanf(%s,searchname);for(j=1;j=i;j+)if(strcmp(searchname,friendsj.name)=0) /比較字符串 Show(j); break;if(i1) printf(n 沒有您所查詢的記錄-No records);printf(n 請按回車鍵繼續(xù)!);getchar();printf(nttttttt此次操作結(jié)束);printf(nt-ttn);getchar();break;case 7: /修改功能 /增添按序列號查詢printf(nt請輸入要修改記錄的相關(guān)姓名:);gets(searchname);scanf(%s,searchname);for(j=1;j=i;j+)if(strcmp(searchname,friendsj.name)=0) /比較字符串 Modify(j); / getchar(); /加個輸出確定修改嗎if(ii)printf(輸入的序號太大!);elseCopy();Save();getchar(); break; case 0: /退出功能char x;printf(是否保存?yes/no:);scanf(%s,&x);/getchar();/ getchar();if(x=y) Save();exit(0);elseexit(0);default: printf(nt輸入有誤,請輸入正確的序列號!);printf(n請按回車鍵繼續(xù)!);getchar();printf(nttttttt此次操作結(jié)束);printf(nt-ttn);while(1);/-

注意事項

本文(程序設(shè)計語言課程設(shè)計-通訊錄.doc)為本站會員(good****022)主動上傳,裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。 若此文所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng)(點擊聯(lián)系客服),我們立即給予刪除!

溫馨提示:如果因為網(wǎng)速或其他原因下載失敗請重新下載,重復下載不扣分。




關(guān)于我們 - 網(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ù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!