C语言学生管理系统主要是由链表实现的学生信息增,删,改,查等功能,我的管理系统由于为用到文件相关知识,感兴趣的同学们可以去学习添加文件保存等功能。
目录
我们首先需要用一个结构体来储存我们每一个学生的信息,以结构体为链表的数据域是不是要好理解一些呢(@@)
我们首先需要用一个结构体来储存我们每一个学生的信息,以结构体为链表的数据域是不是要好理解一些呢(@@)
typedef struct score{
int chinese;
int math;
int english;
}score;
typedef struct stu{
char name[20];
char num[20];
char sex[10];
int age;
int total;
score s;
}stu;//当然在这里我用了结构体的嵌套,其实没太大关系,大家可以稍作修改。
typedef struct linklist{
stu date;
struct linklist *next;
}linklist;
接下来就是各种功能的实现,这里我们就要用到函数。
1.菜单,即主页面(这里大家就可以随意发挥了)
void menu(){
system("cls");
printf("\t\t\t\t***************************************************\n");
printf("\t\t\t\t*\t\t学生管理系统 1.0 *\n");
printf("\t\t\t\t***************************************************\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*1.添加学生信息 2.查找学生信息 3.删除学生信息 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*4.修改学生信息 5.按成绩排序(total)6.显示所以信息 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*7.退出程序 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t***************************************************\n");
}
效果如下
2. 添加
void add(linklist *head){
printf("\t\t\t\t欢迎来到添加界面,请按要求完成操作|(@@)|\n");
linklist *q=(linklist*)malloc(sizeof(linklist));
q->next=NULL;
linklist *p;
p=head;
char nam[20];
printf("请输入姓名:");
scanf("%s",nam);
printf("\n请输入学号:");
char num[20];
scanf("%s",num);
while(p->next!=NULL){
if(strcmp(p->date.num,num)==0&&strcmp(p->date.name,nam)==0){
printf("该学生已存在\n");
break;
}
p=p->next;
}
if(p->next==NULL){
strcpy(q->date.num,num);
strcpy(q->date.name,nam);
printf("\n性别:");
scanf("%s",q->date.sex);
printf("\n请输入年龄:");
scanf("%d",&q->date.age);
printf("\n请输入语文成绩:");
scanf("%d",&q->date.s.chinese);
printf("\n请输入数学成绩:");
scanf("%d",&q->date.s.math);
printf("\n请输入英语成绩:");
scanf("%d",&q->date.s.english);
q->date.total=q->date.s.chinese+q->date.s.english+q->date.s.math;
p->next=q;
p=q;
}
}
3.查找
void seek( linklist *head) {
int k=0;
char name3[20];
printf("请输入学生姓名:\n");
scanf("%s",name3);
linklist *p;
p=(linklist*)malloc(sizeof(linklist));
p=head->next;
if(p==NULL){
printf("\t\t\t\t\t@还未录入信息!!!\n");
}
while(p!=NULL){
if(strcmp(name3,p->date.name)==0) {
k=k+1;
printf("\n姓名\t\t年龄\t\t性别\t\t学号\t\t语文\t\t数学\t\t英语\t\t总分\n");
printf("%s",p->date.name);
printf("\t\t%3d",p->date.age);
printf("\t\t");
printf("%s",p->date.sex);
printf("\t\t");
printf("%s",p->date.num);
printf("\t\t%3d",p->date.s.chinese);
printf("\t\t%3d",p->date.s.math);
printf("\t\t%3d",p->date.s.english);
printf("\t\t%3d",p->date.total);
// printf("\n%s\t\t%3d\t\t%s\t\t%s\t\t%3d\t\t%3d\t\t%3d",p->date.name,p->date.age,p->date.sex,p->date.num,p->date.s.chinese,p->date.s.math,p->date.s.english);
}
if(k==0) {
printf("查无此人");
}
p=p->next;
}
}
4.删除
void delet(linklist *head) {
linklist *p,*q;
p=(linklist*)malloc(sizeof(linklist));
q=(linklist*)malloc(sizeof(linklist));
p=head;
q=p->next;
char name3[20];
if(p==NULL) {
printf("此时无数据");
return;
}
else {
printf("请输入你想删除的学生的名字");
scanf("%s",name3);
while(q!=NULL) {
if(strcmp(q->date.name,name3)==0){
p->next=q->next;
free(q);
printf("\t\t\t\t******************************\n");
printf("\t\t\t\t******************************\n");
printf("\t\t\t\t*** @恭喜您!删除成功!!!***\n");
printf("\t\t\t\t******************************\n");
printf("\t\t\t\t******************************\n\n\n");
}
p=q;
q=q->next;
}
}
}
5.修改
void change(linklist *head){
printf("\t\t\t\t欢迎来到修改界面,请按要求完成操作|(@@)|\n");
char name4[20];
printf("请输入学生姓名:\n");
scanf("%s",name4);
int k=0;
linklist *p;
p=(linklist*)malloc(sizeof(linklist));
p=head->next;
while(p!=NULL){
if(strcmp(name4,p->date.name)==0) {
k=1;
printf("%s",p->date.num);
printf("\n姓名\t\t年龄\t\t性别\t\t学号\t\t语文\t\t数学\t\t英语\t\t总分\n");
printf("%s",p->date.name);
printf("\t\t%3d",p->date.age);
printf("\t\t");
printf("%s",p->date.sex);
printf("\t\t");
printf("%s",p->date.num);
printf("\t\t%3d",p->date.s.chinese);
printf("\t\t%3d",p->date.s.math);
printf("\t\t%3d",p->date.s.english);
p->date.total=p->date.s.chinese+p->date.s.english+p->date.s.math;
}
if(k==0) {
printf("查无此人");
}
p=p->next;
}
printf("\t\t\t\t************************************************\n");
printf("\t\t\t\t************************************************\n");
printf("\t\t\t\t*1.学号 \t2.性别 \t3.年龄 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*4.语文成绩\t5.数学成绩\t6.英语成绩 *\n");
printf("\t\t\t\t************************************************\n");
int sel4;
printf("\n请按要求输入要修改信息的编号:");
scanf(" %d",&sel4);
p=head->next;
while(p!=NULL){
if(strcmp(name4,p->date.name)==0){
switch(sel4){
case 1:
char s1[20];
printf("\n请输入修改后的学号:");
scanf("%s",s1);
strcpy(p->date.num,s1);
break;
case 2:
char s2[20];
printf("\n请输入修改后的性别:");
scanf("%s",s2);
strcpy(p->date.sex,s2);
break;
case 3:
int s3;
printf("\n请输入修改后的年龄:");
scanf("%d",&s3);
p->date.age=s3;
break;
case 4:
int s4;
printf("\n请输入修改后的语文成绩:");
scanf("%d",&s4);
p->date.s.chinese=s4;
break;
case 5:
int s5;
printf("\n请输入修改后的英语成绩:");
scanf("%d",&s5);
p->date.s.english=s5;
break;
case 6:
int s6;
printf("\n请输入修改后的数学成绩:");
scanf("%d",&s6);
p->date.s.math=s6;
break;
}
}
p=p->next;
}
}
6.排序
void sort(linklist *head) {
int b=1;
if(head->next==NULL) {
b=0;
}
if(b==0) {
printf("当前无数据/n");
}
if(b==1) {
linklist *p,*q;
p=(linklist*)malloc(sizeof(linklist));
q=(linklist*)malloc(sizeof(linklist));
/*char name1[20];
char sex1[6];
char num1[20];
int age1;
int chinese1;
int math1;
int english1;
int total1;*/
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n");
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n");
printf("@@@ 接下来请选择排序方式(|$@$|) @@@\n");
printf("@@@@@@@1.按年龄排序 @@@@@@\n");
printf("@@@@@@@2.按语文成绩排序 @@@@@@\n");
printf("@@@@@@@3.按英语成绩排序 @@@@@@\n");
printf("@@@@@@@4.按数学成绩排序 @@@@@@\n");
printf("@@@@@@@5.按总成绩排序 @@@@@@\n");
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n");
printf("你的选择是:");
int flag;
scanf("%d",&flag);
for(p=head; p!=NULL; p=p->next) {
for(q=p->next; q!=NULL; q=q->next) {
switch(flag){
case 1:
if(p->date.age < q->date.age) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 2:
if(p->date.s.chinese < q->date.s.chinese) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 3:
if(p->date.s.english < q->date.s.english) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 4:
if(p->date.s.math < q->date.s.math) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 5:
if(p->date.total< q->date.total) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
}
}
}
}
}
效果如下
7.显示
void print(linklist *head){
linklist *p;
p=(linklist*)malloc(sizeof(linklist));
p=head->next;
printf("\n姓名\t\t年龄\t\t性别\t\t学号\t\t语文\t\t数学\t\t英语\t\t总分\n");
while(p!=NULL){
printf("%s",p->date.name);
printf("\t\t%3d",p->date.age);
printf("\t\t");
printf("%s",p->date.sex);
printf("\t\t");
printf("%s",p->date.num);
printf("\t\t%3d",p->date.s.chinese);
printf("\t\t%3d",p->date.s.math);
printf("\t\t%3d",p->date.s.english);
printf("\t\t%3d\n",p->date.total);
p=p->next;
}
}
效果如下
8.退出
完整代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct score{
int chinese;
int math;
int english;
}score;
typedef struct stu{
char name[20];
char num[20];
char sex[10];
int age;
int total;
score s;
}stu;
typedef struct linklist{
stu date;
struct linklist *next;
}linklist;
struct linklist* head=NULL;
struct linklist* tail=NULL;
void menu(){
system("cls");
printf("\t\t\t\t***************************************************\n");
printf("\t\t\t\t*\t\t学生管理系统 1.0 *\n");
printf("\t\t\t\t***************************************************\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*1.添加学生信息 2.查找学生信息 3.删除学生信息 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*4.修改学生信息 5.排序(total) 6.显示所以信息 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*7.退出程序 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t***************************************************\n");
}
void add(linklist *head){
printf("\t\t\t\t欢迎来到删除界面,请按要求完成操作|(@@)|\n");
linklist *q=(linklist*)malloc(sizeof(linklist));
q->next=NULL;
linklist *p;
p=head;
char nam[20];
printf("请输入姓名:");
scanf("%s",nam);
printf("\n请输入学号:");
char num[20];
scanf("%s",num);
while(p->next!=NULL){
if(strcmp(p->date.num,num)==0&&strcmp(p->date.name,nam)==0){
printf("该学生已存在\n");
break;
}
p=p->next;
}
if(p->next==NULL){
strcpy(q->date.num,num);
strcpy(q->date.name,nam);
printf("\n性别:");
scanf("%s",q->date.sex);
printf("\n请输入年龄:");
scanf("%d",&q->date.age);
printf("\n请输入语文成绩:");
scanf("%d",&q->date.s.chinese);
printf("\n请输入数学成绩:");
scanf("%d",&q->date.s.math);
printf("\n请输入英语成绩:");
scanf("%d",&q->date.s.english);
q->date.total=q->date.s.chinese+q->date.s.english+q->date.s.math;
p->next=q;
p=q;
}
}
void delet(linklist *head) {
linklist *p,*q;
p=(linklist*)malloc(sizeof(linklist));
q=(linklist*)malloc(sizeof(linklist));
p=head;
q=p->next;
char name3[20];
if(p==NULL) {
printf("此时无数据");
return;
}
else {
printf("请输入你想删除的学生的名字");
scanf("%s",name3);
while(q!=NULL) {
if(strcmp(q->date.name,name3)==0){
p->next=q->next;
free(q);
printf("\t\t\t\t******************************\n");
printf("\t\t\t\t******************************\n");
printf("\t\t\t\t*** @恭喜您!删除成功!!!***\n");
printf("\t\t\t\t******************************\n");
printf("\t\t\t\t******************************\n\n\n");
}
p=q;
q=q->next;
}
}
}
void seek( linklist *head) {
int k=0;
char name3[20];
printf("请输入学生姓名:\n");
scanf("%s",name3);
linklist *p;
p=(linklist*)malloc(sizeof(linklist));
p=head->next;
if(p==NULL){
printf("\t\t\t\t\t@还未录入信息!!!\n");
}
while(p!=NULL){
if(strcmp(name3,p->date.name)==0) {
k=k+1;
printf("\n姓名\t\t年龄\t\t性别\t\t学号\t\t语文\t\t数学\t\t英语\t\t总分\n");
printf("%s",p->date.name);
printf("\t\t%3d",p->date.age);
printf("\t\t");
printf("%s",p->date.sex);
printf("\t\t");
printf("%s",p->date.num);
printf("\t\t%3d",p->date.s.chinese);
printf("\t\t%3d",p->date.s.math);
printf("\t\t%3d",p->date.s.english);
printf("\t\t%3d",p->date.total);
// printf("\n%s\t\t%3d\t\t%s\t\t%s\t\t%3d\t\t%3d\t\t%3d",p->date.name,p->date.age,p->date.sex,p->date.num,p->date.s.chinese,p->date.s.math,p->date.s.english);
}
p=p->next;
}
if(k==0){
printf("查无此人");
}
}
void change(linklist *head){
printf("\t\t\t\t欢迎来到修改界面,请按要求完成操作|(@@)|\n");
char name4[20];
printf("请输入学生姓名:\n");
scanf("%s",name4);
int k=0;
linklist *p;
p=(linklist*)malloc(sizeof(linklist));
p=head->next;
while(p!=NULL){
if(strcmp(name4,p->date.name)==0) {
k=1;
printf("%s",p->date.num);
printf("\n姓名\t\t年龄\t\t性别\t\t学号\t\t语文\t\t数学\t\t英语\t\t总分\n");
printf("%s",p->date.name);
printf("\t\t%3d",p->date.age);
printf("\t\t");
printf("%s",p->date.sex);
printf("\t\t");
printf("%s",p->date.num);
printf("\t\t%3d",p->date.s.chinese);
printf("\t\t%3d",p->date.s.math);
printf("\t\t%3d",p->date.s.english);
p->date.total=p->date.s.chinese+p->date.s.english+p->date.s.math;
printf("\t\t%3d\n",p->date.total);
}
p=p->next;
}
if(k==0){
printf("查无此人\n");
}
printf("\n\t\t\t\t************************************************\n");
printf("\t\t\t\t************************************************\n");
printf("\t\t\t\t*1.学号 \t2.性别 \t3.年龄 *\n");
printf("\t\t\t\t* *\n");
printf("\t\t\t\t*4.语文成绩\t5.英语成绩\t6.数学成绩 *\n");
printf("\t\t\t\t************************************************\n");
int sel4;
printf("\n请按要求输入要修改信息的编号:");
scanf("%d",&sel4);
p=head->next;
while(p!=NULL){
if(strcmp(name4,p->date.name)==0){
switch(sel4){
case 1:
char s1[20];
printf("\n请输入修改后的学号:");
scanf("%s",s1);
strcpy(p->date.num,s1);
break;
case 2:
char s2[20];
printf("\n请输入修改后的性别:");
scanf("%s",s2);
strcpy(p->date.sex,s2);
break;
case 3:
int s3;
printf("\n请输入修改后的年龄:");
scanf("%d",&s3);
p->date.age=s3;
break;
case 4:
int s4;
printf("\n请输入修改后的语文成绩:");
scanf("%d",&s4);
p->date.s.chinese=s4;
break;
case 5:
int s5;
printf("\n请输入修改后的英语成绩:");
scanf("%d",&s5);
p->date.s.english=s5;
break;
case 6:
int s6;
printf("\n请输入修改后的数学成绩:");
scanf("%d",&s6);
p->date.s.math=s6;
break;
}
}
p=p->next;
}
}
void print(linklist *head){
linklist *p;
p=(linklist*)malloc(sizeof(linklist));
p=head->next;
printf("\n姓名\t\t年龄\t\t性别\t\t学号\t\t语文\t\t数学\t\t英语\t\t总分\n");
while(p!=NULL){
printf("%s",p->date.name);
printf("\t\t%3d",p->date.age);
printf("\t\t");
printf("%s",p->date.sex);
printf("\t\t");
printf("%s",p->date.num);
printf("\t\t%3d",p->date.s.chinese);
printf("\t\t%3d",p->date.s.math);
printf("\t\t%3d",p->date.s.english);
printf("\t\t%3d\n",p->date.total);
p=p->next;
}
}
void sort(linklist *head) {
int b=1;
if(head->next==NULL) {
b=0;
}
if(b==0) {
printf("当前无数据/n");
}
if(b==1) {
linklist *p,*q;
p=(linklist*)malloc(sizeof(linklist));
q=(linklist*)malloc(sizeof(linklist));
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n");
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n");
printf("@@@ 接下来请选择排序方式(|$@$|) @@@\n");
printf("@@@@@@@1.按年龄排序 @@@@@@\n");
printf("@@@@@@@2.按语文成绩排序 @@@@@@\n");
printf("@@@@@@@3.按英语成绩排序 @@@@@@\n");
printf("@@@@@@@4.按数学成绩排序 @@@@@@\n");
printf("@@@@@@@5.按总成绩排序 @@@@@@\n");
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n");
printf("你的选择是:");
int flag;
scanf("%d",&flag);
for(p=head; p!=NULL; p=p->next) {
for(q=p->next; q!=NULL; q=q->next) {
switch(flag){
case 1:
if(p->date.age < q->date.age) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 2:
if(p->date.s.chinese < q->date.s.chinese) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 3:
if(p->date.s.english < q->date.s.english) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 4:
if(p->date.s.math < q->date.s.math) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
case 5:
if(p->date.total< q->date.total) {
linklist *x;
x=(linklist*)malloc(sizeof(linklist));
x->date=p->date;
p->date=q->date;
q->date=x->date;
free(x);
}
break;
}
}
}
}
}
/*void save(linklist *head)
{
system("cls");
fflush(stdin);
FILE *fp;
linklist *p;
fp=fopen("stu.db","wb");
for(p=head;p!=NULL;p=p->next)
{
fwrite(p,LEN,1,fp);
}
fclose(fp);
printf("♂♂♂♂保存完毕♂♂♂♂♂\n");
system("pause");
system("cls");
fflush(stdin);
}*/
int main()
{
int choose;
head=(linklist*)malloc(sizeof(linklist));
head->next=NULL;
while(1){
menu();
scanf("%d",&choose);
switch(choose){
case 1:
do{
system("cls");
add(head);
char sel[5];
printf("\t\t\t\t\t\t是否继续添加(yes or no): ");
scanf("%s",sel);
if(strcmp(sel,"yes")==0) continue;
else break;
}while(1);
break;
case 2:
do{
printf("\t\t\t\t欢迎来到查找界面,请按要求完成操作|(@@)|\n");
seek(head);
printf("\n\n\t\t\t\t\t\t是否继续查找(yes or no):");
char sel2[5];
scanf("%s",sel2);
if(strcmp(sel2,"yes")==0) continue;
else break;
}while(1);
break;
case 3:
do{
delet(head);
char sel3[5];
printf("\t\t\t\t是否继续删除(yes or no): ");
scanf("%s",sel3);
if(strcmp(sel3,"yes")==0) continue;
else break;
}while(1);
break;
case 4:
change(head);
break;
case 5:
printf("\t\t\t\t欢迎来到排序界面,请按要求完成操作|(@@)|\n");
printf("原顺序:\n");
print(head);
do{
int flag;
printf("如需进行下一步选择1,退出选择0:");
scanf("%d",&flag);
if(flag==1){
sort(head);
print(head);
continue;
}
if(flag==0) break;
}while(1);
break;
case 6:
system("cls");
printf("\t\t\t\t欢迎来输出到界面,请按要求完成操作|(@@)|\n\n\n");
print(head);
printf("退出请输入0:");
int sel6;
scanf("%d",&sel6);
if(sel6==0) break;
/* case 7:
remember(head);
break; */
default:
printf("\n感谢使用!\n");
printf("\n *\n");
printf(" * *** ****\n");
printf(" *** **** ****\n");
printf(" **** **** **** ****\n");
printf(" **** **** **** ****\n");
printf(" **** **** **** ****\n");
printf(" **** **** **** ****\n");
printf(" **** **** **** ****\n");
printf(" **** ******* ****\n");
printf(" *************\n");
printf(" *****\n");
system("pause");
return 0;
}
}
return 0;
}
这就是一个简单管理系统仅供大家参考,欢迎大家修改完善使用
版权声明:本文为weixin_63050915原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。