C语言链表实现工资管理系统
更新时间:2022年02月27日 16:24:52 作者:xjfyt
这篇文章主要为大家详细介绍了C语言链表实现工资管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了C语言链表实现工资管理系统的具体代码,供大家参考,具体内容如下
自己的作业,分享一下,自己为了调试方便,又多加入了一些功能
题目:建立工资管理系统,对职工工资的相关信息进行管理。职工工资相关信息包括职工工号,职工姓名,月份,每月工资和年度总工资等,具体要求如下:
1、建立该系统的存储结构
2、录入职工某个月的工资
3、查找某个职工某个月的工资
4、修改某个职工某个月的工资
5、删除每个职工的工资相关信息
6、统计某个职工年度总工资
7、对职工的月工资或年度总工资进行排名
源码
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct worker { char no[12]; //职工工号 char name[40]; //姓名 int month[12]; //月份 float gz[12]; //月工资 float total; //年度总工资 struct worker *next; //指向下一节点的指针 } Worker; //相关的函数声明 Worker *CreateList(Worker *L, int n); //根据输入的职工人数,批量创建节点 void DeleteList(Worker *L, char n[]); //删除节点 void LIstSearch(Worker *L, char n[]); //查找职工工资信息 void InsertInfo(Worker *L); //插入职工工资信息 void SearchMonthSalary(Worker *L, char n[], int m); //查找某个职工的某个月的工资 void Input(Worker *p, int i); //为节点的数据域赋值 void Print(Worker *L); //输出整个链表的数据 void Modify(Worker *L, char n[], int m, float s); //修改某个职工的工资 void menu(); //工资管理系统的菜单 void Save(Worker *L); //将职工的工资信息保存至文件 void Bubble_sort(Worker *L); //冒泡排序实现对链表节点的排序 void StatiTotal(Worker *L,char n[]); //统计某个职工年度总工资 //根据输入的职工人数,批量创建节点 Worker *CreateList(Worker *L, int n) //n为输入的职工人数 { int i; for (i = 0; i < n; i++) { Worker *p; //将新生成的节点插入到链表中 p = NULL; p = (Worker *)malloc(sizeof(Worker)); Input(p, i); //为节点的数据域赋值 p->next = L->next; L->next = p; } return L; } void DeleteList(Worker *L, char n[]) //按姓名删除职工信息 { int i; Worker *p = L->next, *pre = L; //定义p指针指向头节点的指向,定义pre指向头节点,pre始终指向p的前驱节点 if (p == NULL) printf("数据为空,无法删除!"); else { while (strcmp(p->name, n) != 0) { pre = p; p = pre->next; if (p == NULL) { printf("没有找到相关信息,无法删除\n"); return; } } pre->next = p->next; free(p); printf("删除成功"); } } //向链表中插入职工工资信息 void InsertInfo(Worker *L) { int j, k; Worker *p = NULL; p = (Worker *)malloc(sizeof(Worker)); //生成一个新节点p p->total = 0; printf("请输入要插入的职工的职工工号:"); scanf("%s", &p->no); printf("请输入要插入的职工的姓名:"); scanf("%s", &p->name); for (k = 0, j = 1; j <= 12, k < 12; j++, k++) p->month[k] = j; printf("请输入要插入的职工的月工资(用空格隔开):"); for (j = 0; j < 12; j++) { scanf("%f", &p->gz[j]); //输入每个月的工资 p->total += p->gz[j]; //计算总工资 } p->next = L->next; L->next = p; printf("插入成功!"); } void LIstSearch(Worker *L, char n[]) { int i; Worker *p = L->next; while (p != NULL) { if (strcmp(p->name, n) == 0) { printf("\n该职工的工资的信息如下:\n"); printf("职工编号:"); printf("%s\t\n", p->no); printf("姓名:"); printf("%s\n", p->name); printf("该职工12个月的月工资如下:"); for (i = 0; i < 12; i++) printf("%.2f ", p->gz[i]); printf("\n该职工的年度总工资为:"); printf("%.2f", p->total); printf("\n\n"); printf("\n"); p = p->next; } else p = p->next; } } void SearchMonthSalary(Worker *L, char n[], int m) { int i; Worker *p = L->next; while (p != NULL) { if (strcmp(p->name, n) == 0) { switch (m) { case 1: printf("该职工%d月的工资为%.2f", p->month[0], p->gz[0]); break; case 2: printf("该职工%d月的工资为%.2f", p->month[1], p->gz[1]); break; case 3: printf("该职工%d月的工资为%.2f", p->month[2], p->gz[2]); break; case 4: printf("该职工%d月的工资为%.2f", p->month[3], p->gz[3]); break; case 5: printf("该职工%d月的工资为%.2f", p->month[4], p->gz[4]); break; case 6: printf("该职工%d月的工资为%.2f", p->month[5], p->gz[5]); break; case 7: printf("该职工%d月的工资为%.2f", p->month[6], p->gz[6]); break; case 8: printf("该职工%d月的工资为%.2f", p->month[7], p->gz[7]); break; case 9: printf("该职工%d月的工资为%.2f", p->month[8], p->gz[8]); break; case 10: printf("该职工%d月的工资为%.2f", p->month[9], p->gz[9]); break; case 11: printf("该职工%d月的工资为%.2f", p->month[10], p->gz[10]); break; case 12: printf("该职工%d月的工资为%.2f", p->month[11], p->gz[11]); break; default: break; } p = p->next; } else p = p->next; } } void Bubble_sort(Worker *L)//冒泡排序实现对链表节点的排序 { Worker *p,*q,*tail,*l; tail = NULL; while((L->next->next) != tail) { p = L; q = L->next; while(q->next != tail) { if((q->total) > (q->next->total)) { p->next = q->next; q->next = q->next->next; p->next->next = q; q = p->next; } q = q->next; p = p->next; } tail = q; } printf("排序完成!年度总工资从小到大结果如下:\n"); l=L->next; while(l!=NULL) { if(l->next!=NULL) { printf("%s->",l->name); l=l->next; } else { printf("%s",l->name); l=l->next; } } } void StatiTotal(Worker *L,char n[]) //统计某个职工年度总工资 { int i; Worker *p=L->next; while(p!=NULL) { p->total=0; if(strcmp(p->name,n)==0) { for(i=0;i<12;i++) p->total+=p->gz[i]; printf("%s的年度总工资为%.2f",n,p->total); break; } else p=p->next; } } void Modify(Worker *L, char n[], int m, float s) { int i,j; Worker *p = L->next; while (p != NULL) { if (strcmp(p->name, n) == 0) { switch (m) { case 1: p->gz[0] = s; break; case 2: p->gz[1] = s; break; case 3: p->gz[2] = s; break; case 4: p->gz[3] = s; break; case 5: p->gz[4] = s; break; case 6: p->gz[5] = s; break; case 7: p->gz[6] = s; break; case 8: p->gz[7] = s; break; case 9: p->gz[8] = s; break; case 10: p->gz[9] = s; break; case 11: p->gz[10] = s; break; case 12: p->gz[11] = s; break; default: break; } p->total=0; for(j=0;j<12;j++) p->total+=p->gz[j]; p=p->next; } else p = p->next; } printf("修改成功!"); } void Input(Worker *p, int i) { int j, k; p->total = 0; printf("请输入第%d名职工的职工工号:", i + 1); scanf("%s", &p->no); printf("请输入第%d名职工的姓名:", i + 1); scanf("%s", &p->name); for (k = 0, j = 1; j <= 12, k < 12; j++, k++) p->month[k] = j; printf("请输入第%d名职工的月工资(用空格隔开):", i + 1); for (j = 0; j < 12; j++) { scanf("%f", &p->gz[j]); //输入每个月的工资 p->total += p->gz[j]; //计算总工资 } } void Print(Worker *L) //打印所有职工工资信息 { int i; Worker *p = L->next; while (p != NULL) { printf("职工编号:"); printf("%s\t\n", p->no); printf("姓名:"); printf("%s\n", p->name); printf("该职工12个月的月工资如下:"); for (i = 0; i < 12; i++) printf("%.2f ", p->gz[i]); printf("\n该职工的年度总工资为:"); printf("%.2f", p->total); printf("\n\n"); p = p->next; } } void Save(Worker *L) { int i; Worker *p = L->next; FILE *fp = fopen("WorkerSalaryInfo.txt", "w"); while (p != NULL) { fprintf(fp, "职工编号:"); fprintf(fp, "%s\t\n", p->no); fprintf(fp, "姓名:"); fprintf(fp, "%s\n", p->name); fprintf(fp, "该职工12个月的月工资如下:"); for (i = 0; i < 12; i++) fprintf(fp, "%.2f ", p->gz[i]); fprintf(fp, "\n该职工的年度总工资为:"); fprintf(fp, "%.2f", p->total); fprintf(fp, "\n\n"); p = p->next; } fclose(fp); printf("保存成功,已保存至当前目录下的‘WorkerSalaryInfo.txt'文件中"); } void menu() { printf("\t\t\t\t\t \n"); printf("\t\t\t\t\t▔▔▔▔▔▔▔欢迎进入工资管理系统▔▔▔▔▔▔▔\n"); printf("\t\t\t\t\t1.录入职工每个月的工资信息 \n"); printf("\t\t\t\t\t2.按姓名查找某个员工各月的工资 \n"); printf("\t\t\t\t\t3.按姓名查找某个职工的某个月的工资 \n"); printf("\t\t\t\t\t4.修改某个职工某个月的工资 \n"); printf("\t\t\t\t\t5.删除某个职工的相关信息 \n"); printf("\t\t\t\t\t6.插入职工工资信息 \n"); printf("\t\t\t\t\t7.统计某个职工年度总工资 \n"); printf("\t\t\t\t\t8.对职工的年度总工资进行从小到大排名 \n"); printf("\t\t\t\t\t9.输出所有职工工资信息 \n"); printf("\t\t\t\t\t10、将所有职工的工资信息保存至文件 \n"); printf("\t\t\t\t\t0.退出 \n"); printf("\t\t\t\t\t▁▁▁▁▁▁▁▁▁▁谢谢使用▁▁▁▁▁▁▁▁▁\n"); } int main() { int item, n, m; //item用于接收输入的命令,n用于接收输入的职工人数 float s; char nam[10]; Worker *L = (Worker*)malloc(sizeof(Worker)); L->next=NULL; do { system("cls"); menu(); printf("\n请输入相应的数字,进行相应的操作:\n"); scanf("%d", &item); switch (item) { case 1: printf("请输入您要录入的职工人数:"); scanf("%d", &n); L = CreateList(L, n); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 2: printf("请输入您要查找的职工姓名:"); scanf("%s", &nam); LIstSearch(L, nam); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 3: printf("请输入您要查找的职工的姓名:"); scanf("%s", &nam); printf("请输入您要查找该职工第几个月的工资(1到12):"); scanf("%d", &m); SearchMonthSalary(L, nam, m); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 4: printf("请输入您要修改的职工姓名:"); scanf("%s", &nam); printf("\n请输入您要修改的月份:"); scanf("%d", &m); printf("\n请输入您修改后的数据:"); scanf("%f", &s); Modify(L, nam, m, s); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 5: printf("请输入您要删除的职工姓名:"); scanf("%s", &nam); DeleteList(L, nam); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 6: InsertInfo(L); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 7: printf("请输入您要查询的职工姓名:"); scanf("%s",&nam); StatiTotal(L,nam); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 8: Bubble_sort(L); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 9: printf("全部职工的信息如下:\n\n"); Print(L); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 10: Save(L); getchar(); printf("\n请按任意键返回主菜单\n"); getchar(); break; case 0: printf("谢谢您使用工资管理系统,即将退出工资管理系统....."); exit(0); break; } printf("\n\n\n\n"); } while (item); return 0; }
部分运行结果截图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
C++11中std::move、std::forward、左右值引用、移动构造函数的测试问题
这篇文章主要介绍了C++11中std::move、std::forward、左右值引用、移动构造函数的测试,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-09-09
最新评论