附源代码:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<conio.h>
#define HEAD1 p->data.clss,p->data.name,p->data.xh,p->data.cyy,p->data.yy,p->data.wl,p->data.zy,p->data.ty
#define TITLE1 "| 班级 | 姓名 | 学号 | C语言 | 计算机英语 | 网络基础 | 职业生涯 | 体育 |\n"
#define TITLE2 "|%10s|%7s|%10s|%7s|%12s|%10s|%10s|%6s|\n"
#define TITLE3 "-------------------------------------------------------------------------------------\n"
#define MAX 20
struct book{
char clss[MAX]; /*班级*/
char name[MAX]; /*姓名*/
char xh[MAX]; /*学号*/
int cyy[MAX]; /*C语言*/
int yy[MAX]; /*计算机英语*/
int wl[MAX]; /*网络基础*/
int zy[MAX]; /*职业生涯*/
int ty[MAX]; /*体育*/
};
typedef struct node
{
struct book data;
struct node *next;
}Node,*Link;
/*数据输出*/
void Output(Link head)
{
Node *p;
p=head->next;
if(p==NULL)
{
printf("\n文件为空\n");
getchar();
return ;
}
printf(TITLE3);
printf(TITLE1);
while(p!=NULL)
{
printf(TITLE3);
printf(TITLE2,HEAD1);
p=p->next;
}
printf(TITLE3);
printf("任意键返回...\n");
}
/*数据输入*/
void Input(Link head) /*链表头做参数传入*/
{
int flag=1; /*判断是否继续输入的变量*/
Node *p;
Node *ptr;
FILE *fp;
Output(head);
fp=fopen("H:\\实力派(勿删).doc","a");
if(fp==NULL)
{
printf("file open error!");
exit(0);
}
p=head;
ptr=p;
while(p->next!=NULL)
{
p=p->next; /*将指针移至于链表最末尾*/
ptr=p;
}
while(flag)
{
p=(Node*)malloc(sizeof(Node ));
printf("例如:17计算机高技班 谢某某 20150303 99 99 99 99 99\n");
printf("输入学生信息:班级,姓名,学号,C语言,计算机英语,网络基础,职业生涯,体育:\n");
scanf("%s %s %s %s %s %s %s %s",HEAD1);
printf("\n是否继续输入(1.YES,0.NO)");
scanf("%d",&flag);
fprintf(fp,"%s ",p->data.clss); /*写入文件*/
fprintf(fp,"%s ",p->data.name);
fprintf(fp,"%s ",p->data.xh);
fprintf(fp,"%s ",p->data.cyy);
fprintf(fp,"%s ",p->data.yy);
fprintf(fp,"%s ",p->data.wl);
fprintf(fp,"%s ",p->data.zy);
fprintf(fp,"%s ",p->data.ty);
ptr->next=p; /*将p写入链表*/
p->next=NULL;
ptr=ptr->next;
}
fclose(fp); /*关闭文件*/
printf("任意键返回...\n");
}
/*学生信息查询函数*/
void Search(Link head) /*链表头做参数传入*/
{
Node *p;
int choice;
int flag=0; /*判断是否存在想要查询的信息*/
char xh[20]; /*存储学号的 变量*/
char name[20]; /*存储姓名的 变量*/
p=head->next;
printf("1:按学号查询 2:按姓名查询\n");
printf("请选择(1 or 2):");
scanf("%d",&choice);
if(choice==1) /*以学号搜索*/
{
printf("请输入学号:");
scanf("%s",xh);
while(p!=NULL)
{
if(strcmp(xh,p->data.xh)==0) /*找到节点*/
{
printf(TITLE3);
printf(TITLE1);
printf(TITLE3);
printf(TITLE2,HEAD1); /*输出节点内容*/
printf(TITLE3);
flag=1;
}
p=p->next;
}
if(flag==0) /*没有学生信息*/
printf("\n没有该学号信息\n");
printf("任意键返回...\n");
}
else
if(choice==2) /*以姓名查询*/
{
printf("请输入姓名:");
scanf("%s",name);
while(p!=NULL)
{
if(strcmp(name,p->data.name)==0) /*找到节点*/
{
printf(TITLE3);
printf(TITLE1);
printf(TITLE3);
printf(TITLE2,HEAD1); /*输出节点内容*/
printf(TITLE3);
flag=1;
}
p=p->next;
}
if(flag==0) /*没有信息*/
printf("\n没有该姓名信息\n");
printf("任意键返回...\n");
}
else
printf("\n搞事情是吧!\n"); /*选择不为1或2,输出错误提示*/
}
/*数据信息更改*/
void Update(Link head) /*链表头做参数传入*/
{
Node *p,*ptr;
FILE *fp;
int n=1; /*判断是否继续更改*/
int flag=0; /*判断学号是否存在的参数*/
char xh[20]; /*储存修改的学号*/
fp=fopen("H:\\实力派(勿删).doc","w"); /*文件打开*/
if(fp==NULL)
{
printf("File open error!");
getchar();
exit(0);
}
while(n!=0)
{
p=head->next;
if(p==NULL)
{
printf("\n文件为空\n");
getchar();
return ;
}
printf("输入你想的学号:");
scanf("%s",&xh);
while(p!=NULL)
{
if(strcmp(xh,p->data.xh)==0) /*找到节点*/
{
printf(TITLE3);
printf(TITLE1);
printf(TITLE3);
printf(TITLE2,HEAD1); /*原有信息输出*/
printf(TITLE3);
printf("输入新的学生信息:班级,姓名,学号,C语言,计算机英语,网络基础,职业生涯,体育:\n"); /*更新内容*/
scanf("%s %s %s %s %s %s %s %s",HEAD1);
flag=1;
printf("是否继续更改(1.yes 0.no):");
scanf("%d",&n);
break;
}
p=p->next;
}
if(flag==0) /*没有信息,提示*/
{
printf("没有改学号信息\n");
printf("是否继续更改(1.yes 0.no):");
scanf("%d",&n);
}
}
ptr=head->next;
while(ptr!=NULL) /*重新将链表内容写入文件*/
{
fprintf(fp,"%s ",ptr->data.clss);
fprintf(fp,"%s ",ptr->data.name);
fprintf(fp,"%s ",ptr->data.xh);
fprintf(fp,"%s ",ptr->data.cyy);
fprintf(fp,"%s ",ptr->data.yy);
fprintf(fp,"%s ",ptr->data.wl);
fprintf(fp,"%s ",ptr->data.zy);
fprintf(fp,"%s ",ptr->data.ty);
ptr=ptr->next;
}
fclose(fp); /*关闭文件*/
}
/*数据删除*/
void Delete(Link head)
{
FILE *fp;
Node *p,*ptr;
char xh[20];
int flag=0;
fp=fopen("H:\\实力派(勿删).doc","w"); /*文件打开*/
if(fp==NULL)
{
printf("File open error!");
getchar();
exit(0);
}
ptr=head;
p=head->next;
printf("输入你想删除学生信息的学号:"); /*学号记录*/
scanf("%s",xh);
while(p!=NULL)
{
if(strcmp(xh,p->data.xh)==0) /*找到删除信息的节点*/
{
ptr->next=p->next; /*实现删除功能*/
p->next=NULL;
free(p); /*释放p的内存*/
flag=1; /*标志找到了此节点*/
break;
}
else
{
ptr=p;
p=p->next;
}
}
if(flag=0) /*没有此信息,输出提示信息*/
printf("\n没有你想删除的学生信息.\n");
ptr=head->next;
while(ptr!=NULL) /*链表内容重新写入文件*/
{
fprintf(fp,"%s ",ptr->data.clss);
fprintf(fp,"%s ",ptr->data.name);
fprintf(fp,"%s ",ptr->data.xh);
fprintf(fp,"%s ",ptr->data.cyy);
fprintf(fp,"%s ",ptr->data.yy);
fprintf(fp,"%s ",ptr->data.wl);
fprintf(fp,"%s ",ptr->data.zy);
fprintf(fp,"%s ",ptr->data.ty);
ptr=ptr->next;
}
}
/*选择错误提醒函数*/
void wrong()
{
printf("\n操作错误!!!\n");
}
void banben(Link head) /*版本信息*/
{
printf("\n");
printf("\n");
printf(" 本软件开发时间为2018年1月8日 \n");
printf(" Copyright 2018[17计算机高技班创建] \n");
printf(" 本软件所有的版权均属于飞哥认证 \n");
printf(" 最终版权归计算机高技班所有,如有侵犯将追究法律责任\n");
}
/*菜单函数*/
void menu()
{
printf(" ===========*|----------|*===========\n");
printf(" ============|实力派 2.0|============\n");
printf(" ============|欢迎**使用|============\n");
printf(" ===========*|----------|*===========\n");
printf(" ------------------------------------\n");
printf(" | 1.录入学生信息 |\n");
printf(" ------------------------------------\n");
printf(" | 2.查看学生信息 |\n");
printf(" ------------------------------------\n");
printf(" | 3.查询学生信息 |\n");
printf(" ------------------------------------\n");
printf(" | 4.修改学生信息 |\n");
printf(" ------------------------------------\n");
printf(" | 5.删除学生信息 |\n");
printf(" ------------------------------------\n");
printf(" | 6.版本信息 |\n");
printf(" ------------------------------------\n");
printf(" | 0.退出 |\n");
printf(" ------------------------------------\n");
}
/*main 函数*/
int main(void)
{
Link head;
int choice=1;
Node *p;
Node *tail;
FILE *fp;
fp=fopen("H:\\实力派(勿删).doc","a+");
if(fp==NULL) /*打开文件*/
{
printf("FILE open error!\n");
exit(0);
}
head=(Node*)malloc(sizeof(Node)); /*链表头建立*/
if(!head)
{
printf("\n allocate memory failure "); /*如没有申请到,打印提示信息*/
return 0; /*返回主界面*/
}
head->next=NULL;
tail=head;
while(fgetc(fp)!=EOF)
{
fseek(fp,-1,1);
p=(Node*)malloc(sizeof(Node));
if(!p)
{
printf("\n allocate memory failure!\n");
return 0;
}
fscanf(fp,"%s",p->data.clss);
fscanf(fp,"%s",p->data.name);
fscanf(fp,"%s",p->data.xh);
fscanf(fp,"%s",&p->data.cyy);
fscanf(fp,"%s",&p->data.yy);
fscanf(fp,"%s",&p->data.wl);
fscanf(fp,"%s",&p->data.zy);
fscanf(fp,"%s",&p->data.ty);
p->next=NULL;
tail->next=p;
tail=p;
}
fclose(fp); /*关闭文件*/
while(1)
{
menu();
printf(" 请输入你的操作序号(0--6):"); /*选择操作*/
scanf("%d",&choice);
if(choice==0) /*如果选择0,退出*/
{
printf(" 感谢你的使用,再见!\n");
printf(" 按任意键退出...\n");
getchar();
break;
}
switch(choice)
{
case 1:Input(head);break;
case 2:Output(head);getch();break;
case 3:Search(head);getch();break;
case 4:Update(head);getch();break;
case 5:Delete(head);getch();break;
case 6:banben(head);getch();break;
default:wrong();break;
}
}
getchar();
return 0;
}