九九热最新网址,777奇米四色米奇影院在线播放,国产精品18久久久久久久久久,中文有码视频,亚洲一区在线免费观看,国产91精品在线,婷婷丁香六月天

程序設計基礎課程設計報告c語言實現(xiàn)附源碼員工工資管理系統(tǒng)

上傳人:仙*** 文檔編號:37005449 上傳時間:2021-11-01 格式:DOC 頁數(shù):34 大小:256KB
收藏 版權申訴 舉報 下載
程序設計基礎課程設計報告c語言實現(xiàn)附源碼員工工資管理系統(tǒng)_第1頁
第1頁 / 共34頁
程序設計基礎課程設計報告c語言實現(xiàn)附源碼員工工資管理系統(tǒng)_第2頁
第2頁 / 共34頁
程序設計基礎課程設計報告c語言實現(xiàn)附源碼員工工資管理系統(tǒng)_第3頁
第3頁 / 共34頁

下載文檔到電腦,查找使用更方便

0 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《程序設計基礎課程設計報告c語言實現(xiàn)附源碼員工工資管理系統(tǒng)》由會員分享,可在線閱讀,更多相關《程序設計基礎課程設計報告c語言實現(xiàn)附源碼員工工資管理系統(tǒng)(34頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、程序設計基礎課程設計報告題 目: 員工工資管理系統(tǒng) 院 (系): 信息科學與工程學院 專業(yè)班級: 學生姓名: 學 號: 指導教師: 20 16 年 12 月 12 日至20 16 年 12 月 23 日武昌首義學院制 程序設計基礎 課程設計任務書一、設計(調(diào)查報告/論文)題目員工工資管理系統(tǒng)二、設計(調(diào)查報告/論文)主要內(nèi)容1.員工工資管理系統(tǒng)主要內(nèi)容:設計一個利用文件處理方式實現(xiàn)對員工工資(包括員工編號、員工姓名、應發(fā)、扣款和實發(fā))進行管理,具有增加數(shù)據(jù)、更新數(shù)據(jù)、查詢數(shù)據(jù)、刪除數(shù)據(jù)、列表顯示數(shù)據(jù)以及重組文件的功能。員工工資管理系統(tǒng)由六大功能模塊組成:增加數(shù)據(jù)該模塊完成將輸入的數(shù)據(jù)存入數(shù)據(jù)文

2、件中,用戶一次可輸入多個員工的信息。更新數(shù)據(jù)該模塊用于實現(xiàn)對記錄的修改,首先用戶輸入員工的編號,然后查詢該員工的信息,最后更新該員工的信息。查詢數(shù)據(jù)該模塊可選擇按員工編號查詢,或者按員工姓名進行查詢,然后列出滿足條件的且未作刪除標記的員工信息。刪除數(shù)據(jù)該模塊用于刪除指定編號的員工工資信息,為提高效率,只作刪除標記,不在物理上刪除信息,可稱為邏輯刪除。顯示數(shù)據(jù)該模塊用于以列表方式顯示所有未作刪除標記的員工信息。重組文件當邏輯刪除的信息太多時,將會降低查詢效率。重組文件模塊專門用于在物理上刪除作有刪除標記的信息,這樣不但提高查詢效率,同時也節(jié)約存儲空間。統(tǒng)計輸出輸出實發(fā)工資最高的員工工資信息。統(tǒng)計

3、輸出員工實發(fā)工資的平均工資。統(tǒng)計輸出超過實發(fā)平均工資的員工人數(shù)。 排序該模塊按員工實發(fā)工資由高到低的順序排序輸出所有員工信息。要求本系統(tǒng)采用結(jié)構(gòu)體等數(shù)據(jù)結(jié)構(gòu)。系統(tǒng)以菜單方式工作。2.學生學籍管理系統(tǒng)主要內(nèi)容:設計一個利用文件處理方式,實現(xiàn)對學生學籍信息(包括:學號,姓名,性別,年齡,籍貫,系別,專業(yè),班級)進行添加、修改、刪除、查找、統(tǒng)計輸出等操作。學生學籍管理系統(tǒng)的功能要求如下:增加數(shù)據(jù)該模塊完成將輸入的數(shù)據(jù)存入數(shù)據(jù)文件中,用戶一次可輸入多個學生的學籍信息。更新數(shù)據(jù)該模塊用于實現(xiàn)對記錄的修改,首先用戶輸入學生的學號,然后查詢該學生的學籍信息,最后更新該學生的學籍的信息。查詢數(shù)據(jù)該模塊可選擇按

4、學生的學號查詢,或者按學生的姓名查詢,再或者按學生的班級查詢,然后列出滿足條件的且未作刪除標記的學生學籍信息。刪除數(shù)據(jù)該模塊用于刪除指定編號的學生學籍信息,為提高效率,只作刪除標記,不在物理上刪除信息,可稱為邏輯刪除。顯示數(shù)據(jù)該模塊用于以列表方式顯示所有未作刪除標記的學生學籍信息。重組文件當邏輯刪除的信息太多時,將會降低查詢效率。重組文件模塊專門用于在物理上刪除作有刪除標記的信息,這樣不但提高查詢效率,同時也節(jié)約存儲空間。統(tǒng)計輸出1)按專業(yè)輸出所有學生的學籍信息。2)統(tǒng)計輸出學生的平均年齡。3)統(tǒng)計輸出超過平均年齡的學生人數(shù)。 排序該模塊按學生學號由低到高的順序排序輸出所有學生學籍信息。要求本

5、系統(tǒng)采用結(jié)構(gòu)體等數(shù)據(jù)結(jié)構(gòu)。系統(tǒng)以菜單方式工作。3.班級成績管理系統(tǒng)主要內(nèi)容:對一個有N個學生的班級,每個學生有M門課程。每個學生應當包括如下信息:學號、姓名、M門課程名稱。該系統(tǒng)實現(xiàn)對班級成績的添加、修改、刪除、查找、統(tǒng)計輸出等操作的管理。功能要求如下:增加數(shù)據(jù)該模塊完成將輸入的數(shù)據(jù)存入數(shù)據(jù)文件中,用戶一次可輸入多個學生的基本信息。更新數(shù)據(jù)該模塊用于實現(xiàn)對記錄的修改,首先用戶輸入學生的學號,然后查詢該學生的基本信息,最后更新該學生的基本信息。查詢數(shù)據(jù)該模塊可選擇按學生的學號查詢,或者按學生的姓名查詢,然后列出滿足條件的且未作刪除標記的學生基本信息。刪除數(shù)據(jù)該模塊用于刪除指定編號的學生基本信息,

6、為提高效率,只作刪除標記,不在物理上刪除信息,可稱為邏輯刪除。顯示數(shù)據(jù)該模塊用于以列表方式顯示所有未作刪除標記的學生基本信息。重組文件當邏輯刪除的信息太多時,將會降低查詢效率。重組文件模塊專門用于在物理上刪除作有刪除標記的信息,這樣不但提高查詢效率,同時也節(jié)約存儲空間。統(tǒng)計輸出1)顯示每門課程成績最高的學生的基本信息。2)顯示每門課程的平均成績。3)顯示超過某門課程平均成績的學生人數(shù)。 排序該模塊按學生學號由低到高的順序排序輸出所有學生的基本信息。要求本系統(tǒng)采用結(jié)構(gòu)體等數(shù)據(jù)結(jié)構(gòu)。系統(tǒng)以菜單方式工作。課程設計要求:課程設計從第一、二和三道題中選一道題完成。其中,學號尾數(shù)為0、2、4、8的做第一道

7、題;學號尾數(shù)為1、3、7的做第二道題;學號尾數(shù)為5、6、9的做第三道題。系統(tǒng)要求在Microsoft Visual C+ 6.0編譯平臺上采用C語言編程實現(xiàn)。 課程設計報告(要求正規(guī)打印,A4幅面),內(nèi)容包括:l 題目l 需求與總體設計(描述系統(tǒng)要實現(xiàn)什么功能;系統(tǒng)怎么實現(xiàn),繪制系統(tǒng)功能模塊結(jié)構(gòu)圖;數(shù)據(jù)結(jié)構(gòu)的設計及用法說明)l 詳細設計(描述系統(tǒng)包含的主函數(shù)和子函數(shù);解釋各個功能模塊的軟件功能;畫系統(tǒng)的總體流程圖,某種查詢、插入、刪除程序?qū)崿F(xiàn)的子函數(shù)流程圖,要求采用標準流程圖圖符至少畫兩個流程圖)l 編碼與實現(xiàn)(只能使用C語言,源程序編寫格式要按照縮進方式,源程序要有詳細的注釋,使程序容易閱讀

8、。源程序編寫格式的規(guī)范和注釋體現(xiàn)程序員的素質(zhì),必須從本課程設計開始培養(yǎng)。)l 運行結(jié)果(包括輸入數(shù)據(jù)的結(jié)果,查詢、修改、刪除的結(jié)果,可以將輸出的結(jié)果以截屏方式呈現(xiàn)到課程設計報告中)l 總結(jié)(必須真實的說出自己在課程設計中的切身體會。例如:課程設計如何構(gòu)思、如何設計、如何編程、如何調(diào)試、遇到的主要問題和解決方法,哪些地方使你“痛苦不堪”;創(chuàng)新之處;課程設計中存在的不足,需進一步改進的設想等等。)注:每人以班級+學號+姓名創(chuàng)建目錄,目錄需包括課程設計報告電子文檔和源程序以備檢查。然后由各班學習委員匯總到U盤上統(tǒng)一提交。三、原始資料1.游洪躍,彭駿,譚斌C語言程序設計實驗與課程設計教程北京:清華大學

9、出版社,20112.孫承愛,趙衛(wèi)東程序設計基礎基于C語言(第2版)科學出版社,2010四、要求的設計(調(diào)查/論文)成果1.課程設計報告2.課程設計軟件五、進程安排布置任務,查找資料、需求分析1天總體設計1天詳細設計1天編制源程序?qū)崿F(xiàn)3天測試與修改1天撰寫課程設計報告2天六、主要參考資料1 譚浩強C程序設計第四版清華大學出版社,20102 蘇小紅C語言大學實用教程第2版電子工業(yè)出版社,2008指導教師(簽名):年 月 日 目 錄1需求與總體設計12詳細設計13編碼實現(xiàn)44運行結(jié)果21總結(jié)241需求與總體設計1.1需求描述 設計一個利用文件處理方式實現(xiàn)對員工工資(包括員工編號、員工姓名、年月、崗位

10、工資、獎金、扣款和實發(fā))進行管理,具有增加數(shù)據(jù)、更新數(shù)據(jù)、查詢數(shù)據(jù)、刪除數(shù)據(jù)、列表顯示數(shù)據(jù)以及重組文件的功能。1.2總體設計先以登陸函數(shù)登陸,再進入主菜單,菜單中顯示各個要實現(xiàn)的操作,以菜單將各個函數(shù)聯(lián)系起來,對菜單操作以實現(xiàn)系統(tǒng)的目的。1.3數(shù)據(jù)結(jié)構(gòu)struct user /登陸者信息char un10;char up10;us3 = aaa,111,bbb,222,ccc,333 ;struct yg /員工結(jié)構(gòu)體short zt; /數(shù)據(jù)狀態(tài)long bh; /編號char name20; /名字char time11; /時間long money; /基本工資long jj; /獎金l

11、ong kk; /扣款long sf; /實發(fā)工資;整個程序只運用了結(jié)構(gòu)體的數(shù)據(jù)結(jié)構(gòu),結(jié)構(gòu)體運用于登陸者信息和員工信息,將員工信息封裝在一個結(jié)構(gòu)體里,再創(chuàng)建結(jié)構(gòu)體數(shù)組,將多個員工信息儲存在結(jié)構(gòu)體數(shù)組中。2詳細設計2.1 系統(tǒng)功能設計主函數(shù)和子函數(shù):系統(tǒng)包含一個主函數(shù),和子函數(shù),分別有登陸子函數(shù),菜單子函數(shù),增加數(shù)據(jù)子函數(shù),更新數(shù)據(jù)子函數(shù),查詢數(shù)據(jù)子函數(shù),刪除數(shù)據(jù)子函數(shù),統(tǒng)計數(shù)據(jù)子函數(shù),重組文件子函數(shù),排序數(shù)據(jù)子函數(shù),最后兩個分別是讀取文件和寫入文件子函數(shù)。各個函數(shù)的功能:主函數(shù)是一個入口程序從這里進入,再進入登陸函數(shù),實現(xiàn)登陸操作。登陸函數(shù),只有擁有正確賬號密碼,正確的操作才可以進入菜單界面進

12、行下一步的操作,并且輸入錯誤三次后將會提示并強制退出。菜單界面利用switch()函數(shù)將各個函數(shù)聯(lián)系起來實現(xiàn)真正的菜單,輸入正確的序號可以進行后續(xù)的各個操作。讀取函數(shù),將特定文件中的信息,以特定的方式讀取到正在運行的程序中,實現(xiàn)讀寫操作。寫入函數(shù),在添加、更新、刪除、重組操作過后進行寫入操作,將變換后的數(shù)據(jù)重新寫入文件中。注:每次寫入都是將程序中的所有數(shù)據(jù)重新寫入文件。增加函數(shù),可以新添員工,并將員工的數(shù)據(jù)輸入,并利用寫入函數(shù),寫入文件中。在增加后會提示是否繼續(xù)增加,提供了方便。并且如果原數(shù)據(jù)中有相同編號的員工,會在輸入編號后提示有相同的編號的員工,并重新輸入編號。增加了程序的健全性。更新數(shù)據(jù)

13、函數(shù),以編號來確定更新的員工,更新將重新輸入該編號員工的信息,并在更新后執(zhí)行寫入。刪除函數(shù),執(zhí)行該函數(shù)后,將有兩種選擇,按編號刪除,或按名字刪除,正確輸入后將會將該編號或姓名的數(shù)據(jù)中的一項zt的值更改為1,使其在其他操作時不被識別,以達到不刪除數(shù)據(jù),但達到相同的效果的邏輯刪除。顯示函數(shù),有兩種顯示方式,按學號顯示或按名字顯示,學號顯示為從小到大顯示。重組函數(shù),將文件中邏輯刪除的數(shù)據(jù)物理刪除,用來節(jié)省儲存空間,并可以加快運算速度。統(tǒng)計數(shù)據(jù),將文件中的數(shù)據(jù)統(tǒng)計、計算,并輸出,給人以直觀的方式顯示數(shù)據(jù)。排序函數(shù),將數(shù)據(jù)以實發(fā)工資從大到小排序。2.2 系統(tǒng)流程設計主函數(shù)main();登陸函數(shù)dl();

14、菜單函數(shù)cd();增加函數(shù)zj_data();刪除函數(shù)sc_data()更新函數(shù)gx_data();讀取函數(shù)read();查詢函數(shù)cz_data();顯示函數(shù)xs_data();重組數(shù)據(jù)cz_data();統(tǒng)計數(shù)據(jù)tj_data;排序數(shù)據(jù)px_data();系統(tǒng)的總體流程圖保存函數(shù)save();查詢輸入查詢方式按編號查詢按名字查詢查詢學生輸出當前學生數(shù)據(jù)查無此人查詢函數(shù)的流程圖3編碼實現(xiàn)#define MAX 100#include#include#includestruct user /登陸者信息char un10;char up10;us3 = aaa,111,bbb,222,ccc,33

15、3 ;struct yg /員工結(jié)構(gòu)體short zt; /數(shù)據(jù)狀態(tài)long bh; /編號char name20; /名字char time11; /時間long money; /基本工資long jj; /獎金long kk; /扣款long sf; /實發(fā)工資;yg yMAX; /定義數(shù)據(jù)體數(shù)組int r = 0; /全局變量,人數(shù),包括邏輯刪除人數(shù)int p = 0; /登陸的次數(shù),用全局變量能在登陸三次失敗時退出程序void read() /讀取文件函數(shù)FILE *fp;char b;int i;b = 0;printf(即將讀取文件 員工信息.datn);if (fp = fope

16、n(員工信息.dat, rb) = NULL) /讀取文件printf(員工信息.dat 文件不存在n);printf(是否重新創(chuàng)建該文件?n);printf(創(chuàng)建(y) 員工信息.dat 或 退出(n)n);getchar();b = getchar();while (getchar() != n)if (b = Y | b = N)b += 32;while (b != y&b != n)printf(輸入錯誤!請重新輸入!n);b = getchar();while (getchar() != n)if (b = Y | b = N)b += 32;if (b = y)if (fp =

17、fopen(員工信息.dat, wb) = NULL) /文件不存在則創(chuàng)建文件printf(創(chuàng)建文件失敗!n);printf(按下任意鍵以退出程序!n);getchar();exit(1);if (b = 0)fread(&r, 4, 1, fp);printf(讀取成功!n);elseprintf(創(chuàng)建文件成功!n);if (r != 0)for (i = 0; i r; i+)fread(&yi, sizeof(yg), 1, fp);fclose(fp);void save() /保存文件函數(shù)FILE *fp;int i;if (fp = fopen(員工信息.dat, wb) = NU

18、LL)printf(保存文件失敗!n);printf(按下任意鍵以退出程序!n);getchar();exit(1);elsefwrite(&r, 4, 1, fp);if (r != 0)for (i = 0; i r; i+)fwrite(&yi, sizeof(yg), 1, fp);fclose(fp);void zj_data() /增加數(shù)據(jù)函數(shù)yg yuangong;char b;int i;int k = 0;yuangong.zt = 0; /新建員工信息時,狀態(tài)為0do /用循環(huán)來尋找、避免相同編號的員工printf(編號:(例如:123456)n);scanf(%d, &y

19、uangong.bh);for (i = 0; i r; i+)if (yi.bh = yuangong.bh&yi.zt=0)printf(已有同編號員工無法添加!n);printf(請重新輸入!n);k = 1;break;else if (i = r - 1)k = 0; while (k = 1);printf(姓名:(例如:張三(or tom)n);scanf(%s, yuangong.name);printf(年月:(例如:2015.11.11)n);scanf(%s, yuangong.time);printf(崗位工資:(例如:50000)n);scanf(%d, &yuang

20、ong.money);printf(獎金:(例如:2000)n);scanf(%d, &yuangong.jj);printf(扣款:(例如:100)n);scanf(%d, &yuangong.kk);printf(實發(fā)工資為:(崗位工資+獎金-扣款)n);yuangong.sf = yuangong.money + yuangong.jj - yuangong.kk;printf(%dn, yuangong.sf);yr = yuangong;r+; /新建員工信息時人數(shù)r+save();printf(添加成功!n);getchar(); /防止下面一個%c讀取到上一個的回車printf(

21、是否繼續(xù)添加員工?(y/n)n);b = getchar();while (getchar() != n);if (b = Y | b = N)b += 32;while (b != y&b != n)printf(輸入錯誤!請重新輸入!n);b = getchar();while (getchar() != n)if (b = Y | b = N)b += 32;if (b = y)zj_data();void gx_data() /更新數(shù)據(jù)yg yuangong;long num;int i;printf(n請輸入要更新的員工的編號!n);scanf(%d, &num);for (i =

22、0; i r; i+)if (yi.bh = num&yi.zt = 0)yuangong = yi;printf(當前該員工信息為:n);printf(編號:%dn, yuangong.bh);printf(姓名:%sn, yuangong.name);printf(年月:%sn, yuangong.time);printf(崗位工資:%dn, yuangong.money);printf(獎金:%dn, yuangong.jj);printf(扣款:%dn, yuangong.kk);printf(實發(fā)工資:%dn, yuangong.sf);printf(按下任意鍵輸入更新后的信息!n)

23、;getchar();getchar();printf(編號:(例如:123456)n);scanf(%d, &yuangong.bh);printf(姓名:(例如:張三(or tom)n);scanf(%s, yuangong.name);printf(年月:(例如:2015.11.11)n);scanf(%s, yuangong.time);printf(崗位工資:(例如:50000)n);scanf(%d, &yuangong.money);printf(獎金:(例如:2000)n);scanf(%d, &yuangong.jj);printf(扣款:(例如:100)n);scanf(%

24、d, &yuangong.kk);printf(實發(fā)工資為:(崗位工資+獎金-扣款)n);yuangong.sf = yuangong.money + yuangong.jj - yuangong.kk;printf(%dn, yuangong.sf);yi = yuangong;save();printf(更新成功!n);break;else if (i = r - 1)printf(查無此人!n);void cz_data() /查詢數(shù)據(jù)yg yuangong;int a, i;long num;char na10;printf(n請選擇查詢方式!n); /分為按編號查詢和姓名查詢prin

25、tf( *n);printf( * 1、編號查詢 *n);printf( * 2、姓名查詢 *n);printf( * 3、返回菜單 *n);printf( *n);scanf(%d, &a);if (a = 1)printf(請輸入查詢員工的編號:);scanf(%d, &num);for (i = 0; i r; i+) /編號查詢則循環(huán)r次,查找狀態(tài)為0且編號與所輸入的數(shù)字相同的數(shù)據(jù)if (yi.zt = 0 & yi.bh = num)yuangong = yi;printf(當前該員工信息為:n);printf(編號:%dn, yuangong.bh);printf(姓名:%sn,

26、yuangong.name);printf(年月:%sn, yuangong.time);printf(崗位工資:%dn, yuangong.money);printf(獎金:%dn, yuangong.jj);printf(扣款:%dn, yuangong.kk);printf(實發(fā)工資:%dn, yuangong.sf);break;else if (i = r - 1)printf(查無此人!n);else if (a = 2)printf(請輸入查詢員工的姓名:);scanf(%s, na);for (i = 0; i r; i+) /姓名查詢則循環(huán)r次,查找狀態(tài)為0且編號與所輸入的字

27、符串相同的數(shù)據(jù)if (strcmp(yi.name, na) = 0) & yi.zt = 0)yuangong = yi;printf(當前該員工信息為:n);printf(編號:%dn, yuangong.bh);printf(姓名:%sn, yuangong.name);printf(年月:%sn, yuangong.time);printf(崗位工資:%dn, yuangong.money);printf(獎金:%dn, yuangong.jj);printf(扣款:%dn, yuangong.kk);printf(實發(fā)工資:%dn, yuangong.sf);break;else i

28、f (i = r - 1)printf(查無此人!n);else if (a = 3)elseprintf(輸入錯誤!n);cz_data();void sc_data() /刪除數(shù)據(jù)yg yuangong;long num;int a, i, b;char na10;printf(n請選擇!n); /刪除也按編號刪除和姓名刪除printf( *n);printf( * 1、按編號刪除 *n);printf( * 2、按姓名刪除 *n);printf( * 3、返回主菜單 *n);printf( *n);scanf(%d, &a);if (a = 1)printf(請輸入要刪除員工的編號:);

29、scanf(%d, &num);for (i = 0; i r; i+)if (yi.zt = 0 & yi.bh = num)yuangong = yi;printf(當前該員工信息為:n);printf(編號:%dn, yuangong.bh);printf(姓名:%sn, yuangong.name);printf(年月:%sn, yuangong.time);printf(崗位工資:%dn, yuangong.money);printf(獎金:%dn, yuangong.jj);printf(扣款:%dn, yuangong.kk);printf(實發(fā)工資:%dn, yuangong.

30、sf);yi.zt = 1;save();printf(刪除成功!n);getchar(); /防止下面一個%c讀取到上一個的回車printf(是否繼續(xù)刪除員工?(y/n)n);b = getchar();while (getchar() != n);if (b = Y | b = N)b += 32;while (b != y&b != n)printf(輸入錯誤!請重新輸入!n);b = getchar();while (getchar() != n)if (b = Y | b = N)b += 32;if (b = y)sc_data();break;else if (i = r - 1

31、)printf(查無此人,無法刪除!n);else if (a = 2)printf(請輸入刪除員工的姓名:);scanf(%s, na);for (i = 0; i r; i+)if (strcmp(yi.name, na) = 0) & yi.zt = 0)yuangong = yi;printf(當前該員工信息為:n);printf(編號:%dn, yuangong.bh);printf(姓名:%sn, yuangong.name);printf(年月:%sn, yuangong.time);printf(崗位工資:%dn, yuangong.money);printf(獎金:%dn,

32、yuangong.jj);printf(扣款:%dn, yuangong.kk);printf(實發(fā)工資:%dn, yuangong.sf);yi.zt = 1;save();printf(刪除成功!n);getchar(); /防止下面一個%c讀取到上一個的回車printf(是否繼續(xù)刪除員工?(y/n)n);b = getchar();while (getchar() != n);if (b = Y | b = N)b += 32;while (b != y&b != n)printf(輸入錯誤!請重新輸入!n);b = getchar();while (getchar() != n)if

33、(b = Y | b = N)b += 32;if (b = y)sc_data();break;else if (i = r - 1)printf(查無此人,無法刪除!n);else if (a = 3) /輸入為3時不執(zhí)行操作返回主菜單elseprintf(輸入錯誤!n);sc_data();void xs_data() /顯示數(shù)據(jù)yg yuangongMAX, t;int a;int i, j;int k = 0;printf(n請選擇顯示方式!n);printf( *n);printf( * 1、按編號顯示 *n);printf( * 2、按姓名顯示 *n);printf( * 3、返

34、回主菜單 *n);printf( *n);scanf(%d, &a);for (i = 0; i r; i+)yuangongi = yi;if (yi.zt = 1)k+;if (k = r)printf(無員工信息!n);a = 3;if (a = 1) /按編號顯示時用冒泡排序從大到小排序for (i = 1; i = r; i+)for (j = 0; j yuangongj + 1.bh)t = yuangongj;yuangongj = yuangongj + 1;yuangongj + 1 = t;printf(按編號排列如下:n);printf(%-10s%-10s%-10s%

35、-10s%-10s%-10s%-10sn, 編號, 姓名, 年月, 崗位工資, 獎金, 扣款, 實發(fā)工資);for (i = 0; ir; i+)if (yuangongi.zt = 0)printf(%-10d%-10s%-10s%-10d%-10d%-10d%-10dn, yuangongi.bh, yuangongi.name, yuangongi.time, yuangongi.money, yuangongi.jj, yuangongi.kk, yuangongi.sf);printf(顯示完畢!n);else if (a = 2) /按名字顯示時用冒泡排序從大到小排序,用strcm

36、p來比較字符串的大小for (i = 1; i = r; i+)for (j = 0; j 0)t = yuangongj;yuangongj = yuangongj + 1;yuangongj + 1 = t;printf(按姓名排列如下:n);printf(%-10s%-10s%-10s%-10s%-10s%-10s%-10sn, 編號, 姓名, 年月, 崗位工資, 獎金, 扣款, 實發(fā)工資);for (i = 0; ir; i+)if (yuangongi.zt = 0)printf(%-10d%-10s%-10s%-10d%-10d%-10d%-10dn, yuangongi.bh,

37、yuangongi.name, yuangongi.time, yuangongi.money, yuangongi.jj, yuangongi.kk, yuangongi.sf);printf(顯示完畢!n);else if (a = 3)elseprintf(輸入錯誤!n);cz_data();void chongz_data() /重組文件int i, j;int k = 0;for (i = 0; i r; i+) /循環(huán)r次,將狀態(tài)為1的數(shù)據(jù)剔除,并將剔除數(shù)據(jù)的個數(shù)記錄if (yi.zt = 1)for (j = i; j r; j+)yj = yj + 1;k+;r -= k; /

38、將人數(shù)r重新計算save();printf(重組成功!n);void tj_data() /統(tǒng)計數(shù)據(jù)yg yuangongMAX;int max, m, k = 0;double ave = 0;int n = 0;int i;for (i = 0; i r; i+) /計算文件中邏輯刪除的數(shù)據(jù)個數(shù)kyuangongi = yi;if (yuangongi.zt = 1)k+;for (i = 0; i r; i+) /將數(shù)組中第一個狀態(tài)為0的數(shù)據(jù)的實發(fā)工資賦給max,并記錄是第幾位,跳出循環(huán)if (yuangongi.zt = 0)max = yuangongi.sf;m = i;break

39、;if (yuangong0.zt = 0) /第一個數(shù)據(jù)是否邏輯刪除?否,將實發(fā)工資賦給ave未計算的平均值ave = yuangong0.sf;for (i = 1; i r; i+) /循環(huán)找出最大值,并將所有正常數(shù)據(jù)加入未計算的ave中if (max yuangongi.sf) & (yuangongi.zt = 0)m = i;if (yuangongi.zt = 0)ave += yuangongi.sf;ave = ave / (r - k); /計算avefor (i = 0; i ave) & (yuangongi.zt = 0)n+;printf(n最高實發(fā)工資員工信息為:

40、n); /輸出結(jié)果printf(%-10s%-10s%-10s%-10s%-10s%-10s%-10sn, 編號, 姓名, 年月, 崗位工資, 獎金, 扣款, 實發(fā)工資);printf(%-10d%-10s%-10s%-10d%-10d%-10d%-10dn, yuangongm.bh, yuangongm.name, yuangongm.time, yuangongm.money, yuangongm.jj, yuangongm.kk, yuangongm.sf);printf(平均工資為:%.2fn, ave);printf(超過平均工資人數(shù)為:%dnn, n);void px_data(

41、) /排序數(shù)據(jù)yg yuangongMAX, t;int num = 0;int i, j;for (i = 0; i r; i+)yuangongi = yi;for (i = 1; i = r; i+) /冒泡排序排序所有數(shù)據(jù)for (j = 0; j r - i; j+)if (yuangongj.sfyuangongj + 1.sf)t = yuangongj;yuangongj = yuangongj + 1;yuangongj + 1 = t;printf(n所有員工信息為:n);printf(%-10s%-10s%-10s%-10s%-10s%-10s%-10sn, 編號, 姓名

42、, 年月, 崗位工資, 獎金, 扣款, 實發(fā)工資);for (i = 0; ir; i+)if (yuangongi.zt = 0)printf(%-10d%-10s%-10s%-10d%-10d%-10d%-10dn, yuangongi.bh, yuangongi.name, yuangongi.time, yuangongi.money, yuangongi.jj, yuangongi.kk, yuangongi.sf);void cd() /菜單函數(shù)int l;doprintf(歡迎進入員工工資管理系統(tǒng)菜單!n);printf( _n);printf( *| 1.增加數(shù)據(jù) |*n);p

43、rintf( *| 2.更新數(shù)據(jù) |*n);printf( *| 3.查詢數(shù)據(jù) |*n);printf( *| 4.刪除數(shù)據(jù) |*n);printf( *| 5.顯示數(shù)據(jù) |*n);printf( *| 6.重組數(shù)據(jù) |*n);printf( *| 7.統(tǒng)計輸出 |*n);printf( *| 8.排序數(shù)據(jù) |*n);printf( *| 9.退出 |*n);printf( *|其它輸入為退出|*n);printf( *|_|*nn);printf(請輸入你的選擇:n);scanf(%d, &l);switch (l)case 1:zj_data(); printf(即將返回主菜單n); sy

44、stem(PAUSE); break; /system用于返回主菜單時等待一下case 2:gx_data(); printf(即將返回主菜單n); system(PAUSE); break;case 3:cz_data(); printf(即將返回主菜單n); system(PAUSE); break;case 4:sc_data(); printf(即將返回主菜單n); system(PAUSE); break;case 5:xs_data(); printf(即將返回主菜單n); system(PAUSE); break;case 6:chongz_data(); printf(即將返回

45、主菜單n); system(PAUSE); break;case 7:tj_data(); printf(即將返回主菜單n); system(PAUSE); break;case 8:px_data(); printf(即將返回主菜單n); system(PAUSE); break;case 9:break; while (l != 9 & (l = 1 | l = 2 | l = 3 | l = 4 | l = 5 | l = 6 | l = 7 | l = 8);void dl() /登陸函數(shù)int i;char a10, b10;printf(請輸入用戶名:n);scanf(%s, a);printf(請輸入密碼:n);scanf(%s, b);for (i = 0; i= 3)printf(登錄失敗超過3次,系統(tǒng)將強制退出!n);printf(按下任意鍵以退出程序!n);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. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關資源

更多
正為您匹配相似的精品文檔
關于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!