第一篇:代理商信息管理系统 c语言
C语言课程设计报告
班学号:
学号:
姓名:
指导教师:
年
月
C语言课程设计报告
题目要求
基本功能:代理商信息采集、浏览、查询;代理商信息的输入、浏览、修改、查询、统计等。
需求分析
实现代理商信息采集和代理商品信息输入功能,要提供结构体的输入操作;实现统计功能,要提供相应的统计操作;实现查询功能,要提供查找操作;实现修改弄能,要提供修改操作;另外,还要提供键盘式选择菜单以实现功能选择。
总体分析
整个系统应设计为代理商信息采集、浏览、查询;代理商信息输入、浏览、修改、查询、统计等模块。
数据结构
数据结构财通结构体数组。
算法设计
主菜单选择功能,通过判断输入的选择进入相应的处理模块,包括数据输入、数据统计、数据查询、数据删除等。程序流程如下图所示:
数据结构设计
程序定义了一个运营商加入日期的结构体: struct data
{
};
定义了运营商信息的结构体:
struct acmer
{
};int number;
//运营商的编号; char name[20];
//运营商姓名; char agentnum[20];
//销售量; char phonum[20];
//电话号码; char goods[20];
//商品; struct data time;
//加入日期; int year;
//运营商加入的年份; int month;
//运营商加入的月份; int day;
//运营商加入的日期;
模块设计
1.主函数
Main函数通过调用menu函数输入一个数字来选择用什么函数以实现相应功能,同时这个功能通过switch选择结构来调用:
int main()
{
struct acmer agent[100];int n,i,k;printf(“请输入要统计的代理商数目:”);scanf(“%d”,&n);printf(“请输入代理商信息:n”);for(i=1;i<=n;i++)input(i,agent);menu();while(scanf(“%d”,&k),k!=0){
switch(k){ case 1:for(i=1;i<=n;i++)
{output(i,agent);}menu();break;case 2:stat(n,agent);menu();break;case 3:search(n,agent);menu();break;case 4:amend(n,agent);menu();break;case 5:sort(n,agent);for(i=1;i<=n;i++)
}
}
{
printf(“[%d]”,i);output(i,agent);}
menu();break;case 6:n=add(n,agent);menu();break;case 7:cancel(n,agent);menu();break;default:printf(“errorn”);menu();break;} return 0;2.menu函数
Menu函数是用来辅助main函数提供键盘是菜单以实现选择功能的:
void menu()
{
printf(“1 输出n”);printf(“2 统计n”);printf(“3 查找n”);printf(“4 代理商信息修改n”);printf(“5 排名n”);printf(“6 添加n”);
} printf(“7 删除n”);printf(“0 结束程序”);3.代理商信息添加模块
首先调用add函数以确定输入代理商的数目,然后用input函数来输入代理商信息:
int add(int n,struct acmer agent[]){
void input(int i,struct acmer agent[]){
printf(“姓名:”);scanf(“%s”,agent[i].name);printf(“代理商编号:”);int k,i;printf(“请输入添加代理商数目:”);scanf(“%d”,&k);for(i=n+1;i<=n+k;i++){ } return n+k;input(i,agent);
} scanf(“%s”,agent[i].agentnum);printf(“联系方式:”);scanf(“%s”,agent[i].phonum);printf(“销售量:”);scanf(“%d”,&agent[i].number);printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);printf(“年:”);scanf(“%d”,&agent[i].time.year);printf(“月:”);scanf(“%d”,&agent[i].time.month);printf(“日:”);scanf(“%d”,&agent[i].time.day);4.代理商信息浏览
代理商信息浏览使用了output函数,可以同时输出代理商以及商品的所有信息:
void output(int i,struct acmer agent[]){
printf(“姓名:%s”,agent[i].name);printf(“代理商编号:%s”,agent[i].agentnum);printf(“联系方式:%s”,agent[i].phonum);printf(“销售量:%d”,agent[i].number);printf(“代理商品信息:%s”,agent[i].goods);
加
盟
时
printf(“间:%d %d %dn”,agent[i].time.year,agent[i].time.month,agent[i].time.day);} 5.数据删除
数据删除也是先读取数据文件中所有现存代理商信息。如果没有读到代理商则表示本身无记录,删除功能无法继续。
删除功能的实现主要在重新写文件时。通过比对需要删除的那条记录与已读取出的存放于结构体数组中的记录,如果相同,则跳过该条记录的重新写入,即重新写文件时,就会少了该条记录,于是完成删除功能。
int cancel(int n,struct acmer agent[])
{
char x[20];int i,j,flag,t;t=n;printf(“请输入要删除代理商的编号(按000结束删除):”);while(scanf(“%s,x”)!=EOF){ flag=0;
}
} if(strcmp(x,“000”)==0)break;for(i=1;i<=n;i++)
if(strcmp(x,agent[i].agentnum)==0){
} if(flag==0)
printf(“没有找到代理商信息n”);for(j=i+1;j<=n;j++)
agent[i]=agent[i+1];
flag=1;t--;break;return t;6.统计功能
统计功能主要统计销售量超过一定数量的运营商,使用了stat函数。若运营商超过给定数值k则输出该运营商信息,若未超过则不输出。void stat(int n,struct acmer agent[]){ int k,i,x;
} printf(“1:销售量超过k的代理商n”);printf(“2:排名前k的代理商n”);printf(“3:请选择,按4结束统计:”);while(scanf(“%d”,&x),x!=4){
} printf(“请输入k:”);scanf(“%d”,&k);switch(x){ case 1:for(i=1;i<=n;i++)
if(agent[i].number>k)
output(i,agent);break;case 2:sort(n,agent);for(i=1;i<=k;i++)output(i,agent);break;default:printf(“errorn”);} 7.修改模块
修改模块使用amend函数,当输入号码与已有号码一致时,输入新的商品信息,覆盖原有信息,若未发现输入号码,则输出“没有找到此人信息”。
void amend(int n,struct acmer agent[]){
} int i,k,flag=0;char x[20];printf(“请输入要修改的代理商编号:”);scanf(“%s”,x);for(i=1;i<=n;i++){
} if(flag==0)printf(“没有找到此人信息n”);if(strcmp(x,agent[i].agentnum)==0){
} break;flag=1;printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);else printf(“修改成功n”);8.查找模块
查找模块提供了两种查找方式,即按姓名查找和按编号查找。前者使用了if(strcmp(x,agent[i].name)==0)语句,后者使用了if(strcmp(x,agent[i].name)==0)语句来实现相应功能。void search(int n,struct acmer agent[]){ int k,i,flag=1;char x[20];printf(“1 按姓名查找”);printf(“2 按编号查找”);printf(“请选择查找方式:”);scanf(“%d”,&k);if(k==1){
printf(“请输入要查找代理商姓名:
scanf(”%s“,x);
for(i=1;i<=n;i++)
if(strcmp(x,agent[i].name)==0)
{
flag=0;
output(i,agent);break;
”);
}
if(flag==1)
printf(“没有此人信息n”);} if(k==2){
printf(“请输入要查找代理商编号:
scanf(”%s“,x);
if(strcmp(x,agent[i].name)==0)
{
flag=0;
output(i,agent);
break;
}
if(flag==1)
printf(”没有此人信息n“);} }
程序
#include
”);{
};struct acmer {
};void menu(){
printf(“1 输出n”);printf(“2 统计n”);printf(“3 查找n”);printf(“4 代理商信息修改n”);printf(“5 排名n”);printf(“6 添加n”);int number;char name[20];char agentnum[20];char phonum[20];char goods[20];struct data time;int year;int month;int day;
} printf(“7 删除n”);printf(“0 结束程序”);void input(int i,struct acmer agent[]){
} printf(“姓名:”);scanf(“%s”,agent[i].name);printf(“代理商编号:”);scanf(“%s”,agent[i].agentnum);printf(“联系方式:”);scanf(“%s”,agent[i].phonum);printf(“销售量:”);scanf(“%d”,&agent[i].number);printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);printf(“年:”);scanf(“%d”,&agent[i].time.year);printf(“月:”);scanf(“%d”,&agent[i].time.month);printf(“日:”);scanf(“%d”,&agent[i].time.day);void output(int i,struct acmer agent[]){
printf(“姓名:%s”,agent[i].name);printf(“代理商编号:%s”,agent[i].agentnum);printf(“联系方式:%s”,agent[i].phonum);printf(“销售量:%d”,agent[i].number);printf(“代理商品信息:%s”,agent[i].goods);printf(“
加
盟
时间:%d %d %dn”,agent[i].time.year,agent[i].time.month,agent[i].time.day);} int add(int n,struct acmer agent[]){
} int k,i;printf(“请输入添加代理商数目:”);scanf(“%d”,&k);for(i=n+1;i<=n+k;i++){ } return n+k;input(i,agent);int cancel(int n,struct acmer agent[]){ char x[20];int i,j,flag,t;t=n;printf(“请输入要删除代理商的编号(按000结束删除): while(scanf(”%s,x“)!=EOF){
flag=0;
if(strcmp(x,”000“)==0)
break;
for(i=1;i<=n;i++)
if(strcmp(x,agent[i].agentnum)==0)
{
for(j=i+1;j<=n;j++)
agent[i]=agent[i+1];
flag=1;
t--;
break;
}
if(flag==0)printf(”没有找到代理商信息n“);”);
} } return t;void sort(int n,struct acmer agent[]){
} void stat(int n,struct acmer agent[]){
int k,i,x;printf(“1:销售量超过k的代理商n”);printf(“2:排名前k的代理商n”);printf(“3:请选择,按4结束统计:”);struct acmer t;int i,j;for(i=1;i<=n-1;i++)
for(j=1;j<=n-1;j++)
if(agent[j].number } t=agent[j];agent[j]=agent[j+1];agent[j+1]=t; } while(scanf(“%d”,&x),x!=4){ } printf(“请输入k:”);scanf(“%d”,&k);switch(x){ case 1:for(i=1;i<=n;i++) if(agent[i].number>k) output(i,agent);break;case 2:sort(n,agent);for(i=1;i<=k;i++)output(i,agent);break;default:printf(“errorn”);} void amend(int n,struct acmer agent[]){ int i,k,flag=0;char x[20];printf(“请输入要修改的代理商编号:”);scanf(“%s”,x); } for(i=1;i<=n;i++){ } if(flag==0)printf(“没有找到此人信息n”);if(strcmp(x,agent[i].agentnum)==0){ } break;flag=1;printf(“代理商品信息:”);scanf(“%s”,agent[i].goods);else printf(“修改成功n”);void search(int n,struct acmer agent[]){ int k,i,flag=1;char x[20];printf(“1 按姓名查找”);printf(“2 按编号查找”);printf(“请选择查找方式:”); scanf(“%d”,&k);if(k==1){ printf(“请输入要查找代理商姓名:”);scanf(“%s”,x);for(i=1;i<=n;i++) if(strcmp(x,agent[i].name)==0) { flag=0; output(i,agent); break; } if(flag==1)printf(“没有此人信息n”);} if(k==2){ printf(“请输入要查找代理商编号: scanf(”%s“,x);if(strcmp(x,agent[i].name)==0) { flag=0; ”); } output(i,agent);break;if(flag==1)printf(“没有此人信息n”);} } int main(){ struct acmer agent[100];int n,i,k;printf(“请输入要统计的代理商数目: scanf(”%d“,&n);printf(”请输入代理商信息:n“);for(i=1;i<=n;i++)input(i,agent);menu();while(scanf(”%d“,&k),k!=0){ switch(k) { case 1:for(i=1;i<=n;i++) ”); } } {output(i,agent);}menu();break;case 2:stat(n,agent);menu();break;case 3:search(n,agent);menu();break;case 4:amend(n,agent);menu();break;case 5:sort(n,agent); for(i=1;i<=n;i++){ printf(“[%d]”,i);output(i,agent);} menu();break;case 6:n=add(n,agent);menu();break;case 7:cancel(n,agent);menu();break;default:printf(“errorn”);menu();break;} return 0; 上机操作 1. 数据源 2. 编译、链接和运行 3. 运行结果 下为各界面图: 主函数 输入板块 浏览板块 在主界面输入1后按enter键 统计板块 在主界面输入2后按enter键 查找板块 在主界面输入后按enter键 添加板块 小结 通过本次实习,我对C语言有了更一步的理解与掌握,这一切离不开老师的教育和同学们的帮助,所以我十分感谢我的老师。本次实习过程中,遇到了不少困难,但本着一颗执着的心,加上老师耐心的帮助,我克服了一个个困难,并最终完成了任务,所以这次的实习对我的帮助很大,不仅在学习上取得了更多了收货,也进一步锻炼了我克服困难的勇气和决心,另外我发现自己C语言的兴趣越来越浓厚,希望在以后的学习生活中能更多机会的接触C语言,并能对C语言有更深一步的了解和掌握。也许会遇到困难,但只要做好每一个步骤,保证每个步骤的准确性,就一定会取得成功。再次谢谢老师的教育和同学们的帮助。 #include char num[8];/*学号*/ char name[9];/*姓名*/ char gender[3];/*性别*/ int score;/*成绩*/ }DataType; typedef struct { DataType stu[MAXSIZE]; int length;}sequenlist; int menu_select(){ int sn;printf(“n 学生信息管理系统n”);printf(“=========================================n”);printf(“ 1.学生信息顺序表的建立n”);printf(“ 2.插 入 学 生 信 息n”);printf(“ 3.查 询 学 生 信 息n”);printf(“ 4.删 除 学 生 信 息n”);printf(“ 5.输 出 所有学生信息n”);printf(“ 0.退 出 管 理 系 统n”);printf(“==========================================n”); printf(“请选择0-5:n”);for(;;){ scanf(“%d”,&sn);if(sn<0 || sn>5) printf(“nt输入错误,重选0-5n”); else break;} return sn;} void createList(sequenlist *L){ int n,i;printf(“有几位学生?请输入:n”);fflush(stdin);scanf(“%d”,&n);printf(“以下请输入这%d位学生的信息:n”,n);for(i=0;i printf(“第%d位学生:”,i); printf(“n学号(8) 姓名(8)性别 成绩n”); fflush(stdin); scanf(“%s%s%s%d”,L->stu[i].num,L->stu[i].name,L->stu[i].gender,&L->stu[i].score);} L->length=n;} void printList(sequenlist *L){ int i;printf(“n学号(8) 姓名(8)性别 成绩n”);printf(“------------n”);for(i=0;i printf(“第%d位学生:”,i); printf(“%s,%s,%s,%dn”,L->stu[i].num,L->stu[i].name,L->stu[i].gender,L->stu[i].score); printf(“----n”);} } int insert(sequenlist *L,DataType *student,int i){ int j;if(L->length==MAXSIZE){ printf(“overflow!”); return 0;} else if((i<0)||(i>L->length)){ printf(“error,please input the right 'i'”); return 0;} else { for(j=L->length-1;j>=i;j--) { strcpy(L->stu[j+1].num,L->stu[j].num); strcpy(L->stu[j+1].name,L->stu[j].name); strcpy(L->stu[j+1].gender,L->stu[j].gender); L->stu[j+1].score=L->stu[j].score; } strcpy(L->stu[i].num,student->num); strcpy(L->stu[i].name,student->name); strcpy(L->stu[i].gender,student->gender); L->stu[i].score=student->score; L->length=L->length+1; } return 1;} int findList(sequenlist *L){ char num[8];char name[9];int i=0,xz;printf(“===========================n”); printf(“ 1、按学号查询n”);printf(“ 2、按姓名查询n”);printf(“===========================n”);printf(“ 请选择: ”);fflush(stdin);scanf(“%d”,&xz);if(xz==1){ printf(“请输入要查找学生的学号:”); scanf(“%s”,num); for(i=0;i { if(strcmp(L->stu[i].num,num)==0) return i; } } else if(xz==2){ printf(“请输入要查找学生的姓名:”); scanf(“%s”,name); for(i=0;i { if(strcmp(L->stu[i].name,name)==0) return i; } } return-1;/*如果没找到,返回-1。否则直接返回,不会执行本句*/ } void delNode(sequenlist *L){ int i,j; printf(“请先查找您要删除的学生信息:n”);i=findList(L);if(i==-1){ printf(“没有查到要删除的学生信息”); return;} for(j=i;j L->stu[j].score=L->stu[j+1].score; strcpy(L->stu[j].num,L->stu[j+1].num); strcpy(L->stu[j].name,L->stu[j+1].name); strcpy(L->stu[j].gender,L->stu[j+1].gender);} L->length--;printf(“该学生信息已被删除!n”);} void main(){ sequenlist *L; DataType *student; int i; L=(sequenlist *)malloc(sizeof(sequenlist)); while(1){ switch(menu_select()) { case 1: printf(“**************************************n”); printf(“ 学生信息顺序表的建立 n”); printf(“***************************************n”); createList(L); break; case 2: printf(“**************************************n”); printf(“添加学生信息n”); printf(“请输入要添加的学生信息:n”);printf(“n学号(8) 姓名(8)性别 成绩n”); printf(“**************************************n”); student=(DataType *)malloc(sizeof(DataType)); fflush(stdin); scanf(“%s%s%s%d”,student->num,student->name,student->gender,&student->score); printf(“请输入要插入的位置:n”); fflush(stdin); scanf(“%d”,&i); insert(L,student,i); break; case 3: printf(“**************************************n”); printf(“查询学生信息n”); printf(“**************************************n”); i=findList(L); if(i!=-1) { printf(“您要查的学生为:n学号(8) 姓名(8)性别 成绩n”); printf(“------------n”); printf(“%s,%s,%s,%dn”,L->stu[i].num,L->stu[i].name,L->stu[i].gender,L->stu[i].score); printf(“----n”); } else printf(“没有您要查询的学生信息!”); break; case 4: printf(“**************************************n”); printf(“删除学生信息n”); printf(“**************************************n”); delNode(L); break; case 5: printf(“**************************************n”); printf(“输出所有学生信息n”); printf(“**************************************n”); printList(L); break; case 0: printf(“再见!n”);getchar(); return; } } } #include void lookup(int snum[],int sc[],int length); void summary(int sc[],int length); void change(int n,int snum[],int sc[],int length);void search(int n,int snum[],int sc[],int length);void input(int snum[],int sc[],int length); void main() { int snumber[5]; int score[5]; int choice; int password; char usename; int i=0,j=0,sum=0,min=100,max=0,x=0,flag=0;int number; cout<<“**********************”<<'n';cout<<“欢迎使用学生信息管理系统”<<'n';cout<<“**********************”<<'n';cout<<“1.登陆”<<'n'; cout<<“2.退出”<<'n'; cout<<“3.请选择:”< cin>>choice; if(choice==1) { do { cout<<“请输入用户名”<<'n'; cin>>usename; cout<<“请输入密码”< cin>>password; if(usename!='1'||password!=123) cout<<“用户名或密码错误,请重新输入”< do { cout<<“欢迎使用学生信息管理系统”<<'n';cout<<“**********************”<<'n';cout<<“1.学生信息输入 ”<<'n'; cout<<“2.学生信息查看”<<'n'; cout<<“3.学生信息查找”<<'n'; cout<<“4.学生信息修改 ”<<'n'; cout<<“5.汇总”<<'n'; cout<<“6.退出 ”<<'n'; cout<<“请选择:”< cin>>choice; switch(choice) { case 1:///输入///// input(snumber,score,5); break; case 2: //////查看////// lookup(snumber,score,5); break; case 3://---查询---// cout<<“输入查询学生学号:”<<'n'; cin>>number;search(number,snumber,score,10);break; case 4: ////修改///// cout<<“输入修改学生学号:”<<'n';cin>>number; change(number,snumber,score,10);break; case 5:////汇总////// summary(score,5); }break; }while(choice!=6); } } ///////////////////////////////////////////////////////////////////// ///////输入 void input(int snum[],int sc[],int length) { int i=0; for(int x=0;x snum[x]=x+1; cout< cin>>sc[x]; } } ////////查找 void search(int n,int snum[],int sc[],int length) { int flag=0; for(int i=0;i {if(n==snum[i]){cout< ////////修改 void change(int n,int snum[],int sc[],int length){ int flag=0;int x;for(int i=0;i if(n==snum[i]) { cout< sc[i-1]=x; flag=1; } }if(flag!=1)cout<<“错误!找不到该学生信息”< } ////////查看 void lookup(int snum[],int sc[],int length) { int i=0,j=0,t,p,x=0,flag=0,choice;cout<<“1.按学号查看”< cout<<“2.按成绩查看”< t=sc[j];p=snum[j]; sc[j]=sc[j+1];snum[j]=snum[j+1];sc[j+1]=t;snum[j+1]=p; } } } for(j=0;j cout< } if(choice==2) { for(i=0;i { for(j=0;j {if(sc[j] { t=sc[j];p=snum[j]; sc[j]=sc[j+1];snum[j]=snum[j+1];sc[j+1]=t;snum[j+1]=p;} }} for(j=0;j cout< } /////////汇总 void summary(int sc[],int length) { inti=0,j=0,sum=0,min=100,max=0;int ave; do{ for(i=0;i<5;i++) { if(sc[i]<60) j++; if(max max=sc[i]; if(min>sc[i]) min=sc[i]; sum=sum+sc[i]; }}while(i>length); ave=sum/length; cout<<“总分为”< cout<<“不及格人数”< cout<<“平均分为”< #include int num;char name[10];char sex; int age;char xueli[30]; int wage; char addr[30]; long int tel;}em[100]; /*定义一个结构体*/ void menu();void input();void save(int);void display();void del();void add();void search();void search_num();void search_xueli();void search_tel();void modify();/*定义各函数*/ void menu() /*菜单函数*/ { printf(“ ☆☆☆计算机科学与技术学系☆☆☆n”); printf(“n”); printf(“ ∮08802班 关丽霞∮n”); printf(“n”);printf(“ ******************职工信息管理****************n”);printf(“ 1.录入职工信息”);printf(“ 2.浏览职工信息n”);printf(“ 3.查询职工信息”);printf(“ 4.删除职工信息n”); printf(“ 5.添加职工信息”);printf(“ 6.修改职工信息n”);printf(“ 7.退出n”);printf(“ ********************谢谢使用******************n”); printf(“n”); printf(“n”); } void main(){ menu();/*调用菜单函数*/ int n,flag;char a;do { printf(“请选择你需要操作的步骤(1--7):n”); scanf(“%d”,&n); if(n>=1&&n<=7) { flag=1; break; } else { flag=0; printf(“您输入有误,请重新选择!”); } } while(flag==0); while(flag==1) { switch(n) { case 1:printf(“ ◆◆◆输入职工信息◆◆◆n”);printf(“n”);input();break; case 2:printf(“ ◆◆◆浏览职工信息◆◆◆n”);printf(“n”);display();break; case 3:printf(“ ◆◆◆按职工号查询职工信息◆◆◆n”);printf(“n”);search();break; case 4:printf(“ ◆◆◆删除职工信息◆◆◆n”);printf(“n”);del();break; case 5:printf(“ ◆◆◆添加职工信息◆◆◆n”);printf(“n”);add();break; case 6:printf(“ ◆◆◆修改职工信息◆◆◆n”);printf(“n”);modify();break; case 7:exit(0);break; default :break; } getchar(); printf(“n”); printf(“是否继续进行(y or n):n”); scanf(“%c”,&a); if(a=='y') { flag=1; system(“cls”);/*清屏*/ menu();/*调用菜单函数*/ printf(“请再次选择你需要操作的步骤(1--6):n”); scanf(“%d”,&n); printf(“n”); } else exit(0);} } void input() /*录入函数*/ { int i,m; printf(“请输入需要创建信息的职工人数(1--100):n”); scanf(“%d”,&m); for(i=0;i { printf(“职工号: ”); srand((int)time(0)); em[i].num=rand()%10000+20000000; if(em[i].num!=em[i-1].num) printf(“%8d ”,em[i].num); printf(“n”); printf(“请输入姓名: ”); scanf(“%s”,em[i].name); getchar(); printf(“请输入性别(f--女 m--男): ”); scanf(“%c”,&em[i].sex); printf(“请输入年龄: ”); scanf(“%d”,&em[i].age); printf(“请输入学历: ”); scanf(“%s”,em[i].xueli); printf(“请输入工资: ”); scanf(“%d”,&em[i].wage); printf(“请输入住址: ”); scanf(“%s”,em[i].addr); printf(“请输入电话: ”); scanf(“%d”,&em[i].tel); printf(“n”); } printf(“n创建完毕!n”); save(m);} void save(int m)/*保存文件函数*/ { int i;FILE*fp;if((fp=fopen(“employee_list”,“wb”))==NULL)/*创建文件并判断是否能打开*/ { printf(“cannot open filen”); exit(0);} for(i=0;i if(fwrite(&em[i],sizeof(struct employee),1,fp)!=1) printf(“file write errorn”); fclose(fp);} int load()/*导入函数*/ { FILE*fp;int i=0; if((fp=fopen(“employee_list”,“rb”))==NULL){ printf(“cannot open filen”); exit(0);} else { do { fread(&em[i],sizeof(struct employee),1,fp); i++; } while(feof(fp)==0);} fclose(fp);return(i-1);} void display()/*浏览函数*/ { int i;int m=load();printf(“n 职工号t姓名t性别t年龄t学历t工资t住址t电话 n”);for(i=0;i printf(“n %dt%st%ct%dt%st%dt%st%ldn”,em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel); } void del() /*删除函数*/ { int m=load();int i,j,n,t,flag;char name[20];printf(“n 原来的职工信息:n”); display(); /* 调用浏览函数*/ printf(“n”);printf(“请输入要删除的职工的姓名:n”);scanf(“%s”,name);for(flag=1,i=0;flag&&i if(strcmp(em[i].name,name)==0) { printf(“n已找到此人,原始记录为:n”); printf(“n职工号t姓名t性别t年龄t学历t工资t住址t电话 n”); printf(“n%dt%st%ct%dt%st%dt%st%ldn”,em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel); printf(“n确实要删除此人信息请按1,不删除请按0n”); scanf(“%d”,&n); if(n==1) /*如果删除,则其他的信息都往上移一行*/ { for(j=i;j { strcpy(em[j].name,em[j+1].name); em[j].num=em[j+1].num; em[j].sex=em[j+1].sex; em[j].age=em[j+1].age; strcpy(em[j].xueli,em[j+1].xueli); em[j].wage=em[j+1].wage; strcpy(em[j].addr,em[j+1].addr); em[j].tel=em[j+1].tel; } flag=0; } } } if(!flag) m=m-1;else printf(“n对不起,查无此人!n”); printf(“n 浏览删除后的所有职工信息:n”); save(m); /*调用保存函数*/ display();/*调用浏览函数*/ printf(“n继续删除请按1,不再删除请按0n”);scanf(“%d”,&t);switch(t){ case 1:del();break; case 0:break; default :break;} } void add()/*添加函数*/ { FILE*fp;int n; int count=0; int i; int m=load(); printf(“n 原来的职工信息:n”); display(); /* 调用浏览函数*/ printf(“n”); fp=fopen(“emploee_list”,“a”); printf(“请输入想增加的职工数:n”);scanf(“%d”,&n); for(i=m;i<(m+n);i++) { printf(“n 请输入新增加职工的信息:n”); printf(“请输入职工号: ”); srand((int)time(0)); em[i].num=rand()%10000+20000000; if(em[i].num!=em[i-1].num) printf(“%8d ”,em[i].num); printf(“n”); printf(“请输入姓名: ”); scanf(“%s”,em[i].name); getchar(); printf(“请输入性别(f--女 m--男): ”); scanf(“%c”,&em[i].sex); printf(“请输入年龄: ”); scanf(“%d”,&em[i].age); printf(“请输入学历: ”); scanf(“%s”,em[i].xueli); printf(“请输入工资: ”); scanf(“%d”,&em[i].wage); printf(“请输入住址: ”); scanf(“%s”,em[i].addr); printf(“请输入电话: ”); scanf(“%d”,&em[i].tel); printf(“n”); count=count+1; printf(“已增加的人数:n”); printf(“%dn”,count);} printf(“n添加完毕!n”); m=m+count;printf(“n浏览增加后的所有职工信息:n”);printf(“n”);save(m); display(); fclose(fp);} void search()/*查询函数*/ { int t,flag;do { printf(“n按职工号查询请按1;按学历查询请按2;按电话号码查询请按3,进入主函数按4n”); scanf(“%d”,&t); if(t>=1&&t<=4) { flag=1; break; } else { flag=0; printf(“您输入有误,请重新选择!”); } } while(flag==0); while(flag==1){ switch(t) { case 1:printf(“按职工号查询n”);search_num();break; case 2:printf(“按学历查询n”);search_xueli();break; case 3:printf(“按电话号码查询n”);search_tel();break; case 4:main();break; default:break; } } } void search_num(){ int num; int i,t; int m=load(); printf(“请输入要查找的职工号(20001111---20009999):n”); scanf(“%d”,&num); for(i=0;i if(num==em[i].num){ printf(“n已找到此人,其记录为:n”); printf(“n职工号t姓名t性别t年龄t学历t工资t住址t电话 n”); printf(“n%dt%st%ct%dt%st%dt%st%ldn”,em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel); break;} if(i==m) printf(“n对不起,查无此人n”); printf(“n”); printf(“返回查询函数请按1,继续查询职工号请按2n”); scanf(“%d”,&t); switch(t) { case 1:search();break; case 2: break; default:break; } } void search_xueli(){ char xueli[30]; int i,t; int m=load(); printf(“请输入要查找的学历:n”); scanf(“%s”,xueli); for(i=0;i if(strcmp(em[i].xueli,xueli)==0){ printf(“n已找到,其记录为:n”); printf(“n职工号t姓名t性别t年龄t学历t工资t住址t电话 n”); printf(“n%dt%st%ct%dt%st%dt%st%ldn”,em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel); } if(i==m) printf(“n对不起,查无此人n”); printf(“n”); printf(“返回查询函数请按1,继续查询学历请按2n”); scanf(“%d”,&t); switch(t) { case 1:search();break; case 2:break; default :break; } } void search_tel(){ long int tel; int i, t; int m=load(); printf(“请输入要查找的电话号码:n”); scanf(“%ld”,&tel); for(i=0;i if(tel==em[i].tel){ printf(“n已找到此人,其记录为:n”); printf(“n职工号t姓名t性别t年龄t学历t工资t住址t电话 n”); printf(“n%dt%st%ct%dt%st%dt%st%ldn”,em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel); break;} if(i==m) printf(“n对不起,查无此人n”); printf(“n”); printf(“返回查询函数请按1,继续查询电话号码请按2n”); scanf(“%d”,&t); switch(t) { case 1:search();break; case 2:break; default :break; } } void modify()/*修改函数*/ { int num;char name[10];char sex; int age;char xueli[30]; int wage; char addr[30]; long int tel; int b,c,i,n,t,flag; int m=load();/*导入文件内的信息*/ printf(“n 原来的职工信息:n”); display(); /* 调用浏览函数*/ printf(“n”); printf(“请输入要修改的职工的姓名:n”);scanf(“%s”,name);for(flag=1,i=0;flag&&i if(strcmp(em[i].name,name)==0) { printf(“n已找到此人,原始记录为:n”); printf(“n职工号t姓名t性别t年龄t学历t工资t住址t电话 n”); printf(“n%dt%st%ct%dt%st%dt%st%ldn”,em[i].num,em[i].name,em[i].sex,em[i].age,em[i].xueli,em[i].wage,em[i].addr,em[i].tel); printf(“n确实要修改此人信息请按1;不修改请按0n”); scanf(“%d”,&n); if(n==1) { printf(“n需要进行修改的选项n 1.职工号 2.姓名 3.性别 4.年龄 5.学历 6.工资 7.住址 8.电话n”); printf(“请输入你想修改的那一项序号:n”); scanf(“%d”,&c); if(c>8||c<1) printf(“n选择错误,请重新选择!n”); } flag=0; } } if(flag==1)printf(“n对不起,查无此人!n”); do { switch(c) /*因为当找到第i个职工时,for语句后i自加了1,所以下面的应该把改后的信息赋值给第i-1个人*/ { case 1:printf(“职工号改为: ”); scanf(“%d”,&num); em[i-1].num=num; break; case 2:printf(“姓名改为: ”); scanf(“%s”,name); strcpy(em[i-1].name,name); break; case 3:printf(“性别改为: ”); getchar(); scanf(“%c”,&sex); em[i-1].sex=sex; break; case 4:printf(“年龄改为: ”); scanf(“%d”,&age); em[i-1].age=age; break; case 5:printf(“学历改为: ”); scanf(“%s”,xueli); strcpy(em[i-1].xueli,xueli); break; case 6:printf(“工资改为: ”); scanf(“%d”,wage); break; case 7:printf(“住址改为: ”); scanf(“%s”,addr); strcpy(em[i-1].addr,addr); break; case 8:printf(“电话改为: ”); scanf(“%ld”,&tel); em[i-1].tel=tel; break; } printf(“n”); printf(“n是否确定所修改的信息?n 是 请按1;不,重新修改 请按2: n”); scanf(“%d”,&b); } while(b==2); printf(“n浏览修改后的所有职工信息:n”); printf(“n”); save(m); display(); printf(“n继续修改请按1,不再修改请按0n”); scanf(“%d”,&t); switch(t){ case 1:modify();break; case 0:break; default :break;} } #include /* 单链表内容有无发生改变,是否需要存盘的标志变量 */ struct employee { }; typedef struct Node { void InitList(LinkList *head) /*将单链表初始化为空。动态生成一个头结点,并将头结点的指针域置为空*/ { } ListNode *Locatenum(LinkList head,char find[]) //通过职工工号查找,返回定位指针。{ LinkList p;if((*head=(LinkList)malloc(sizeof(ListNode)))==NULL) /*为头结点分配一 printf(“系统分配存储空间失败!n”);个存储空间*/ exit(-1);(*head)->next=NULL; /*将头结点的指针域置为空*/ struct employee data;struct Node *next;char num[10]; /* 工号 */ char name[15]; /* 姓名 */ char sex[7]; /* 性别 */ int age; /* 年龄 */ char education[15]; /* 学历 */ int salary; /* 工资 */ char phone[20]; /* 电话号码 */ char address[30]; /* 住址 */ }ListNode,*LinkList; } p=head->next;if(!p) //如果职工信息记录为空,返回NULL。 { } return NULL;if(strcmp(p->data.num,find)==0)return p;p=p->next;return NULL;while(p)ListNode *Locatename(LinkList head,char find[]) //通过职工姓名查找,返回定位指针。{ } ListNode *Locatesalary(LinkList head,int salary) //通过职工工资查找,返回定位指针。{ LinkList p;p=head->next;if(!p) //如果职工信息记录为空,返回NULL。 return NULL;while(p){ LinkList p;p=head->next;if(!p) //如果职工信息记录为空,返回NULL。 { } return NULL;if(strcmp(p->data.name,find)==0)return p;p=p->next;return NULL;while(p) } } if(p->data.salary==salary)return p;p=p->next;return NULL;void Nofind(){ } void Modify(LinkList L) //修改功能。{ ListNode *p; char find[20]; if(!L->next) { printf(“请你输入要修改的职工工号:”); scanf(“%s”,find); p=Locatenum(L,find); if(p) { printf(“请你输入新的工号(原来是%s):”,p->data.num); scanf(“%s”,p->data.num); getchar(); printf(“n”); printf(“请你输入新的姓名(原来是%s):”,p->data.name); scanf(“%s”,p->data.name); getchar(); printf(“n”); printf(“n***提示***:没有资料可以修改!n”); return;printf(“n***提示***:没有找到该职工!n”); } printf(“请你输入新的性别(原来是%s):”,p->data.sex); scanf(“%s”,p->data.sex); getchar(); printf(“n”); printf(“请你输入新的年龄(原来是%d):”,p->data.age); scanf(“%d”,&p->data.age); printf(“n”); printf(“请你输入新的学历(原来是%s):”,p->data.education); scanf(“%s”,p->data.education); getchar(); printf(“n”); printf(“请你输入新的工资(原来是%d):”,p->data.salary); scanf(“%d”,&p->data.salary); printf(“n”); printf(“请你输入新的电话(原来是%s):”,p->data.phone); scanf(“%s”,p->data.phone); getchar(); printf(“n”); printf(“请你输入新的住址(原来是%s):”,p->data.address); scanf(“%s”,p->data.address); getchar(); printf(“n”); printf(“n***提示***:资料修改成功!n”); saveflag=1; } else Nofind();//if(p)结束 } //void Modify(LinkList L) //修改功能结束 void Add(LinkList head) /* 录入职工信息 */ { system(“cls”);ListNode *p,*r,*s; /* 实现添加操作的临时的结构体指针变量 */ int sign; /* 标记重复工号的变量 */ char num[10];r=head;s=head->next; /* 链表没有节点时,s=NULL;链表有节点时,指向while(r->next!=NULL)/* 如果存在后继结点时,r指针后移一个 */ r=r->next; /* 将指针移至于链表最末尾,准备添加记录 */ printf(“输入‘#’将退出职工信息录入,退回至主菜单!nn”);while(1){ printf(“(PS:职工号为‘#’即退出录入功能)nn”);printf(“请输入职工号:”);fflush(stdin); //清除缓冲区。gets(num);if(strcmp(num,“#”)==0)/* 输入‘0’,跳出while(1),即跳出Add()函数 */ break;s=head->next; /* 每次从第一个节点开始找,看num是否重 while(s){ if(strcmp(s->data.num,num)==0){ } s=s->next;printf(“***提示***n工号为:‘%s’的职工信息已经存在!printf(”若要修改请按‘4’,放弃请按‘0’!n“);scanf(”%d“,&sign);if(sign==4) Modify(head);return;else 第一个职工节点 */ 复。*/ n”,num);}//while(s)if((p=(LinkList)malloc(sizeof(ListNode)))==NULL)//生成没赋值的新节点 p。 { } strcpy(p->data.num,num);printf(“n”);printf(“请输入该职工姓名:”);scanf(“%s”,p->data.name);getchar();printf(“n”);printf(“请输入该职工的性别:(注:男性:male;女性:female)”);scanf(“%s”,p->data.sex);getchar();printf(“n”);printf(“请输入该职工的年龄:”);scanf(“%d”,&p->data.age);printf(“n”);printf(“请输入该职工的学历:”);scanf(“%s”,p->data.education);getchar();printf(“n”);printf(“请输入该职工的工资:”);scanf(“%d”,&p->data.salary);printf(“n”);printf(“请输入该职工的电话号码:”);scanf(“%s”,p->data.phone);getchar();printf(“n”);printf(“请输入该职工的住址:”);gets(p->data.address);printf(“n”);p->next=NULL; /* 表明这是链表的尾部结点 */ r->next=p; /* 将新建的结点加入链表尾部中 */ r=p;saveflag=1;printf(“n”);printf(“系统分配存储空间失败!n”);printf(“退出程序!n”);exit(-1);}//while(1)}//void Add函数结束。 void printline() //打印横线。{ } void printsubject() //打印各分类标题。{ } void printLinkList(LinkList p) //打印p结点各个数据成员的值。{ printf(“ %s %s %s %d %s %d %s %sn”,p->data.num,p->data.name,p->data.sex,p->data.age,p->data.education,p->data.salary,p->data.phone,p->data.address);} void Allemployeeinfo(LinkList head)//显示所有职工信息。{ int count=0;ListNode *p;p=head->next;if(!p){ } printf(“tttt显示结果n”);printline();printsubject();printf(“n”);while(p)printf(“***提示***:目前没有存储任何职工记录!n”);printf(“返回主菜单,请重新选择功能!n”);return;printf(“ 工 号t 姓 名 性 别 年 龄 学 历 工 资 电 话tt 住 址n”);printf(“------------------n”); } { } printline();printf(“n”);printf(“已经存储了%d条职工信息!n”,count);printLinkList(p);p=p->next;count++;void Wrong(){ } void menu() //主菜单。{ printf(“n”);printf(“t**********************************************************printf(”t* printf(“t* printf(”t* < 职工信息管理系统_单链表实现 > printf(“t* printf(”t* [1] 录入职工信息 [2] 删除职工信息 printf(“t* [3] 查询职工信息 [4] 修改职工信息 printf(”t* [5] 插入职工记录 [6] 统计职工信息 printf(“t* [7] 排序 [8] 保存职工信息 printf(”t* [9] 显示所有职工记录 [0] 退出系统 printf(“n***提示***:输入错误!n”);*********n“);*n”);*n“);*n”);*n“);*n”);*n“);*n”);*n“);*n”); printf(“t* printf(”t* printf(“t* 版权所有人:printf(”t* 电子132班 printf(“t* printf(”t***********************************************************n“);*n”);彭林 *n“);*n”);1319200063 *n“);*********n”);} //void menu菜单结束。 void Del(LinkList L)//删除职工信息。{ int select; //删除方式选择记录变量。ListNode *p,*r;char find[20];if(!L->next) //当list无后继结点时,提示和结束Del()函数。{ } printf(“n按工号删除,请按‘1’n按姓名删除,请按‘2’n”);printf(“n=====>功能选择:”);scanf(“%d”,&select);if(select==1){ printf(“请输入要删除的职工工号:”);scanf(“%s”,find);getchar();p=Locatenum(L,find);if(p){ r=L;printf(“n***提示***:没有记录可以删除!n”);return; } while(r->next!=p)r=r->next;//从第一个结点找起,直到发现r->next=p, 是待删除结点,跳出循环。 r->next=p->next;free(p);printf(“n***提示***:该职工信息已成功删除!n”);saveflag=1;else Nofind();}//if(select==1).else if(select==2){ printf(“请输入要删除的职工姓名:”);scanf(“%s”,find);getchar();p=Locatename(L,find);if(p){ } else Nofind();r=L;while(r->next!=p)r=r->next;r->next=p->next;free(p);printf(“n***提示***:该职工信息已成功删除!n”);saveflag=1;}//if(select==2).else Wrong(); //显示输入错误的话 }//void Del()删除函数结束。 void Search(LinkList L) //查询职工信息。{ int select; int salary;int sign=0;char find[20];ListNode *p; //实现查询操作的临时结构体指针变量。if(!L->next){ } printf(“n按工号查找,请按‘1’n按工资查找,请按‘2’n按姓名查找,printf(”n=====>功能选择:“);scanf(”%d“,&select);printf(”n“);if(select==1) //工号。{ } else if(select==2) //工资。{ printf(”请输入要查找的工资:“);scanf(”%d“,&salary);p=Locatesalary(L,salary);printf(”请输入要查找的工号:“);scanf(”%s“,find);getchar();p=Locatenum(L,find);if(p){ } else Nofind();printf(”tttt 查找结果n“);printline(); //打印横线。printsubject(); //打印各分类标题。 printLinkList(p); //打印p结点各个数据成员的值。printline(); //打印横线。printf(”n***提示***:没有职工信息资料可以查询!n“);printf(”返回主菜单,请重新选择功能!n“);return;请按‘3’n”); } if(p){ } while(p){ { } } if(sign==0)Nofind();printf(“tttt查找结果n”);printline();printsubject();printLinkList(p);printline();sign++;p=Locatesalary(p,salary);if(p)printf(“tttt查找结果n”);printline();printsubject();printLinkList(p);printline();sign++;else if(select==3) //姓名。{ printf(“请输入要查找的姓名:”);scanf(“%s”,find);getchar();p=Locatename(L,find);if(p){ printf(“tttt查找结果n”);printline();printsubject();printLinkList(p); } } printline();else Nofind();else Wrong();}//void Search()查询函数结束。 void Save(LinkList L) //信息保存到文件中。{ FILE *fp;ListNode *p;int count=0;int flag=1;fp=fopen(“Employeeinfo.txt”,“wb”);if(fp==NULL){ } p=L->next;while(p){ if(fwrite(p,sizeof(ListNode),1,fp)==1) //将第一个记录结点值写入文 { p=p->next; //依次写入下一个结点的 count++; //文件的记录数+1。printf(“n***提示***:打开文件时发生错误!n”);return;件。 值。 } else { flag=0; printf(“写入文件过程发生错误!n”); break; } }//while(p).if(count>0){ } else { } fclose(fp);system(“cls”);//清屏。 printf(“文件保存失败!‘0’条记录被保存。n”);printf(“n***提示***:文件保存成功。(有%d条记录已经保存。)n”,count);saveflag=0; }//void Save()函数结束。 void Sort(LinkList L) //排序功能函数。{ ListNode *p,*m,*n;int i,j,count=0;p=L->next;if(!p){ } system(“cls”); //清屏。printf(“按工资从低到高排序:n”);printf(“***以下为排序前的所有职工记录***n”);Allemployeeinfo(L);while(p){ } for(i=0;i //不包含头结点的职工信息结点的总个数。p=p->next;system(“cls”); //清屏。printf(“无任何职工信息!n”);printf(“返回主菜单!n”);return; } { } printf(“***以下为排序后的所有职工记录***n”);Allemployeeinfo(L);saveflag=1;printf(“排序成功!n”);n=L;p=L->next;m=p->next;while(m){ } if(p->data.salary>m->data.salary){ } else { } n=p;p=m;m=m->next;n->next=p->next;p->next=m->next;m->next=p;n=m;m=p->next;void Statistics(LinkList L)//统计职工中的最高工资和最低工资。{ ListNode *Max,*Min;int i;ListNode *t=L->next;if(!t){ system(“cls”); //清屏。printf(“没有储存任何职工记录!n”); } } printf(“返回主菜单,请先录入职工信息!n”);return;system(“cls”);Max=Min=t;t=t->next;while(t){ } printf(“最高工资为:%dn”,Max->data.salary);printf(“最低工资为:%dn”,Min->data.salary);printf(“若要查看最低,最高工资的相关职工信息,n”);printf(“请按‘1’,然后按照提示进行相关操作,n”);printf(“否则,请按‘1’除外的任何数字键以退出统计功能,返回主菜单。n”);printf(“n=====>功能选择:”);scanf(“%d”,&i);if(i==1)Search(L); //显示符合要求的职工信息。return;else if(Max->data.salary //Max指针指向最高工资的职工结点。Min=t; //Min指针指向最低工资的职工结点。if(Min->data.salary>t->data.salary)t=t->next;void Insert(LinkList L) //插入新的职工信息。{ printf(“本功能可以通过姓名和工号查找到符合要求的n”);//功能介绍。printf(“相关职工信息,然后将您希望添加进去的新的n”);printf(“职工信息插入到该职工信息记录的后面。n”);ListNode *p,*s;char find[20]; //存放工号和姓名的变量。int i;printf(“通过姓名查找,请按‘1’。n”);printf(“通过工号查找,请按‘2’。n”); printf(“返回主菜单,请按‘3’。n”);printf(“n=====>功能选择:”);scanf(“%d”,&i);printf(“n”);if(i==3){ } else if(i==1){ printf(“请输入已在存储记录中的职工姓名:”);scanf(“%s”,find);getchar();p=Locatename(L,find);//定位。if(!p){ } s=(LinkList)malloc(sizeof(ListNode));if(!s){ } printf(“请输入新职工工号:”);gets(s->data.num);printf(“n”);printf(“请输入新职工姓名:”);scanf(“%s”,s->data.name);getchar();printf(“n”);printf(“请输入新职工的性别:(注:男性:male;女性:female)”);scanf(“%s”,s->data.sex);printf(“系统分配存储空间失败!n”);system(“cls”);return;printf(“您输入的该职工姓名不在信息记录中,请重新核审!n”);printf(“返回主菜单。n”);return;system(“cls”); //退出插入功能,返回主菜单。return; } getchar();printf(“n”);printf(“请输入新职工的年龄:”);scanf(“%d”,&s->data.age);printf(“n”);printf(“请输入新职工的学历:”);scanf(“%s”,s->data.education);getchar();printf(“n”);printf(“请输入新职工的工资:”);scanf(“%d”,&s->data.salary);printf(“n”);printf(“请输入新职工的电话号码:”);scanf(“%s”,s->data.phone);getchar();printf(“n”);printf(“请输入新职工的住址:”);scanf(“%s”,s->data.address);getchar();printf(“n”);s->next=p->next;p->next=s;printf(“姓名为:%s的新职工信息已成功插到姓名为:%s的职工信息记saveflag=1; //资料已改动的存储变量。录后面。n”,s->data.name,p->data.name);else if(i==2){ printf(“请输入已在存储记录中的职工工号:”);scanf(“%s”,find);getchar();p=Locatenum(L,find);//定位。if(!p){ printf(“您输入的该职工工号不在信息记录中,请重新核审!n”);printf(“返回主菜单。n”);return; } s=(LinkList)malloc(sizeof(ListNode));if(!s){ } printf(“请输入新职工工号:”);gets(s->data.num);printf(“n”);printf(“请输入新职工姓名:”);scanf(“%s”,s->data.name);getchar();printf(“n”);printf(“请输入新职工的性别:(注:男性:male;女性:female)”);scanf(“%s”,s->data.sex);getchar();printf(“n”);printf(“请输入新职工的年龄:”);scanf(“%d”,&s->data.age);printf(“n”);printf(“请输入新职工的学历:”);scanf(“%s”,s->data.education);getchar();printf(“n”);printf(“请输入新职工的工资:”);scanf(“%d”,&s->data.salary);printf(“n”);printf(“请输入新职工的电话号码:”);scanf(“%s”,s->data.phone);getchar();printf(“n”);printf(“请输入新职工的住址:”);scanf(“%s”,s->data.address);getchar();printf(“n”);printf(“系统分配存储空间失败!n”);system(“cls”);return; } } s->next=p->next;p->next=s;printf(“姓名为:%s的新职工信息已成功插到姓名为:%s的职工信息记saveflag=1;录后面。n”,s->data.name,p->data.name);else { } printf(“功能选择有误!返回主菜单。n”);return;void main(){ LinkList L;/*定义链表*/ // struct Node *list; FILE *fp;/* 文件指针 */ int choose;/*保存选择结果变量*/ char ch; /*保存(y,Y,n,N)*/ int count=0;/*保存文件中的记录条数(或结点个数)*/ struct Node *p,*r; /*定义记录指针变量*/ printf(“tttt职工信息管理系统nttttn”); L=(struct Node*)malloc(sizeof(struct Node)); if(!L) { printf(“n系统分配存储空间失败!n”);/*如没有申请到,打印提示信 return; /*返回菜单*/ 息*/ } L->next=NULL; r=L; fp=fopen(“Employeeinfo.txt”,“rb”); if(fp==NULL) { printf(“n***提示***:存储职工信息的文件还不存在,是否创建? scanf(”%c“,&ch);(y/n)n”); */ if(ch=='y'||ch=='Y') { fp=fopen(“Employeeinfo.txt”,“ab+”); printf(“文件创建成功!n”); } else { printf(“文件没有创建,无法写入职工信息!nn”); printf(“<-----退 出 职 工 信 息 管 理 系 统----->n”); exit(0); } } // if(fp==NULL) printf(“n=====>提示:文件已经打开,正在导入记录......n”); while(!feof(fp))//没有到文件尾时,循环 { fclose(fp);/* 关闭文件 */ printf(“n=====>提示:记录导入完毕,共导入%d条记录。n”,count); while(1) p=(struct Node*)malloc(sizeof(struct Node)); if(!p) { if(fread(p,sizeof(struct Node),1,fp))/* 读文件的已有内容放入结点中 { p->next=NULL; r->next=p; r=p;/* 将该结点挂入链表中, r指向最后的节点 */ count++; printf(“ memory malloc failure!n”); /*没有申请成功*/ exit(0); /*退出*/ } } } //while(!feof(fp)) { menu(); printf(“tt====>请选择:”); scanf(“%d”,&choose); if(choose==0) { if(saveflag==1) { getchar(); printf(“n=====>提示:资料已经改动,是否将改动保存到文件 scanf(”%c“,&ch); if(ch=='y'||ch=='Y') Save(L);中(y/n)?n”); } //if printf(“n***提示***:您已经退出系统,欢迎再次使用!~n”); break; }//if switch(choose){ case 1:Add(L); break;break;break;break;break;break;Sort(L);break;Save(L);case 2:Del(L);case 3:Search(L);case 4:Modify(L);case 5:Insert(L);case 6:Statistics(L);case 7: case 8: break;system(“cls”);Allemployeeinfo(L);break;case 9: default: } } } Wrong();break;第二篇:c语言 学生信息管理系统(线性表版)
第三篇:学生信息管理系统实训(C语言)
第四篇:C语言职工信息管理系统设计
第五篇:职工信息管理系统 单链表实现 C语言源程序(范文)