1、职工信息管理系统c语言版#include #include #include #include #define LEN sizeof(struct employee)typedef struct employee char name20; long num; char sex5; int age; char addr30; int wage; char health20; char edu20; struct employee * next;EMP;void input(); /输入职工信息EMP * open(); /将文件中的职工信息载入链表void numfind(EMP *); /查找
2、职工信息,按职工号查找void namefind(EMP *); /查找职工信息,按职工姓名查找void modify(EMP *); /修改职工信息void delet(EMP *); /删除职工信息void numsort(EMP *); /按工号给职工信息排序void wagesort(EMP *); /按工资给职工信息排序void print(EMP *); /输出职工信息void renew(EMP *); /更新文件信息int n; /职工的个数void main() EMP *fhead; int choice,flag=1; char s; while(flag) printf
3、(n *n); printf( 欢迎使用职工信息管理系统!); printf(n); printf( *nn); printf( 主窗口菜单 name); printf(n工号: ); scanf(%ld,&p1-num); getchar(); printf(n性别: ); scanf(%s,p1-sex); printf(n年龄: ); scanf(%d,&p1-age); printf(n地址: ); scanf(%s,p1-addr); printf(n月薪: ); scanf(%d,&p1-wage); printf(n健康状况: ); scanf(%s,p1-health); pr
4、intf(n教育程度: ); scanf(%s,p1-edu); getchar(); printf(n是否继续录入?(y/n): ); scanf(%c,&s); getchar(); if(s=y) p2=p1; p1=(EMP *)malloc(LEN); p2-next=p1; else flag=0; p1-next=NULL; p=head; if(fp=fopen(employee.txt,ab)=NULL) if(fp=fopen(employee.txt,wb)=NULL) printf(无法打开文件!n); exit(0); while(p!=NULL) if(fwrite
5、(p,LEN,1,fp)!=1) printf(无法保存!n); p=p-next; fclose(fp); printf(n录入成功!n);EMP * open(void) n=0; EMP *fhead,*p1,*p2; FILE *fp; fhead=NULL; p1=p2=(EMP *)malloc(LEN); if(fp=fopen(employee.txt,rb)!=NULL) fread(p1,LEN,1,fp); while(!feof(fp) n=n+1; if(n=1) fhead=p1; else p2-next=p1; p2=p1; p1=(EMP *)malloc(L
6、EN); fread(p1,LEN,1,fp); p2-next=NULL; else fp=fopen(employee.txt,wb); fclose(fp); return (fhead);void namefind(EMP * head) int a=0; char findname20; EMP *p; p=head; printf(n请输入姓名: ); gets(findname); while(p!=NULL) if(strcmp(findname,p-name)=0) a=a+1; if(a=1) printf(n姓名 工号 性别 年龄 地址 月薪 健康状况 教育程度nn);
7、printf(%-8s%-8ld%-8s%-8d%-14s%-9d%-12s%-8sn,p-name,p-num,p-sex,p-age,p-addr,p-wage,p-health,p-edu); p=p-next; if(a=0) printf(n没有姓名为 %s 的职工n,findname);void numfind(EMP * head) int findnum,a=0; EMP *p; p=head; printf(n请输入职工号: ); scanf(%ld,&findnum); getchar(); while(p!=NULL) if(findnum=p-num) a=a+1; p
8、rintf(n姓名 工号 性别 年龄 地址 月薪 健康状况 教育程度nn); printf(%-8s%-8ld%-8s%-8d%-14s%-9d%-12s%-8sn,p-name,p-num,p-sex,p-age,p-addr,p-wage,p-health,p-edu); p=p-next; if(a=0) printf(n没有工号为 %ld 的职工n,findnum);void modify(EMP * head) EMP *p; int a=0; char findname20; p=head; system(cls); printf(n请输入姓名: ); gets(findname)
9、; while(p!=NULL) if(strcmp(findname,p-name)=0) a=a+1; printf(n姓名 工号 性别 年龄 地址 月薪 健康状况 教育程度nn); printf(%-8s%-8ld%-8s%-8d%-14s%-9d%-12s%-8sn,p-name,p-num,p-sex,p-age,p-addr,p-wage,p-health,p-edu); printf(n请修改!n); printf(n姓名: ); scanf(%s,p-name); printf(n工号: ); scanf(%ld,&p-num); getchar(); printf(n性别:
10、); scanf(%s,p-sex); printf(n年龄: ); scanf(%d,&p-age); printf(n地址: ); scanf(%s,p-addr); printf(n月薪: ); scanf(%d,&p-wage); printf(n健康状况: ); scanf(%s,p-health); printf(n教育程度: ); scanf(%s,p-edu); getchar(); printf(n修改成功!n); p=p-next; if(a=0) printf(n没有姓名为 %s 的职工n,findname); else renew(head);void delet(EM
11、P * head) int a=0; char c,findname20; EMP *p1,*p2; p1=p2=head; system(cls); printf(n请输入姓名: ); scanf(%s,findname); getchar(); /清空缓冲区 while(p1!=NULL) if(strcmp(findname,p1-name)=0) a=a+1; printf(n姓名 工号 性别 年龄 地址 月薪 健康状况 教育程度nn); printf(%-8s%-8ld%-8s%-8d%-14s%-9d%-12s%-8sn,p1-name,p1-num,p1-sex,p1-age,p
12、1-addr,p1-wage,p1-health,p1-edu); printf(n确定删除该职工信息?(y/n): ); c=getchar(); getchar(); /清空缓冲区 if(c=y) if(p1=head) p1=p2=head=p1-next; else p2-next=p1-next; free(p1); p1=p2; printf(n删除成功!n); p2=p1; if(p1!=NULL) p1=p1-next; else; if(a=0) printf(n没有姓名为 %s 的职工n,findname); else renew(head);void renew(EMP
13、* head) FILE *fp; struct employee *p; p=head; if(fp=fopen(employee.txt,wb)=NULL) printf(无法打开文件!n); exit(0); while(p!=NULL) if(fwrite(p,LEN,1,fp)!=1) printf(无法保存!n); p=p-next; fclose(fp);void print(EMP * head) EMP * p; p=head; system(cls); if(p=NULL) printf(n无任何信息!n); else printf(n姓名 工号 性别 年龄 地址 月薪 健
14、康状况 教育程度nn); while(p!=NULL) printf(%-8s%-8ld%-8s%-8d%-14s%-9d%-12s%-8snn,p-name,p-num,p-sex,p-age,p-addr,p-wage,p-health,p-edu); p=p-next; void numsort(EMP * head) /按工号排序 int i; EMP *p1,*p2,*p3,*end=NULL; p1=p2=p3=head; if(head!=NULL&head-next!=NULL) for(i=1;inext; while(p1!=end) if(p1-numnum) p2-ne
15、xt=p1-next; p1-next=p2; if(p2=p3) head=p1; else p3-next=p1; p3=p1; p1=p2-next; else p3=p2; p2=p1; p1=p1-next; end=p2; p1=p2=p3=head; renew(head);void wagesort(EMP * head) /按工资排序 int i; EMP *p1,*p2,*p3,*end=NULL; p1=p2=p3=head; if(head!=NULL&head-next!=NULL) for(i=1;inext; while(p1!=end) if(p1-wagewage) p2-next=p1-next; p1-next=p2; if(p2=p3) head=p1; else p3-next=p1; p3=p1; p1=p2-next; else p3=p2; p2=p1; p1=p1-next; end=p2; p1=p2=p3=head; renew(head);
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1