按照题目要求:
1、实现文件写入功能,一次写入一个职工信息。
2、实现查询功能(包含4种条件查询)。
3、实现信息删除和修改并写入文件。
根据题意,数据用结构数组存储,且职工编号唯一性,因此单独两个函数计算信息长度和编号。
除条件查询函数和读取文件的函数,不会自行free释放内存。如你写代码调用,注意自行写free语句释放。
下面是代码:
#include <stdio.h>
#include <malloc.h>
#include <string.h>
#include <windows.h>
#include <conio.h>
#define PATH "C:\\worker.data"
typedef struct worker//职员
{
int id;
char name[20];
int sex;//0:女。1:男
int byy;
int bmm;
int bdd;
}WR;
int write2File(char path[]);//写入文件,成功返回1,失败返回-1
int getLen(char path[]);//重新计算信息长度,成功返回1,失败返回-1
int getMaxId(char path[]);//获取最大的id,避免ID重复,成功返回1,失败返回-1
WR *readFormFile(char path[]);//读取文件内容到结构体数组,成功返回数组,失败返回NULL
void showWRS();//打印输出文件所有内容
WR *selectBy(WR *wrs,int n);//根据条件查询,查询成功返回查到的第一个节点(对于唯一的编号而言是精准查询),失败返回NULL。
//注意:该函数不会自动释放wrs内存,单独调用后需单独释放。单独调用n传0,在修改模块中调用n传1
int init();//初始化参数
int updateWr();//更新,成功返回1,失败返回-1
int showMenu();//菜单
int len=0;
int id=0;
int main()
{
init();
if(showMenu()==-1) return 1;
return 0;
}
int showMenu()
{
int n;
WR *wrs=NULL;;
while(1)
{
n=0;
printf("【职工档案管理系统】\n1、输入一个职工信息\n2、查询所有职工信息\n3、条件查询职工信息\n4、修改删除职工信息\n");
while(n<1 || n>4) scanf("%d",&n);
switch(n)
{
case 1:if(write2File(PATH)==-1) return -1; break;
case 2:showWRS(); break;
case 3:
wrs=readFormFile(PATH);
selectBy(wrs,0);
free(wrs);
break;
case 4:if(updateWr()==-1) return -1;break;
}
fflush(stdin);
printf("按任意键继续。。。。。"),getch();
system("cls");
}
}
int init()
{
if(getLen(PATH)!=-1 && getMaxId(PATH)!=-1) return 1;
return -1;
}
int updateWr()
{
int i,del=-1;
WR *wr=NULL,*wrs=NULL;
FILE *fp=NULL;
wrs=readFormFile(PATH);
if(!wrs) return -1;
wr=selectBy(wrs,1);
printf("请输入操作(1、删除,2、修改):");
while(del!=2 && del!=1)scanf("%d",&del);
if(del==2)
{
printf("请输入修改后职工信息:\n");
printf("请输入职工姓名:"),scanf("%s",wr->name);
printf("请选择职工性别(0:女。1:男):"),scanf("%d",&wr->sex);
printf("请输入职工生日(年月日用空格分隔):"),scanf("%d%d%d",&wr->byy,&wr->bmm,&wr->bdd);
}
if(remove(PATH)==-1) return -1;
if(!(fp=fopen(PATH,"w"))) return -1;
for(i=0;i<len;i++)
if(del==2 ||(del==1 && wr!=&wrs[i]))
fprintf(fp,"%d %s %d %d %d %d%s",wrs[i].id,wrs[i].name,wrs[i].sex,wrs[i].byy,wrs[i].bmm,wrs[i].bdd,"\n");
printf("更新成功!\n");
fclose(fp);
free(wrs);
return 1;
}
WR *selectBy(WR *wrs,int n)
{
int i;
WR swr,*sp=NULL;
if(!wrs) return NULL;
while(n<1 || n>4)printf("请输入筛选条件(1、编号,2、姓名,3、性别,4、出生日期):"),scanf("%d",&n);
switch(n)
{
case 1:printf("请输入要查找的编号:"),scanf("%d",&swr.id);break;
case 2:printf("请输入要查找的姓名:"),scanf("%s",swr.name);break;
case 3:printf("请输入要查找的性别(1、男,0、女):"),scanf("%d",&swr.sex);break;
case 4:printf("请输入职工出生日期(年月日用空格分隔):"),scanf("%d%d%d",&swr.byy,&swr.bmm,&swr.bdd);break;
}
printf("%8s %8s %8s %10s\n","职工编号","职工姓名","职工性别","职工年龄");
for(i=0;i<len;i++)
if((n==1 && wrs[i].id==swr.id) ||(n==2 && strcmp(wrs[i].name,swr.name)==0) ||(n==3 && wrs[i].sex==swr.sex) ||(n==4 && wrs[i].byy==swr.byy && wrs[i].bmm==swr.bmm && wrs[i].bdd==swr.bdd))
{
if(sp==NULL) sp=&wrs[i];
printf("%8d %8s %8s %04d-%02d-%02d\n",wrs[i].id,wrs[i].name,wrs[i].sex?"男":"女",wrs[i].byy,wrs[i].bmm,wrs[i].bdd);
}
return sp;
}
void showWRS()
{
int i;
WR *wrs=NULL;
wrs=readFormFile(PATH);
if(wrs)
{
printf("%8s %8s %8s %10s\n","职工编号","职工姓名","职工性别","职工年龄");
for(i=0;i<len;i++)
printf("%8d %8s %8s %04d-%02d-%02d\n",wrs[i].id,wrs[i].name,wrs[i].sex?"男":"女",wrs[i].byy,wrs[i].bmm,wrs[i].bdd);
}
free(wrs);
}
int getLen(char path[])
{
FILE *fp=NULL;
WR wr;
if(!(fp=fopen(path,"r"))) return -1;
len=0;
while((fscanf(fp,"%d%s%d%d%d%d",&wr.id,wr.name,&wr.sex,&wr.byy,&wr.bmm,&wr.bdd))!=-1)
len++;
fclose(fp);
return 1;
}
int getMaxId(char path[])
{
FILE *fp=NULL;
WR wr;
if(!(fp=fopen(path,"r"))) return -1;
len=0;
while((fscanf(fp,"%d%s%d%d%d%d",&wr.id,wr.name,&wr.sex,&wr.byy,&wr.bmm,&wr.bdd))!=-1)
if(id<wr.id) id=wr.id;
fclose(fp);
return 1;
}
WR *readFormFile(char path[])
{
int i;
FILE *fp=NULL;
WR *wrs=NULL;
getLen(path);
if(!(fp=fopen(path,"r"))) return NULL;
if(len==0) return NULL;
wrs=(WR *)malloc(sizeof(WR)*len);
if(!wrs) return NULL;
i=0;
while((fscanf(fp,"%d%s%d%d%d%d",&wrs[i].id,wrs[i].name,&wrs[i].sex,&wrs[i].byy,&wrs[i].bmm,&wrs[i].bdd))!=-1)i++;
fclose(fp);
return wrs;
}
int write2File(char path[])
{
FILE *fp=NULL;
WR wr;
if(!(fp=fopen(path,"a"))) return -1;
wr.id=id++;
printf("-----------------------------\n");
printf("请输入职工姓名:"),scanf("%s",wr.name);
printf("请选择职工性别(0:女。1:男):"),scanf("%d",&wr.sex);
printf("请输入职工生日(年月日用空格分隔):"),scanf("%d%d%d",&wr.byy,&wr.bmm,&wr.bdd);
printf("-----------------------------\n\n");
fprintf(fp,"%d %s %d %d %d %d%s",wr.id,wr.name,wr.sex,wr.byy,wr.bmm,wr.bdd,"\n");
fclose(fp);
len++;
return len;
}
这种需求建议去百度文库去搜索。职工档案管理系统--设计与实现
c语言程序大神帮忙设计一下?
1、实现文件写入功能,一次写入一个职工信息。2、实现查询功能(包含4种条件查询)。3、实现信息删除和修改并写入文件。根据题意,数据用结构数组存储,且职工编号唯一性,因此单独两个函数计算信息长度和编号。除条件查询函数和读取文件的函数,不会自行free释放内存。如你写代码调用,注意自行写free语句释放。
求C语言大神来编个程序呀。。。
设白皮有x块,则黑皮有(32-x)块,每块白皮是六边形,共6x条边,因每块白皮有三条边和黑皮连在一起,故黑皮共有3x条边,可得方程3x=5(32-x);所以:include"stdio.h"main(){ int x; for(x=1;x<32;x++) if(3*x==5*(32-x)) printf("黑皮块有%d块,白皮块有%d块!
求C语言大神帮忙编写一个程序,按要求写出来。
define MAX 20\/* userCode(<100字符): 自定义函数之原型声明 *\/ void rotate( int (*arrA)[MAX], int (*arrB)[MAX], int m, int n);int main(void){ int arrA[MAX][MAX], arrB[MAX][MAX], i, j, m, n;printf("请输入 m n: ");scanf("%d %d", &m, &n);printf("...
大神来帮忙用c语言编个程序啊!
include<stdio.h> int main(){ int year, month, day, sum = 0, leap;printf("please input year,month,day\\n");scanf("%d, %d, %d", &year, &month, &day);if(day > 0 && day < 32 && month < 13 && month > 0){ enum data {d1 = 1, d2, d3, d4, d5, d6, ...
C语言版数据结构程序设计求大神帮助
pS->elem[pS->top]=e; pS->top=pS->top+1; return 1; } int Pop(SqStack *pS,SElemType *pe) \/* 出栈 *\/ { if (pS->top==0) \/* 栈空 *\/ return 0; pS->top = pS->top - 1; *pe = pS->elem[pS->top]; return 1; } \/*队列(循环队列)的定义及基本操作*\/ typ...
用C语言怎么编写,求大神帮忙
中文是:一 继续请按1:1 输入英文或阿拉伯数字 :\/ include <stdio.h> include <string.h> int main() { char depot1[3][3][10] = {{"one","two","three"},{"1","2","3"},{"ONE","TWO","THREE"}};char depot2[3][3][10] = {{"一","二","三"},{"1","2","3...
跪求编程大神~用c语言编个程序
题目描述输入二叉树的先序遍历序列和中序遍历序列,输出该二叉树的后序遍历序列。输入第一行输入二叉树的先序遍历序列;第二行输入二叉树的中序遍历序列。输出输出该二叉树的后序遍历序列。示例输入ABDCEFBDAECF示例输出DBEFCA include <iostream>#include <cstring>#define MAX 50+3using namespace std;...
这题好难,求大神帮忙 C语言程序设计题
if( num[i]>='A' && num[i]<='Z' ){ bit = num[i] - 'A' + 10; }else{ bit = num[i] - '0'; } res += (p*bit); } return res;}\/\/ 10进制转为K进制存储 void toKbit(uLL num, int k, char buffer[]){ if( num == 0 ){ buf...
程序高手帮个忙,新手实在是做不来了。C语言程序设计,做任意一个就行了...
我回答第三题 include <stdio.h> include <stdlib.h> include <malloc.h>\/\/如果用链表的话申请空间要用这个头文件,本方法可以不用 include <string.h> pragma warning(disable:4996)\/\/该语句是屏蔽第4996号警告,可不要,typedef struct Node { long num;char name[10];float math;float ...
有没有C语言大神,给我讲讲这个程序怎么运行?一步步详细分析一下,拜托...
第一行的数字相当于标尺,表示第几个字符位,为方便后续说明 c表示输出一个字符,分别对应输出c1,c2,c3,c4和c5 '\\101'表示八进制101即十进制65对应的ASCII字符,为'A',所以c4='A''\\116'表示八进制116即十进制78对应的ASCII字符,为'N',所以c5='N''\\t'表示水平制表符Tab,当其前面有n个...