收藏 分销(赏)

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

上传人:w****g 文档编号:2727246 上传时间:2024-06-05 格式:DOC 页数:15 大小:31.54KB 下载积分:8 金币
下载 相关 举报
C语言专业课程设计职工信息标准管理系统结构体数组实现程序源代码.doc_第1页
第1页 / 共15页
C语言专业课程设计职工信息标准管理系统结构体数组实现程序源代码.doc_第2页
第2页 / 共15页


点击查看更多>>
资源描述
//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工号\t姓名\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("姓名:"); 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工号\t姓名\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工号\t姓名\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工号\t姓名\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("姓名:"); 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; }
展开阅读全文

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


开通VIP      成为共赢上传

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

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

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

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

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

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

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

客服