温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C语言中怎么利用链表实现一个学生管理系统

发布时间:2021-08-09 16:52:48 来源:亿速云 阅读:185 作者:Leah 栏目:编程语言

这篇文章将为大家详细讲解有关C语言中怎么利用链表实现一个学生管理系统,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

具体内容如下

#include<stdio.h>#include<ctype.h>#include<fstream>#include<stdlib.h>#include<string.h>#include<iostream>using namespace std;typedef struct ndoe{ char id[10]; char name[10]; char sex[3]; char num[10];  struct node *next;}student;struct Student{ student data; struct Student *next;};/********创建学生信息**********/ Student * insert(Student * head){  Student * s,*r;  head=(Student *)malloc(sizeof(Student)); printf("请输入学生的个数:");  int n;  scanf("%d",&n);  r=head;  printf("按照“学号 姓名 性别(M or G) 手机号”的形式输入每个学生的信息\n");  for(int i=0;i<n;i++){  s=(Student *)malloc(sizeof(Student));  /*scanf("%s",s->data.id);  scanf("%s",s->data.name);  scanf("%s",s->data.sex);  scanf("%s",s->data.num);*/ scanf("%s%s%s%s",s->data.id,s->data.name,s->data.sex,s->data.num);  r->next=s;  r=s; } r->next=NULL; printf("录入成功\n");  return head;}/********增加学生************/void add(Student *head){ Student *s; s=head->next; while(s->next!=NULL) s=s->next; Student *ad=(Student *)malloc(sizeof(Student)); ad->next=NULL; s->next=ad; //printf("输入新学生的信息:\n"); scanf("%s%s%s%s",ad->data.id,ad->data.name,ad->data.sex,ad->data.num); printf("添加成功\n"); return ;}/*************修改学生信息********************/ void change(Student * head){ printf("输入1,按学号搜索学生,并修改改学生的信息\n"); printf("输入2,按姓名搜索学生,并修改改学生的信息\n"); Student * s; int n; scanf("%d",&n); switch(n){ case 1:{ printf("请输入学号:"); char number[10]; scanf("%s",number);  s=head->next; while(s!=NULL){ if(strcmp(s->data.id,number)==0){  printf("请输入要修改的信息:");  char phone[10];  scanf("%s",phone);  strcpy(s->data.num,phone);  printf("修改成功\n");  break; } s=s->next; }  break; } case 2:{ printf("请输入姓名:"); char nam[10]; scanf("%s",&nam);  s=head->next; while(s!=NULL){ if(strcmp(s->data.name,nam)==0){  printf("请输入要修改的信息:"); char phone[10];  scanf("%s",phone);  strcpy(s->data.num,phone);  printf("修改成功\n");  break; } s=s->next; }  break; } }  return ;}/**********删除学生信息******************/void del(Student * head){ printf("输入1,按学号搜索学生,并删除该学生的信息\n"); printf("输入2,按姓名搜索学生,并删除该学生的信息\n"); Student * s,*r; int n; scanf("%d",&n); switch(n){ case 1:{ printf("请输入学号:"); char number[10]; scanf("%s",number);  s=head->next;  r=head; while(s!=NULL){ if(strcmp(s->data.id,number)==0){  r->next=s->next;  free(s);  printf("删除成功\n");  break; } r=s; s=s->next; }  break; } case 2:{ printf("请输入姓名:"); char nam[10]; scanf("%s",&nam);  s=head->next;  r=head; while(s!=NULL){ if(strcmp(s->data.name,nam)==0){  r->next=s->next;  free(s);  printf("删除成功\n");  break; } r=s; s=s->next; }  break; } } return ;}/**********查询学生的信息**********************/void check(Student * head){ printf("输入1,按学号搜索学生,并展示该学生的信息\n"); printf("输入2,按姓名搜索学生,并展示该学生的信息\n"); Student * s,r; int n; scanf("%d",&n); switch(n){ case 1:{ printf("请输入学号:"); char number[10]; scanf("%s",number);  s=head->next; while(s!=NULL){ if(strcmp(s->data.id,number)==0){  printf("%s %s %s %s\n",s->data.id,s->data.name,s->data.sex,s->data.num);  break; } s=s->next; }  break; } case 2:{ printf("请输入姓名:"); char nam[10]; scanf("%s",&nam);  s=head->next; while(s!=NULL){ if(strcmp(s->data.name,nam)==0){  printf("%s %s %s %s\n",s->data.id,s->data.name,s->data.sex,s->data.num);  break; } s=s->next; }  break; } } if(s==NULL) printf("该学生不存在\n"); return ;} int main(){ Student *head=NULL; Student *a; printf("***欢迎进入学生管理系统***\n"); printf("***1:请录入学生信息***\n"); printf("***2:请修改学生信息***\n"); printf("***3:请删除学生信息***\n"); printf("***4:请查询学生信息***\n"); printf("***5:请添加新学生信息**\n"); printf("***6: 退出管理系统 ***\n"); printf("*************************\n"); printf("请输入命令:"); int n; while(scanf("%d",&n)&&n!=6){ switch(n){ case 1:{ printf("请录入学生信息:\n"); head=insert(a); break; } case 2:{ printf("请改学生信息:\n"); change(head); break; } case 3:{ cout<<"请删除学生信息:"<<endl; del(head); break; } case 4:{ cout<<"请查询学生信息:"<<endl; check(head);  break; } case 5:{ cout<<"请添加新学生信息:"<<endl; add(head); break; }  default : break; } printf("请继续输入命令:");  } Student *s,*r; s=head->next; while(s!=NULL){ r=s->next; free(s); s=r; } free(head); return 0;}

关于C语言中怎么利用链表实现一个学生管理系统就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI