按照学号查找学生_C语言编写学生信息管理系统

本文介绍了使用C语言编写的学号查找功能的学生信息管理系统。系统包含菜单操作、增加、显示、查询、排序、删除、修改、保存和刷新学生信息等功能,其中查询功能支持按学号和姓名进行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

3fc87713ba36e36b8de722c0ff041994.png

f5a59dc19143dea0f485fecbe875ec2c.png

学生信息管理系统,包括学生基本的个人信息,比如学号、姓名、性别、年龄等信息,针对这些信息,利用自定义的各个功能成员函数来实现,具体的学生信息管理系统的所需要的功能需求如下:
1)系统以菜单方式工作,菜单是自定义的一个menu函数;
2) 增加学生信息并提供录入功能;
3)学生信息显示、浏览功能;
4)查询、排序功能,查询又分为:按学号查询、按姓名查询;
5)学生信息的删除功能;
6)学生信息的修改功能;
7)学生信息的保存功能;
8)学生信息的刷新功能,刷新依靠于按照学号的重新排序,在录入信息和增加信息后,对所有的信息进行刷新;9)帮助菜单功能,让不熟悉的人很快能够了解该程序的使用方法

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
//宏定义变量
#define N 1024
#define MAXSIZE 32
#define WIDESIZE 65
typedef struct Student
{
/*学生基本信息*/
int code;	//学号
char name[MAXSIZE];	//姓名,采用字符数组
int age;	//年龄
char sex[MAXSIZE];	//性别
/*学生成绩信息*/
int math;	//数学成绩
int chinese;	//语文成绩
int english;	//英语成绩
struct Student *next;	//指向下一个学生的指针
}Student;
/*
*创建学生链表
*/
Student * createList()
{
//申请一个Student【学生结构体】大小的控件
Student * studentList = (Student*)malloc(sizeof(Student));
return studentList;
}
/*
*创建学生节点
*/
Student * createNode()
{
Student * newStu = (Student*)malloc(sizeof(Student));
printf("学号:");
scanf("%d",&newStu->code);
printf("姓名:");
scanf("%s",newStu->name);
printf("年龄:");
scanf("%d",&newStu->age);
printf("性别:");
scanf("%s",newStu->sex);
printf("数学:");
scanf("%d",&newStu->math);
printf("语文:");
scanf("%d",&newStu->chinese);
printf("英语:");
scanf("%d",&newStu->english);
newStu->next=NULL;
return newStu;
}
//显示学生信息
void showMsg(Student *stu)
{
printf("%dt%st%dt%st%dt%dt%dtn",stu->code,stu->name,stu->age,stu->sex,
stu->math,stu->chinese,stu->english);
}
/*
*添加学生信息
*/
Student * insertStudent(Student * head)
{
int i,count;
printf("请输入录入的学生人数n");
scanf("%d",&count);
//获得学生链表的头节点
Student *tail= head;
//初始批量录入学生信息
if(head)
{
for(i = 0;i<count;i++)
{
printf("==============输入第%d个学生信息==============》n",i+1);
Student * newNode = createNode();
tail->next = newNode;//tail永远指向最后一位学生,即尾节点
tail = tail->next;
}
}else{
//批量添加学生信息
while(tail)
{
tail = tail->next;
}
for(i = 0;i<count;i++)
{
printf("==============输入第%d个学生信息==============》n",i+1);
Student * newNode = createNode();//创建存储学生信息的节点
tail->next = newNode;//添加学生
tail = tail->next;//尾节点后移
}
}
return head;//返回头节点
}
/*
*删除学生信息
*/
void deleteStudent(Student *studentList)
{
printf("请输入学号:");
int ditCode;
scanf("%d",&ditCode);
//获取链表头节点
Student *preStudent = studentList;
//获取链表第一个节点
Student *afterStudent = studentList->next;
if(afterStudent)//链表不是空
{
while(afterStudent)
{
if(afterStudent->code==ditCode)//学号相等,则说明已找到要删除的学生
{
preStudent->next=afterStudent->next;//进行删除操作
free(afterStudent);//释放节点控件
break;
}else
{//学生编号不相等,则继续向后移动,进行遍历
preStudent = afterStudent;
afterStudent = afterStudent->next;
}
}
}else
{
printf("没有这名学生的信息!");
}
}
/*
*根据学号修改学生信息
*/
//1.修改姓名
void changeName(Student *stu)
{
char newName[MAXSIZE];
printf("请输入新的名字:");
scanf("%s",newName);
strcpy(stu->name,newName);
showMsg(stu);
}
//2.修改年龄
void changeAge(Student *stu)
{
int newAge;
printf("请输入新的年龄:");
scanf("%d",&newAge);
stu->age=newAge;
showMsg(stu);
}
//3.修改数学成绩
void changeMathScore(Student *stu)
{
int newSocre;
printf("请输入新的数学成绩:");
scanf("%d",&newSocre);
stu->math=newSocre;
showMsg(stu);
}
//4.修改语文成绩
void changeChineseScore(Student *stu)
{
int newSocre;
printf("请输入新的语文成绩:");
scanf("%d",&newSocre);
stu->chinese=newSocre;
showMsg(stu);
}
//5.修改英语成绩
void changeEnglishScore(Student *stu)
{
int newSocre;
printf("请输入新的英语成绩:");
scanf("%d",&newSocre);
stu->chinese=newSocre;
showMsg(stu);
}
/*
*
*1、采用多分支选择结构,实现学生信息的修改
*2、编辑学生信息输入对应的编号,进行对应的修改,例:1,则进行姓名修改
*/
void editStudent(Student *studentList)
{
printf("请输入学号:");
int ditCode;
scanf("%d",&ditCode);
Student *ditStu = studentList->next;
if(ditStu!=NULL)
{
while(ditStu!=NULL)
{
if(ditStu->code==ditCode)
{
printf("请输入修改信息编号:n1.姓名n2.年龄n3.数学n4.语文n5.英语n");
int number;
scanf("%d",&number);
switch(number)
{
case 1: changeName(ditStu);
break;
case 2: changeAge(ditStu);
break;
case 3: changeMathScore(ditStu);
break;
case 4: changeChineseScore(ditStu);
break;
case 5: changeEnglishScore(ditStu);
break;
default:
printf("输入内容无效!");
}
}
ditStu = ditStu->next;
}
}else{
printf("抱歉,你还未录入学生信息,请先录入学生信息!n");
}
}
//根据学生编号查找学生信息
void findStudent(Student *studentList)
{
printf("请输入学号:");
int code;
scanf("%d",&code);
//指向第一个学生节点
Student *ditStu = studentList->next;
//如果学生链表不为空,则进行查询
if(ditStu!=NULL)
{
while(ditStu!=NULL)
{
if(ditStu->code!=code)	//学生学号不相等,则继续下一个比对查找
{
ditStu=ditStu->next;
}else{//找到后则进行学生信息的输出
showMsg(ditStu);
break;
}
}
}else{
printf("没有这名学生的信息!");
}
}
/*
*显示学生列表
*/
void showStudent(Student * studentList)
{
Student *temp = studentList->next;
printf("学号t姓名t年龄t性别t数学t语文t英语n");
//如果学生链表不为空,则进行输出
while(temp != NULL){
showMsg(temp);
temp=temp->next;
}
printf("n");
}
/*
*保存学生信息到文件中
*/
void saveStudent(Student *studentList)
{
//创建文件指针
FILE *fp = NULL;
//存放在D【C盘需要事先创建文件夹】盘根目录下,自动【有就不创建。否则创建文件】
创建studentMsg.txt
//fp = fopen("D:studentMsg.txt","a+");
fp = fopen("C:UsersSherryHanDesktop学习文件politicalstudentMsg.txt","a+");
//“a+”采用追加的形式保存到文件中
Student *stu = studentList->next;	//指针指向第一个学生
char title[N] = "学号t姓名t年龄t性别t数学t语文t英语n";
//将标题【学生属性列】写入文件中
fprintf(fp,"%s",title);
//遍历学生链表,并将学生信息写入文件,直到最后一个学生的下一个节点为空
while(stu!=NULL)
{
fprintf(fp,"%dt%st%dt%st%dt%dt%dn",stu->code,stu->name,stu->age,stu->sex
,stu->math,stu->chinese,stu->english);
stu=stu->next;
}
fclose(fp);
}
void showHelp()
{
printf("1、此系统可以对学生信息进行管理。n");
printf("2、输入对应功能项的编号即可进行不同功能的系统操作。n");
}
/*
*显示菜单
*/
void showMenu()
{
int i;
printf("------------------------");
printf("t欢迎使用学生管理系统t");
printf("------------------------n");
printf("t");
for(i=0;i<WIDESIZE;i++)
{
printf("*");
}
printf("n");
printf("t*t0.系统帮助及说明t**");
printf("t1.刷新学生信息tt*n");
printf("t*t2.查询学生信息tt");
printf("**t3.修改学生信息tt*n");
printf("t*t4.增加学生信息tt**");
printf("t5.按学号删除信息t*n");
printf("t*t6.显示所有学生信息t**");
printf("t7.保存当前信息tt*n");
printf("t*t8.退出学生管理系统t**");
for(i=0;i<4;i++)
{
printf("t");
}
printf("*n");
printf("t");
for(i=0;i<WIDESIZE;i++)
{
printf("*");
}
printf("n");
printf("------------------------");
printf("t2017级软件工程开发t");
printf("------------------------n");
printf("请按所需输入菜单编号:");
}
/*
*
*采用带头结点的链表来存储学生信息
*
*/
int main(int argc, char const *argv[])
{
int choice;
Student * studentList =  createList();
do
{
showMenu();
scanf("%d",&choice);
switch(choice)
{
case 0: showHelp();
break;
case 1: printf("刷新完成!n");
break;
case 2: findStudent(studentList);
break;
case 3: editStudent(studentList);
break;
case 4: insertStudent(studentList);
break;
case 5: deleteStudent(studentList);
break;
case 6: showStudent(studentList);
break;
case 7: saveStudent(studentList);
break;
default:
exit(1);
}
}while(1);
return 0;
}

fde7609d60f609d8c52cc5769ecc066e.png

a08f2b7231181784011fd76ecf0cf457.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值