收藏 分销(赏)

C语言课程设计报告_职工信息管理系统_结构体数组实现程序源代码.doc

上传人:二*** 文档编号:4518167 上传时间:2024-09-26 格式:DOC 页数:20 大小:54KB
下载 相关 举报
C语言课程设计报告_职工信息管理系统_结构体数组实现程序源代码.doc_第1页
第1页 / 共20页
本文档共20页,全文阅读请下载到手机保存,查看更方便
资源描述
. . //C语言课程设计 职工信息管理系统—构造体数组实现 #include <stdio.h> #include <stdlib.h> #include <string.h> struct employee { char num[10]; char name[15]; char sex[5]; char bm[20]; char zc[20]; int gz; }; int read_file(struct employee em[]); void menu(); void write_file(struct employee em[]); void add(); void select(); //查看职工所有信息 void zc_query(); //按职称查询 void num_del(); //按工号删除 void tongji(); //统计 void sort(); //排序 void num_modify(); //按工号修改职工信息 void save(); //保存信息 void disp(); //显示职工信息 void fh(); //返回主菜单 struct employee em[300]; //这个数组用来保存所有的职工信息 和文件里面的一致 int Number=0; //记录总的职工人数 也就是数组/文件里面的职工人数 void menu() { printf("\t***********************************************************************\n"); printf("\t* *\n"); printf("\t* 职工信息管理系统_构造体数组实现 *\n"); printf("\t* *\n"); printf("\t* [1] 增加职工信息 [2] 查看职工信息 *\n"); printf("\t* [3] 查找职工信息 [4] 删除职工信息 *\n"); printf("\t* [5] 统计 [6] 职工工资排列 *\n"); printf("\t* [7] 修改职工信息 [8] 保存职工信息 *\n"); printf("\t* [9] 显示职工信息 [0] 退出系统 *\n"); printf("\t* *\n"); printf("\t***********************************************************************\n"); } void main() { int choose=0; FILE *fp=NULL; char yesorno; if((fp=fopen("employee1.txt","rb+"))==NULL) { printf("\n=========>提示:文件不存在,是否要创立一个?(y/n)\n"); scanf("%c",&yesorno); if(yesorno=='y'||yesorno=='Y') { //这里仅为了建立文件 fp=fopen("employee1.txt","wb+"); fclose(fp); //关闭fp所指的文件,释放文件缓冲区 } else exit(0); } else { Number=read_file(em); //要是文件已经有数据 将数据初始化到数组中 } system("cls"); while(1) { menu(); printf("\t\t====>请选择:"); scanf("%d",&choose); system("cls"); switch(choose) { case 0: exit(0); //退出 break; case 1: add(); fh();//增加职工信息 break; case 2: select(); fh();//查看职工信息 break; case 3: zc_query(); fh();// 查找 break; case 4: num_del(); fh();//删除 break; case 5: tongji(); fh();//统计 break; case 6: sort(); fh();//排序 break; case 7: num_modify(); fh();//修改后返回 break; case 8: save(); fh();//保存 break; case 9: disp(); fh(); break;//显示 default: break; } fflush(stdin); getchar(); system("cls"); } } void save() { printf("\t=====程序在运行时已自动保存.....\n"); } void fh() { printf("\t===>按Enter键返回主菜单\n"); } void num_modify() //修改职工信息 { FILE *fp=NULL; char gh[60]; int i=0; int changeIndex=0; //changeIndex 改变标记 int index=0; printf("请输入要修改的职工工号:"); scanf("%s",gh); for (i=0;i<Number;i++) { if (strcmp(gh,em[i].num)==0) //比较输入工号和数组中已有工号 { changeIndex=i; //保存要修改的人的下标 break; } } printf("\t工号\tXX\t性别\t部门\t职称\t工资\n"); printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[changeIndex].num,em[changeIndex].name,em[changeIndex].sex,em[changeIndex].bm,em[changeIndex].zc,em[changeIndex].gz); printf("请重新输入该职工信息"); printf("工号:"); scanf("%s",em[changeIndex].num); printf("XX:"); scanf("%s",em[changeIndex].name); printf("性别:"); scanf("%s",em[changeIndex].sex); printf("部门:"); scanf("%d",em[changeIndex].bm); printf("职称:"); scanf("%s",em[changeIndex].zc); printf("工资:"); scanf("%d",&em[changeIndex].gz); //信息修改后重新更新文件里面的数据 以保持数据一致性 fp=fopen("employee1.txt","wb+"); for (i=0;i<Number;i++) { fwrite(&em[i],sizeof(struct employee),1,fp); //把ptr所指向n*size个字节输入到fp所指向的文件中 } fclose(fp); printf("\t=======>修改成功\n"); } void disp() //输出所有职工信息 { int i=0; for (i=0;i<Number;i++) { printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[i].num,em[i].name,em[i].sex,em[i].bm,em[i].zc,em[i].gz); } } void sort()//排序 { struct employee t; int wantNUmber=0; int i=0; int j=0; int k=0; for(i=0;i<Number-1;i++) {k=i; for(j=i+1;j<Number;j++) { if(em[j].gz>em[k].gz) k=j; } if(k!=i) { t=em[i]; em[i]=em[k]; em[k]=t; } } printf("你想输出前几名职工的信息:"); scanf("%d",&wantNUmber); if (wantNUmber>Number) { wantNUmber=Number; } printf("\t工号\tXX\t性别\t部门\t职称\t工资\n"); for(i=0;i<wantNUmber;i++) { printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[i].num,em[i].name,em[i].sex,em[i].bm,em[i].zc,em[i].gz); } } void tongji()//统计 { int i,m,k,max,min; double sum=0.0; for(i=0;i<Number;i++) { sum=sum+em[i].gz; } printf("全体职工的总工资为:%f\n",sum); printf("平均工资为:%f\n",sum/Number); i=0;m=0;max=0; max=em[m].gz; for(i=1;i<Number;i++) { if (em[i].gz>max) m=i; max=em[m].gz; } printf("最高工资为:%d\n",max); printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[m].num,em[m].name,em[m].sex,em[m].bm,em[m].zc,em[m].gz); i=0;k=0;min=0; min=em[0].gz; for(i=1;i<Number;i++) { if (em[i].gz<min) k=i; min=em[k].gz; } printf("最低工资:%d\n",min); printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[k].num,em[k].name,em[k].sex,em[k].bm,em[k].zc,em[k].gz); } void num_del()//按工号删除 { FILE *fp=NULL; char gh[60]; int i=0; int j=0; printf("请输入要删除的职工工号:"); scanf("%d",gh); for(i=0;i<Number;i++) { if (strcmp(gh,em[i].num)==0) //如果查找到就删除 { for (j=i;j<Number-1;j++) { em[j]=em[j+1]; } Number--; } } //将剩余数据写入文件 重新一写的方式翻开文件 把以前的数据擦除了 fp=fopen("employee1.dat","wb"); for (i=0;i<Number;i++) { fwrite(&em[i],sizeof(struct employee),1,fp); } fclose(fp); printf("删除成功;\n"); } void zc_query()//按职称查找 { char zc[20]; int i=0; printf("请输入要查找职工职称:"); scanf("%s",zc); system("cls"); printf("\t工号\tXX\t性别\t部门\t职称\t工资\n"); for (i=0;i<Number;i++) { if (strcmp(zc,em[i].zc)==0) { printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[i].num,em[i].name,em[i].sex,em[i].bm,em[i].zc,em[i].gz); } } } void select()//查看职工 { int i=0; printf("以下是全部职工信息\n"); printf("\t工号\tXX\t性别\t部门\t职称\t工资\n"); for(i=0;i<Number;i++) { printf("\t%s\t%s\t%s\t%s\t%s\t%d\n\n",em[i].num,em[i].name,em[i].sex,em[i].bm,em[i].zc,em[i].gz); } } void add()//增加职工 { int numberTemp=0; int i=0; struct employee temp; //临时保存信息 printf("请输入要增加职工信息的个数:"); scanf("%d",&numberTemp); for(i=0;i<numberTemp;i++) { printf("输入第%d个职工信息\n",i+1); printf("工号:"); scanf("%s",temp.num); printf("XX:"); scanf("%s",temp.name); printf("性别:"); scanf("%s",temp.sex); printf("部门:"); scanf("%s",temp.bm); printf("职称:"); scanf("%s",temp.zc); printf("工资:"); scanf("%d",&temp.gz); em[Number++]=temp; //将刚添加的写入到数组 write_file(&temp); //将刚添加的写入到文件 } printf("添加成功\n"); } void write_file(struct employee *em) { FILE *fp=NULL; fp=fopen("employee1.txt","rb+"); fwrite(em,sizeof(struct employee),1,fp); fclose(fp); } int read_file(struct employee em[]) { FILE *fp=NULL; int i=0; fp=fopen("employee1.txt","rb"); while(fread(&em[i],sizeof(struct employee),1,fp)) i++; fclose(fp); return i; } ?数据构造?课程设计任务书 设计题目 员工管理系统 限定人数 4 问题描述 每个员工的信息包括:编号、XX、性别、出生年月、学历、职务、、住址等。系统能够完成员工信息的查询、更新、插入、删除、排序等功能。 根本要求与说明 1、 职工信息保存在文本文件 2、 排序:按不同关键字,对所有员工的信息进展排序,并输出排序结果。 3、 查询:按特定条件查找员工。 4、 更新:按编号对某个员工的某项信息进展修改。 5、 插入:参加新员工的信息。 6、 删除:按编号删除已离职的员工的信息。 计算机科学与信息工程学院制 教育之通病是教用脑的人不用手,不教用手的人用脑,所以一无所能。教育革命的对策是手脑联盟,结果是手与脑的力量都可以大到不可思议。 . .word.zl.
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服