概述
本文实例为大家分享了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 %sn",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 %sn",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语言链表实现学生管理系统的全部内容,希望文章能够帮你解决C语言链表实现学生管理系统所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复