




已阅读5页,还剩8页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/*C语言课程设计任务书:职工档案管理系统设计*/#include #include#include #include #include #defineMAX_NUM95 struct worker int ID;char Birth20;char Sex20;char Name30;char Telenum20;int Wage;char Department30;char Job30; workMAX_NUM;void main() void showmenu(); /* 声明主菜单函数 */void append(); /* 声明添加函数 */ void search(); /* 声明查找函数 */ void output(); /* 声明输出函数 */ void modify(); /* 声明修改函数 */ void deletes(); /* 声明删除函数 */ void save(); /* 声明保存函数 */ void read(); /* 声明录入函数 */ void sort(); /* 声明排序存函数 */ int m; showmenu();scanf(%d,&m);for(;m=0&mMAX_NUM)printf(您输入的人数太多,大于 %d 人!n,MAX_NUM); for(i=0;inumber;i+)printf(n请输入第%d个职工的编号:t,i+1);scanf(%d,&worki.ID);printf(t职工档案:n);printf(tt姓名:);scanf(%s,&worki.Name);printf(tt出生年月:);scanf(%s,&worki.Birth);printf(tt电话:);scanf(%s,&worki.Telenum); printf(tt性别:);scanf(%s,&worki.Sex);printf(tt工资:);scanf(%d,&worki.Wage);printf(tt部门:);scanf(%s,&worki.Department);printf(tt职称:);scanf(%s,&worki.Job);printf(n您的输入是:n); printf( *职工档案信息库*n);printf( 序号 编号 姓名 出生年月 电话t 性别 t工资t部门t职称n);for(i=0;inumber;i+)printf( %d %d %s %st%st%st%dt%st%sn,i+1,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job);printf( *n);printf(n); /* 查找函数 */ void search()system(cls); int number=MAX_NUM,findID,v,i;char findName30;printf(n您选择的是档案查询!n);printf( *请选择查询方式*n);printf(t t 1-按编号查找;t t t t 2-按姓名查找n); /*以下可以修改为子菜单方式:1-按编号查找,2-按姓名查找*/printf( *n);printf(请选择:);scanf(%d,&v);switch(v) case 1: system(cls); printf(n您选择的是按编号查找!n);printf(n请输入职工的编号: );scanf(%d,&findID);for(i=0;inumber;i+)if(worki.ID=findID)break;if(inumber)printf(查找结果如下:n);printf(t编号t姓名 t出生年月t电话t 性别t工资t部门t职称n);printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job); else printf(您输入的编号不存在!n);break;case 2: system(cls); printf(n您选择的是按姓名查找!n);printf(n请输入职工的姓名: );scanf(%s,&findName);for(i=0;inumber;i+)if(!strcmp(worki.Name,findName)break;if(inumber)printf(查找结果如下:n);printf(t编号t姓名 t出生年月t电话t 性别t工资t部门t职称n);printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job); else printf(您输入的姓名不存在!n);break; /* 输出函数 */ void output() int i,number=MAX_NUM;system(cls); printf(查找结果如下:n); printf(t编号t姓名 t出生年月t电话t 性别t工资t部门t职称n); for(i=0;inumber;i+) printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job); void deletes()int findID,i,j,number=MAX_NUM; system(cls); printf(n您选择的是档案删除!n);printf(n请输入职工的编号: );scanf(%d,&findID);for(i=0;inumber;i+)if(worki.ID=findID)break;printf(t编号t姓名 t出生年月t电话t 性别t工资t部门t职称n);if(inumber) for(j=i;jnumber-1;j+) workj.ID=workj+1.ID; strcpy(workj.Name,workj+1.Name); strcpy(workj.Telenum,workj+1.Telenum); strcpy(workj.Birth,workj+1.Birth); strcpy(workj.Sex,workj+1.Sex); workj.Wage=workj+1.Wage; strcpy(workj.Department,workj+1.Department); strcpy(workj.Job,workj+1.Job);for(i=0;inumber-1;i+)printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job);elsefor(i=0;inumber-1;i+)printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Telenum,worki.Birth,worki.Sex,worki.Wage,worki.Department,worki.Job);number-; /* 修改函数 */ void modify()int findID,i,number=MAX_NUM; system(cls); char yz9,psw9=12345678;printf(n您选择的是档案修改!n);while(1) printf(n请输入密码!n); for(i=0;i9;i+) yzi=getch(); printf(*); if(yzi=r) yzi=0; break; if(!strcmp(psw,yz) printf(n密码正确!n); break; else printf(密码错误,请重输!n); printf(n请输入职工的编号: );scanf(%d,&findID);for(i=0;inumber;i+)if(worki.ID=findID)break;if(inumber) printf(t姓名 t出生年月电话tt 性别t工资t部门t职称n); printf(原档案:nt%d t%st%st %st%dt%st%sn,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job);printf(请输入新档案:n );printf(tt姓名:);scanf(%s,&worki.Name);printf(tt出生年月:);scanf(%s,&worki.Birth);printf(tt电话:);scanf(%s,&worki.Telenum); printf(tt性别:);scanf(%s,&worki.Sex);printf(tt工资:);scanf(%d,&worki.Wage);printf(tt部门:);scanf(%s,&worki.Department);printf(tt职称:);scanf(%s,&worki.Job);printf(n您的输入是:n); printf( *职工档案信息库*n);printf( 序号 编号 姓名 出生年月 电话t 性别 t工资t部门t职称n);for(i=0;inumber;i+)printf( %d %d %s %st%st%st%dt%st%sn,i+1,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job);printf( *n);printf(n);elseprintf(您输入的编号不存在!n); /* 保存函数 */ void save() FILE *fp;char filepnMAX_NUM;int number=MAX_NUM,i; system(cls);printf(您选择的是职工档案的保存!n);printf(请输入文件路径及文件名:);scanf(%s,filepn);if(fp=fopen(filepn,w+)=NULL)printf(不能打开文件!n);for (i=0;inumber;i+) if (fwrite(&worki,sizeof(struct worker),1,fp)!=1) printf(写入文件错误!n); fclose(fp);printf(文件已经保存!n); /* 读取档案函数 */ void read() FILE *fp;char filepnMAX_NUM;int number=MAX_NUM,i; system(cls);printf(您选择的是职工档案的读取!n);printf(请输入文件路径及文件名:);scanf(%s,filepn);/*输入文件路径及名称*/if(fp=fopen(filepn,r+)=NULL)printf(不能打开文件!n); i=0;while(!feof(fp) fread(&worki+,sizeof(struct worker),1,fp); number=i-1;/*排序函数*/void sort()int i,j,n=MAX_NUM,s,v; char temp20; printf(n您选择的是数据排序!n);printf( *请选择排序方式*n);printf(t t 1-按编号排序;t t t t 2-按工资排序n); /*以下可以修改为子菜单方式:1-按编号排序,2-按工资排序*/printf( *n);printf(请选择:);scanf(%d,&v);switch(v) case 1: for(i=0;i=n;i+)for(j=i+1;j=n;j+)if(workj.IDworki.ID)strcpy(temp,worki.Birth);strcpy(worki.Birth,workj.Birth);strcpy(workj.Birth,temp);strcpy(temp,worki.Name);strcpy(worki.Name,workj.Name);strcpy(workj.Name,temp);strcpy(temp,worki.Sex);strcpy(worki.Sex,workj.Sex);strcpy(workj.Sex,temp);s=worki.Wage; worki.Wage=workj.Wage; workj.Wage=s;strcpy(temp,worki.Telenum);strcpy(worki.Telenum,workj.Telenum);strcpy(workj.Telenum,temp);strcpy(temp,worki.Department);strcpy(worki.Department,workj.Department);strcpy(workj.Department,temp);strcpy(temp,worki.Job);strcpy(worki.Job,workj.Job);strcpy(workj.Job,temp); s=worki.ID; worki.ID=workj.ID; workj.ID=s; printf( 新的排序如下:n); printf(t编号t姓名 t出生年月t电话t 性别t工资t部门t职称n); for(i=0;in;i+) printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job);break ;case 2:int k;printf(n您选择的是按工资排序!n);printf( *请选择排序方式*n);printf(t t 1-按工资从高到低排序;t t t t 2-按工资从低到高排序n); /*以下可以修改为子菜单方式:1-按工资从高到低排序;2-按工资从低到高排序*/printf( *n);printf(请选择:);scanf(%d,&k);switch(k) case 1: for(i=0;i=n;i+)for(j=i+1;j=n;j+)if(worki.Wageworkj.Wage)strcpy(temp,worki.Birth);strcpy(worki.Birth,workj.Birth);strcpy(workj.Birth,temp);strcpy(temp,worki.Name);strcpy(worki.Name,workj.Name);strcpy(workj.Name,temp);strcpy(temp,worki.Sex);strcpy(worki.Sex,workj.Sex);strcpy(workj.Sex,temp);s=worki.Wage; worki.Wage=workj.Wage; workj.Wage=s;strcpy(temp,worki.Telenum);strcpy(worki.Telenum,workj.Telenum);strcpy(workj.Telenum,temp);strcpy(temp,worki.Department);strcpy(worki.Department,workj.Department);strcpy(workj.Department,temp);strcpy(temp,worki.Job);strcpy(worki.Job,workj.Job);strcpy(workj.Job,temp); s=worki.ID; worki.ID=workj.ID; workj.ID=s; printf( 新的排序如下:n); printf(t编号t姓名 t出生年月t电话t 性别t工资t部门t职称n); for(i=0;in;i+) printf(t%dt%s t%st%st %st%dt%st%sn,worki.ID,worki.Name,worki.Birth,worki.Telenum,worki.Sex,worki.Wage,worki.Department,worki.Job);break ;case 2: for(i=0;i=n;i+)for(j=i+1;jworkj.Wage)strcpy(temp,worki.B
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年微生物学与免疫学考试试题及答案
- Tesmilifene-fumarate-Standard-DPPE-fumarate-Standard-生命科学试剂-MCE
- mCherry-mRNA-N1-Me-Pseudo-UTP-生命科学试剂-MCE
- Halymecin-C-生命科学试剂-MCE
- 2025年青少年心理健康教育师考试试题及答案
- 2025年人工智能应用专业毕业生能力测试试题及答案
- 2025年社会心理学应用与研究方法考试试题及答案
- 2025年经济法学专业考试相关试题及答案
- 2025年建筑设计专业研究生入学考试试卷及答案
- 2025年电子技术基础考试试题及答案
- 岩石力学与工程课后习题与思考解答
- 低压配电柜技术规范
- 《思考的框架》读书笔记思维导图
- 食堂管理考核评分表
- 网路使用亲子契约书
- 会计知识大赛初赛题库
- 甲骨文课件完整版
- 2023年全国电力生产人身伤亡事故统计
- 国际金融(南开大学)智慧树知到答案章节测试2023年
- 外研版七年级上册英语思维导图各个单元的内容
- 《熔焊方法及设备》第二版思考题(课后)
评论
0/150
提交评论