资源描述
. .
//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.
展开阅读全文