C语言《学生信息管理系统》链表+文件操作

来源:互联网 发布:mac c库函数 编辑:程序博客网 时间:2024/06/15 15:39

今天带来的是一个链表版本的《学生信息管理系统》,功能包括:添加、显示、查询、删除、保存、读取,等功能模块,链表是C语言的进阶内容,希望大家好好学习,这里的代码可能会有一些瑕疵,希望大家提供意见或建议



主界面


显示功能:


查询功能:

这里只展示了学号查询,还有姓名查询也是可以使用的,不再赘述。



其他功能均可使用,大家可以在我的CSDN资源中下载源码,谢谢大家!

  #include<stdio.h>#include<stdlib.h>#include<string.h>#define Length sizeof(struct student)        //用来开辟空间int n=0;struct student {char name[20];           //名字char num[20];            //学号char Class[20];          //班级char mayor[20];          //专业int age;                 //年龄int score;               //成绩struct student *next;}*head,*p,*p1,*p2;       //head表示开头  p表示不同位置的数据void add()                    //添加{p1=(struct student *)malloc(Length);         //开辟存储空间if(n==0)                                     //判断链表开头head=p1;                                 //n=0代表输入的是第一个数据     //p2的结尾所指向的地址是p1else p2->next=p1;                            //n!=0 就它们连接起来system("cls");printf("请输入学生基本信息:\n姓名:");scanf("%s",&p1->name);printf("学号:");scanf("%s",&p1->num);printf("年龄:");scanf("%d",&p1->age);printf("班级:");scanf("%s",&p1->Class);printf("专业:");scanf("%s",&p1->mayor);printf("成绩:");scanf("%d",&p1->score);p2=p1;                                       //p2指向p1所在的地址p2->next=NULL;                              //链表结束标志n+=1;                                       //n判断是不是第一个数据system("pause");system("cls");}void print(){if(n!=0){p=head;                                   //p先指向开头system("cls");printf("姓名\t学号\t\t班级\t年龄\t专业\t\t成绩\n");do{printf("%-8s%-16s%-8s%-8d%-16s%-8d\n",p->name,p->num,p->Class,p->age,p->mayor,p->score);p=p->next;                            //p打印结束 把p指向next以判断下一个区域有没有内容}while(p!=NULL);//只要p指向的内存区域有数据 就打印内容}elseprintf("******您还没有添加数据哟!\n");system("pause");system("cls");}void find()           //查找{void find1();void find2();if(n!=0){int a;system("cls");printf("1.按姓名查找\n2.按学号查询\n");scanf("%d",&a);switch(a){case 1:find1();break;case 2:find2();break;}}else{printf("******您还没有添加数据哟!\n");system("pause");}}void Delete(){if(n!=0){struct student *f,*l;                              //定义新的指针 f使用来指向要删除的数据用来释放内存!char a[20];printf("请输入要删除的姓名:");scanf("%s",&a);p=head;if(strcmp(head->name,a)==0){f=head;head=head->next;free(f);}else{do{if(strcmp(p->name,a)==0){f=p;l->next=p->next;free(f);break;}l=p;                                          //不满足if表示这不是要删除的那一个节点,l暂时指向p  之后p再指向下一个节点,如果这个是要删除的节点那么l指向这个节点的next的地址p=p->next;}while(p!=NULL);}}elseprintf("******您还没有添加数据哟!\n");    printf("数据已经被删除\n");system("pause");                                    //等待命令system("cls");}void amend(){if(n!=0){int c;char a[20];printf("请输入要修改的姓名:");scanf("%s",&a);p=head;do{if(strcmp(a,p->name)==0){printf("\n被修改人信息如下:\n姓名\t学号\t\t班级\t年龄\t专业\t\t成绩\n");printf("%-8s%-16s%-8s%-8d%-16s%-8d\n",p->name,p->num,p->Class,p->age,p->mayor,p->score);break;}p=p->next;                            ////指针指向下一个节点}while(p!=NULL);printf("\n\n1.修改姓名\n2.修改学号\n3.修改班级\n4.修改年龄\n5.修改专业\n6.修改成绩\n7.退出修改\n\n");scanf("%d",&c);switch(c){case 1:printf("姓名修改为:");scanf("%s",&p->name);break;case 2:printf("学号修改为:");scanf("%s",&p->num);break;case 3:printf("班级修改为:");scanf("%s",&p->Class);break;case 4:printf("年龄修改为:");scanf("%d",&p->age);break;case 5:printf("专业修改为:");scanf("%s",&p->mayor);break;case 6:printf("成绩修改为:");scanf("%d",&p->score);break;case 7:break;}printf("\n\n操作成功!\n\n");}elseprintf("******您还没有添加数据哟!\n");system("pause");system("cls");}void save(){    FILE *fp;      struct student *p;      if((fp=fopen("C:\\数据内容\\data.txt","wb"))==NULL)printf("Can not open the file!");      p=head;      while(p!=NULL){  if(fwrite(p,Length,1,fp)!=1){printf("写入数据出错\n");  fclose(fp);break;        }          p=p->next;      }      fclose(fp);  printf("存储完成\n");system("pause");system("cls");}void read(){FILE *fp;if((fp=fopen("C:\\数据内容\\data.txt","rb+"))==NULL){printf("Can not open file!");exit(0);}    do{ p1=malloc(Length);if(n==0)                                     //判断链表开头head=p1;                                 //n=0代表输入的是第一个数据     //p2的结尾所指向的地址是p1elsep2->next=p1;; fread(p1,Length,1,fp);p2=p1;n+=1;    }while(p2->next!=NULL);    fclose(fp);printf("读取完成!\n\n");system("pause");system("cls");}void main()                                  //主函数{int a=1;while(a!=0){system("cls");printf("〓〓〓〓〓〓〓〓〓〓  ☆   学 生 成 绩 管 理 系  统     ☆  〓〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          1.增加学生信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          2.显示全部信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          3.查找学生信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          4.删除学生信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          5.修改学生信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          6.保存学生信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          7.读取学生信息        ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("〓〓〓〓〓〓〓〓〓★  ☆          0.  退出系统          ☆  ★〓〓〓〓〓〓〓〓〓\n");printf("请选择:");scanf("%d",&a);if(a>=0&&a<=9){switch(a){case 1:add();break;case 2:print();break;case 3:find();break;case 4:Delete();break;     case 5:     amend();break;case 6:save();break;case 7:read();break;}}else{printf(" 您输入的不符合要求,将返回主菜单!\n");system("pause");}}}void find1 (){char a[20];printf("请输入要查找的姓名:");scanf("%s",&a);p=head;do{if(strcmp(a,p->name)==0){printf("\n信息已被找到:\n姓名\t学号\t\t班级\t年龄\t专业\t\t成绩\n");printf("%-8s%-16s%-8s%-8d%-16s%-8d\n\n",p->name,p->num,p->Class,p->age,p->mayor,p->score);}p=p->next;                            ////指针指向下一个节点}while(p!=NULL);system("pause");system("cls");}void find2 (){char a[20];printf("请输入要查找的学号:");scanf("%s",&a);p=head;do{                                //指针指向开头if(strcmp(a,p->num)==0){printf("\n信息已被找到:\n姓名\t学号\t\t班级\t年龄\t专业\t\t成绩\n");printf("%-8s%-16s%-8s%-8d%-16s%-8d\n\n",p->name,p->num,p->Class,p->age,p->mayor,p->score);}p=p->next;                            //指针指向下一个节点}while(p!=NULL);system("pause");system("cls");}


1 0
原创粉丝点击