这篇文章主要为大家详细介绍了C语言实现学籍管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了C语言实现学籍管理系统的具体代码,供大家参考,具体内容如下
设计一个学籍管理系统,基本功能包括:
1.输入学生基本信息
2.查询学生信息(1.按学号2.按姓名)
3.删除学生信息(1.按学号2.按姓名)
4.学生信息排序(1.按学号2.按姓名)
5.修改学生基本信息
6.输出学生信息
7.保存学生信息
0.退出程序
注:由于知识有限,该系统暂时规定只输入3个学生数据,今后会改良成可随机处理任意多个学生的数据
一、首页
void enter(struct student stu[],int n)
{
int select;
while(select!=0)
{
printf("\t\t\t ---------------------------\n");
printf("\n");
printf("\t\t\t 欢迎使用学籍管理系统\n");
printf("\n");
printf("\t\t\t ---------------------------\n");
printf("\t\t\t 1.输入学生基本信息\n");
printf("\t\t\t 2.查询学生信息(1.按学号2.按姓名)\n");
printf("\t\t\t 3.删除学生信息(1.按学号2.按姓名)\n");
printf("\t\t\t 4.学生信息排序(1.按学号2.按姓名)\n");
printf("\t\t\t 5.修改学生基本信息\n");
printf("\t\t\t 6.输出学生信息\n");
printf("\t\t\t 7.保存学生信息\n");
printf("\t\t\t 0.退出程序\n");
printf("\t\t\t 请输入您的选项");
scanf("%d",&select);
system("cls");
switch(select)
{
case 1:input(stu,n);break;
case 2:seek(stu,n);break;
case 3:delect(stu,n);break;
case 4:sort(stu,n);break;
case 5:revise(stu,n);break;
case 6:output(stu,n);break;
case 7:keep(stu,n);break;
case 0:printf("\t\t\t 您已退出学籍管理系统\n");break;
default:printf("输入有误\n");
system("pause");
system("cls");
}
}
}
二、输入
int count=0; //计数器记录学生个数
void input(struct student stu[],int n)
{
int i;
if(count!=0)
count=0;
printf("\t\t\t-------------------------------\n");
printf("\n");
printf("\t\t\t 欢迎进入学生信息录入系统\n");
printf("\n");
printf("\t\t\t-------------------------------\n");
printf("\t\t请输入学生基本信息(学号,姓名,年龄,性别(女w,男m))\n");
for(i=0;i<n;i++)
scanf("%d %s %d %c",&stu[i].number,stu[i].name,&stu[i].age,&stu[i].sex);
system("cls");
printf("\t\t\t 学生信息已录入\n");
system("pause");
system("cls");
}
三、查询
void seek(struct student stu[],int n)
{
int i,select2,num2;
char name2[10];
printf("\t\t\t-------------------------------\n");
printf("\n");
printf("\t\t\t 欢迎进入学生信息查询系统\n");
printf("\n");
printf("\t\t\t-------------------------------\n");
printf("\t\t请选择查询方式(1.按学号查询 2.按姓名查询)");
scanf("%d",&select2);
system("cls");
switch(select2)
{
case 1:
{
printf("\t\t\t\t 请输入学号");
scanf("%d",&num2);
system("cls");
for(i=0;i<n-count;i++)
if(stu[i].number==num2)break; //判断输入学号和结构数组的学号是否匹配,找到匹配项则退出循环
if(i<n-count) //数组下标小于学生数,则说明找到该学生,输出信息
{
printf("\t\t\t您要查询的学生信息为:\n");
printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
}
else //数组下标等于学生数,则没有找到该学生
printf("\t\t\t\t查无此人\n");
system("pause");
system("cls");
}break;
case 2:
{
printf("\t\t\t\t 请输入姓名");
scanf("%s",name2);
system("cls");
for(i=0;i<n-count;i++)
if(strcmp(stu[i].name,name2)==0)break;
if(i<n-count)
{
printf("\t\t\t您要查询的学生信息为:\n");
printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
}
else
printf("\t\t\t\t查无此人\n");
system("pause");
system("cls");
}break;
}
}
四、删除
void delect(struct student stu[],int n)
{
int i=n,j,select3,num3,choice3;
char name3[10];
printf("\t\t\t-------------------------------\n");
printf("\n");
printf("\t\t\t 欢迎进入学生信息删除系统\n");
printf("\n");
printf("\t\t\t-------------------------------\n");
printf("\t\t请选择删除方式(1.按学号删除 2.按姓名删除)");
scanf("%d",&select3);
system("cls");
switch(select3)
{
case 1:
{
printf("\t\t\t\t 请输入学号");
scanf("%d",&num3);
system("cls");
for(i=0;i<n-count;i++)
if(stu[i].number==num3)break;//首先找到要删除的学生
if(i<n-count)
{
printf("\t\t\t当前您要修改的学生信息为\n");
printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
printf("\t\t\t如果您不想再删除该生信息请按0,继续删除请按1\n");
scanf("%d",&choice3);
system("cls");
if(choice3==1)
{
for(j=i;j<n-count;j++)//从该学生往后每一项向前移动一项,覆盖前一个数据项
stu[j]=stu[j+1];
count++;
printf("\t\t\t\t该生信息已删除\n");
system("pause");
system("cls");
}
}
else
{
printf("\t\t\t\t查无此人\n");
system("pause");
system("cls");
}
}break;
case 2:
{
printf("\t\t\t\t 请输入姓名");
scanf("%s",&name3);
system("cls");
for(i=0;i<n-count;i++)
if(strcmp(stu[i].name,name3)==0)break;
if(i<n-count)
{
printf("\t\t\t当前您要修改的学生信息为\n");
printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
printf("\t\t\t如果您不想再删除该生信息请按0,继续删除请按1\n");
scanf("%d",&choice3);
system("cls");
if(choice3==1)
{
for(j=i;j<n-count;j++)
stu[j]=stu[j+1];
count++;
printf("\t\t\t\t该生信息已删除\n");
system("pause");
system("cls");
}
}
else
{
printf("\t\t\t\t查无此人\n");
system("pause");
system("cls");
}
}
}
}
五、排序
void sort(struct student stu[],int n)
{
int select4,i,j;
struct student t;
printf("\t\t\t-------------------------------\n");
printf("\n");
printf("\t\t\t 欢迎进入学生信息排序系统\n");
printf("\n");
printf("\t\t\t-------------------------------\n");
printf("\t\t请选择排序方式(1.按学号排序 2.按姓名排序)");
scanf("%d",&select4);
system("cls");
switch(select4)
{
case 1:{ //冒泡排序
for(j=1;j<n-count;j++)
{
for(i=0;i<n-count-j;i++)
{
if(stu[i].number>stu[i+1].number)
{
t=stu[i];
stu[i]=stu[i+1];
stu[i+1]=t;
}
}
}
}break;
case 2:{
for(j=1;j<n-count;j++)
{
for(i=0;i<n-count-j;i++)
{
if(strcmp(stu[i].name,stu[i+1].name)>0)
{
t=stu[i];
stu[i]=stu[i+1];
stu[i+1]=t;
}
}
}
}
}
printf("\t\t\t\t已按要求完成排序\n");
system("pause");
system("cls");
}
六、修改
void revise(struct student stu[],int n)
{
int num5,i=n,choice5;
printf("\t\t\t-------------------------------\n");
printf("\n");
printf("\t\t\t 欢迎进入学生信息修改系统\n");
printf("\n");
printf("\t\t\t-------------------------------\n");
printf("\t\t\t请输入您要修改的学生学号");
scanf("%d",&num5);
system("cls");
for(i=0;i<n-count;i++)
if(stu[i].number==num5)break;
if(i<n-count)
{
printf("\t\t\t当前您要修改的学生信息为\n");
printf("\t\t\t学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
printf("\t\t\t如果您不想再修改该生信息请按0,继续修改请按1\n");
scanf("%d",&choice5);
system("cls");
if(choice5==1)
{
printf("\t\t\t请输入修改的信息\n");
printf("\t\t\t学号\t姓名\t年龄\t性别\n");
printf("\t\t\t");
scanf("%d %s %d %c",&stu[i].number,stu[i].name,&stu[i].age,&stu[i].sex);//直接将新信息存储到原数据项中,覆盖原信息即可
system("cls");
printf("\t\t\t\t已完成信息修改\n");
system("pause");
system("cls");
}
}
else
{
printf("\t\t\t\t查无此人\n");
system("pause");
system("cls");
}
}
七、输出
void output(struct student stu[],int n)
{
int i;
printf("\t\t\t-------------------------------\n");
printf("\n");
printf("\t\t\t 欢迎进入学生信息输出系统\n");
printf("\n");
printf("\t\t\t-------------------------------\n");
for(i=0;i<n-count;i++)//循环输出所有学生信息
printf("\t\t\t 学号%d 姓名%s 年龄%d 性别%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);
system("pause");
system("cls");
}
八、保存
void keep(struct student stu[],int n)
{
FILE *fp; //文件指针fp
int i;
if((fp=fopen("d:\\xsxx.txt","wt+"))==NULL)//在D盘读写打开或建立一个名为“xxsx”的文本文件,允许读写
{
printf("\t\t\t\t文件不能打开!");
exit(0);
}
for(i=0;i<n-count;i++)
fprintf(fp,"%d\t%s\t%d\t%c\n",stu[i].number,stu[i].name,stu[i].age,stu[i].sex);//调用格式化写fprintf()函数,将数组中内容写入文件
fclose(fp);
printf("\t\t\t\t文件已保存\n");
system("pause");
system("cls");
}
九、主函数
int main(){
struct student stu[3];
enter(stu,3); //规定学生数为3人
return 0;
}
十、结构体定义
struct student{
int number;
char name[10];
int age;
char sex;
}; //定义结构体student
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程学习网。
沃梦达教程
本文标题为:C语言实现学籍管理系统
基础教程推荐
猜你喜欢
- 详解c# Emit技术 2023-03-25
- C++使用easyX库实现三星环绕效果流程详解 2023-06-26
- C利用语言实现数据结构之队列 2022-11-22
- 一文带你了解C++中的字符替换方法 2023-07-20
- C++详细实现完整图书管理功能 2023-04-04
- C++中的atoi 函数简介 2023-01-05
- C语言 structural body结构体详解用法 2022-12-06
- C语言基础全局变量与局部变量教程详解 2022-12-31
- 如何C++使用模板特化功能 2023-03-05
- C/C++编程中const的使用详解 2023-03-26