1、题目 3:职工工资管理系统设计功能:实现简单的职工工资信息管理,职工工资的基本信息包括编号、姓名、基本工资、奖金、工资总额等 基本要求:1 设计简单的菜单,能够进行系统功能选择。 2 实现信息的录入功能。3 在已有信息的基础上添加新的记录。 4 删除指定编号的记录。 5 修改指定编号的记录 6 实现信息的浏览功能 7 按编号查询功能8 按工资总额排序功能 #include “stdio.h“#include “stdlib.h“#include “ctype.h“#include “process.h“struct gongzi /*定义数组*/int bianhao;char xingmin
2、g10;int jbgz;/*基本工资*/int jiangjin;int tatal;struct gongzi *next;void print() /*菜单*/printf(“welcom!n“);printf(“1.创建新信息n“);printf(“2.删除原信息n“);printf(“3.修改原信息n“);printf(“4.按编号查找n“);printf(“5.工资总额排序n“);struct gongzi * creat(struct gongzi*head) /*case1创建工资,降序排列*/struct gongzi *p1, *p2, *p3; /*p1 新增点,p2,p
3、3 切点*/ p1 =p2 =p3 =(struct gongzi * )malloc(sizeof(struct gongzi) );printf(“创建新信息n 输入编号,姓名,基本工资,奖金n“);printf(“输入编号“);scanf(“%d“,printf(“输入姓名“);scanf(“%s“,printf(“输入基本工资“);scanf(“%d“,printf(“输入奖金“);scanf(“%d“,p1-tatal =p1-jbgz + p1-jiangjin;p1-next =NULL;if(head = NULL)head =p1;else p2 =head;while(p2
4、-tatal tatal) p2 =p2-next;if(p1-tatal tatal)if(head = p1)head =p1;elsep3-next =p1;p1-next =p2;elsep2-next =p1;p1-next =NULL;return head;struct gongzi * del(struct gongzi*head) /*case2 删除原信息*/int bianhao;struct gongzi *p1, *p2;printf(“输入要删除的编号“);if(head = NULL)printf(“nlist is null“);goto end;p1=head
5、;scanf(“%d“,while(bianhao != p1-bianhao) p1 =p1-next;if(bianhao =p1-bianhao)if(p1 = head)head =p1-next;elsep2-next =p1-next;printf(“%d has been deleted.n“,bianhao);elseprintf(“%d not been found!n“,bianhao);end:return(head);struct gongzi * change(struct gongzi*head) /*case 3 修改原信息*/int bianhao;struct
6、 gongzi *p1, *p2;printf(“输入要修改的编号“);if(head = NULL)printf(“nlist is null“);goto end;p1=head;scanf(“%d“,while(bianhao != p1-bianhao) p1 =p1-next;if(bianhao =p1-bianhao)printf(“输入编号“);scanf(“%d“,printf(“输入姓名“);scanf(“%s“,printf(“输入基本工资“);scanf(“%d“,printf(“输入奖金“);scanf(“%d“,p1-tatal =p1-jbgz + p1-jian
7、gjin;p1-next =NULL;printf(“%d has been change.n“,bianhao);elseprintf(“%d not been found!n“,bianhao);end:return(head);struct gongzi * search(struct gongzi*head) /*case4 按编号查找*/int bianhao;struct gongzi *p1, *p2;printf(“输入要查找的编号“);if(head = NULL)printf(“nlist is null“);goto end;p1=head;scanf(“%d“,whil
8、e(bianhao != p1-bianhao) p1 =p1-next;if(bianhao =p1-bianhao)printf(“%5d%10s%5d%5d%5dn“,p1-bianhao, p1-xingming,p1-jbgz, p1-jiangjin, p1-tatal);elseprintf(“%d not been found!n“,bianhao);end:return(head);void list(struct gongzi*head) /*case5 输出*/struct gongzi*p1;p1 =head;printf(“编号、姓名、基本工资、奖金、工资总额n“);
9、if(head = NULL)printf(“nlist is nulln“);while(p1 != NULL)printf(“%5d%10s%5d%5d%5dn“,p1-bianhao, p1-xingming,p1-jbgz, p1-jiangjin, p1-tatal);p1 =p1-next;main()int caidan, ch;struct gongzi*p;struct gongzi*head =NULL;loop:print();scanf(“%d“,switch(caidan)case 1:head =creat(head);getch();break;case 2:head =del(head);getch();break;case 3:head =change(head);getch();break;case 4:head =search(head);getch();break;case 5:list(head);getch();break;goto loop;