一、用C语言编写一个学生成绩管理系统。
概述
单纯只用多个数组管理学生成绩信息,不使用结构体,该程序最主要的难点是依据学号或总成绩对学生信息进行排序,借助了临时数组来标记排好序的下标。
运行结果如下:
输入数据:
根据总成绩排序:
根据学号删除学生信息:
贴上代码(有点多)
#include<stdio.h>
#include<stdlib.h>//exit函数头文件
#include<string.h>//字符串相关操作头文件
#define MAX_STUDENT 30//最大学生数
//函数声明,本程序共10个子函数,每个函数对应一个操作
void student_scanf(int n);
void student_printf(int n);
int student_find_name(int n);
int student_find_num(int n);
void student_sort_num(int n);
void student_sort_sum(int n);
int student_alter_num(int n);
int student_alter_name(int n);
int student_delete_num(int n);
int student_delete_name(int n);
//全局数组变量,用于存储学生信息
char names[MAX_STUDENT][50];
int math[MAX_STUDENT];
int english[MAX_STUDENT];
int computer[MAX_STUDENT];
int sum[MAX_STUDENT];
int num[MAX_STUDENT];
//以下变量用于学生信息数组排序,作为临时数组
int temp_num[MAX_STUDENT];
char temp_names[MAX_STUDENT][50];
int temp_math[MAX_STUDENT];
int temp_english[MAX_STUDENT];
int temp_computer[MAX_STUDENT];
int temp_sum[MAX_STUDENT];
//sort数组存储排好序的学号或姓名下标
int sort[MAX_STUDENT];
//循环全局变量
int i, j;
//main主函数
int main(void)
{
int choice,n;
while(1)
{
printf("*************************************\n");
printf("欢迎使用学生成绩管理系统\n");
printf("[1]输入所有学生信息\n");
printf("[2]输出所有学生成绩\n");
printf("[3]按学号查找某个学生信息\n");
printf("[4]按姓名查找某个学生信息\n");
printf("[5]按学号对学生排序\n");
printf("[6]按总成绩对学生排序\n");
printf("[7]按学号修改某个学生信息\n");
printf("[8]按姓名修改某个学生信息\n");
printf("[9]按学号删除某个学生信息\n");
printf("[10]按姓名删除某个学生信息\n");
printf("[0]退出程序\n");
printf("请输入您的选择(0- 9):");
scanf("%d",&choice);
printf("**************************************)\n");
switch(choice)
{
case 1://录入;
printf("请输入录入的学生信息数:");
scanf("%d",&n);
student_scanf(n);
break;
case 2://输出;
student_printf(n);
break;
case 3://根据学号查找
student_find_num(n);
break;
case 4://根据姓名查找
student_find_name(n);
break;
case 5://按学号排序
student_sort_num(n);
break;
case 6://按姓名排序
student_sort_sum(n);
break;
case 7://按学号修改
student_alter_num(n);
break;
case 8://按姓名修改
student_alter_name(n);
break;
case 9://按学号删除
student_delete_num(n);
n--;
break;
case 10://按姓名删除
student_delete_name(n);
n--;
break;
case 0://退出程序
printf("退出程序\n");
printf("程序结束,谢谢使用!\n");
exit(0);
default:
printf("您输入的菜单有误。请重新输入!\n");
}
}
return 0;
}
//1.输入信息
void student_scanf(int n)
{
for(i= 0; i<n;++i)
{
printf("\n请输入第%d个学生的信息:\n", i+ 1);
printf("\n学号:");
scanf("%d",&num[i]);
printf("\n姓名:");
scanf("%s", names[i]);
printf("\n数学成绩:");
scanf("%d",&math[i]);
printf("\n英语成绩:");
scanf("%d",&english[i]);
printf("\n计算机成绩:");
scanf("%d",&computer[i]);
//计算总成绩
sum[i]= math[i]+ english[i]+ computer[i];
}
}
//2.打印信息
void student_printf(int n)
{
printf("\n学号\t姓名\t数学成绩\t英语成绩\t计算机成绩\t总成绩\n");
printf("----------------------------------------------------------\n");
for(i= 0; i<n;++i)
{
printf("%d\t%s\t%d\t\t%d\t\t%d\t\t%d\n", num[i], names[i], math[i], english[i], computer[i], sum[i]);
}
printf("-------------------------------------------------------\n");
}
//3.按学号查找
int student_find_num(int n)
{
int nums;
int result;
printf("请输入待查找的学生学号:");
scanf("%d",&nums);
result=-1;
for(i= 0; i<n;++i)
{
if(nums== num[i])
{
result= i;
break;
}
}
//最后判断q值
if(result==-1)
{
printf("没有该学生信息!\n");
return 0;
}
else
{
//先打印表头
printf("\n学号\t\t姓名\t\t数学成绩\t英语成绩\t计算机成绩\t总成绩\n");
//再打印数据
printf("%d\t\t%s\t\t%d\t\t%d\t\t%d\t%d\n", num[result], names[result], math[result], english[result], computer[result], sum[result]);
printf("打印出查找结果!\n");
}
return 1;
}
//4.用姓名查找成绩
int student_find_name(int n)
{
char name[200];
int result;
printf("请输入待查找的学生姓名:");
scanf("%s", name);
result=-1;
for(i= 0; i<n;++i)
{
if(strcmp(name, names[i])== 0)
{
result= i;
break;
}
}
if(result==-1)
{//未找到结果
printf("没有该学生信息!\n");
return 0;
}
else//找到结果
{
printf("\n学号\t姓名\t数学成绩\t英语成绩\t计算机成绩\t总成绩\n");
printf("%d\t%s\t%d\t\t%d\t\t%d\t\t%d\n", num[result], names[result], math[result], english[result], computer[result], sum[result]);
printf("已完成查找!\n");
}
return 1;
}
//5.按学号排序
void student_sort_num(int n)
{
int min,max;
for(i=0; i<n;++i)//**临时数组
{
temp_num[i]= num[i];
}
max= 0;//查找学号最大值,将其下标存至sort数组的最后一个值中
for(j=1; j<n; j++)
{
if(temp_num[max]<temp_num[j])
max= j;
}
sort[n-1]= max;//sort数组的最后一个数
for(i=0; i<n-1;++i)
{
min= i;//查找学号最小值
for(j=0; j<n;++j)
{
if(temp_num[min]>temp_num[j])
min= j;
}
//sort数组记录排序的学生信息的下标
sort[i]= min;
temp_num[min]= temp_num[max];//利用临时数组将查找过的学生信息的学号设为最大值,排除查找干扰
}
for(i=0; i<n;++i)//再**一次临时数组
{
temp_num[i]= num[i];
strcpy(temp_names[i],names[i]);
temp_math[i]= math[i];
temp_english[i]= english[i];
temp_computer[i]= computer[i];
temp_sum[i]= sum[i];
}
for(i=0; i<n; i++)//按照下标对原数组进行修改
{
num[i]= temp_num[sort[i]];
strcpy(names[i],temp_names[sort[i]]);
math[i]= temp_math[sort[i]];
english[i]= temp_english[sort[i]];
computer[i]= temp_computer[sort[i]];
sum[i]= temp_sum[sort[i]];
}
printf("排序完毕,请按菜单键2查看排序结果!\n");
return;
}
//6.按总成绩排序
void student_sort_sum(int n)
{
int min,max;
for(i=0; i<n;++i)//**临时数组
{
temp_sum[i]= sum[i];
}
max= 0;//查找总成绩最大值,将其下标存至sort数组的最后一个值中
for(j=1; j<n; j++)
{
if(temp_sum[max]<temp_sum[j])
max= j;
}
sort[n-1]= max;//sort数组的最后一个数
for(i=0; i<n-1;++i)
{
min= i;//查找总成绩最小值
for(j=0; j<n;++j)
{
if(temp_sum[min]>temp_sum[j])
min= j;
}
//sort数组记录排序的学生信息的下标
sort[i]= min;
temp_sum[min]= temp_sum[max];//利用临时数组将查找过的学生信息的总成绩设为最大值,排除查找干扰
}
for(i=0; i<n;++i)//再**一次临时数组
{
temp_num[i]= num[i];
strcpy(temp_names[i],names[i]);
temp_math[i]= math[i];
temp_english[i]= english[i];
temp_computer[i]= computer[i];
temp_sum[i]= sum[i];
}
for(i=0; i<n; i++)//按照下标对原数组进行修改
{
num[i]= temp_num[sort[i]];
strcpy(names[i],temp_names[sort[i]]);
math[i]= temp_math[sort[i]];
english[i]= temp_english[sort[i]];
computer[i]= temp_computer[sort[i]];
sum[i]= temp_sum[sort[i]];
}
printf("排序完毕,请按菜单键2查看排序结果!\n");
return;
}
//7.按学号修改学生信息
int student_alter_num(int n)
{
int nums;
int result;
printf("请输入待修改的学生学号:");
scanf("%d",&nums);
result=-1;
for(i= 0; i<n;++i)
{
if(nums== num[i])
{
result= i;
break;
}
}
//最后判断q值
if(result==-1)
{
printf("没有该学生信息!\n");
return 0;
}
else//修改信息值
{
printf("请重新输入该学生信息:\n");
printf("学号:\n");
scanf("%d",&num[result]);
printf("姓名:\n");
scanf("%s",names[result]);
printf("数学成绩:\n");
scanf("%d",&math[result]);
printf("英语成绩:\n");
scanf("%d",&english[result]);
printf("计算机成绩:\n");
scanf("%d",&computer[result]);
sum[result]= math[result]+ english[result]+ computer[result];
}
return 1;
}
//8.按姓名修改学生信息
int student_alter_name(int n)
{
char name[50];
int result;
printf("请输入待修改的学生姓名:");
scanf("%s",name);
result=-1;
for(i= 0; i<n;++i)
{
if(strcmp(name,names[i])==0)
{
result= i;
break;
}
}
//最后判断q值
if(result==-1)
{
printf("没有该学生信息!\n");
return 0;
}
else//修改信息值
{
printf("请重新输入该学生信息:\n");
printf("学号:\n");
scanf("%d",&num[result]);
printf("姓名:\n");
scanf("%s",names[result]);
printf("数学成绩:\n");
scanf("%d",&math[result]);
printf("英语成绩:\n");
scanf("%d",&english[result]);
printf("计算机成绩:\n");
scanf("%d",&computer[result]);
sum[result]= math[result]+ english[result]+ computer[result];
}
return 1;
}
//9.按学号删除学生信息
int student_delete_num(int n)
{
int nums;
int result;
printf("请输入待删除的学生学号:");
scanf("%d",&nums);
result=-1;
for(i= 0; i<n;++i)
{
if(nums== num[i])
{
result= i;
break;
}
}
//最后判断q值
if(result==-1)
{
printf("没有该学生信息!\n");
return 0;
}
else//删除当前学生信息即为将数组从result的位置依次前挪一个位置
{
for(i=result; i<n-1;++i)//最后在main函数中,要将n的值减1
{
num[i]= num[i+1];
strcpy(names[i],names[i+1]);
math[i]= math[i+1];
english[i]= english[i+1];
computer[i]= computer[i+1];
sum[i]= sum[i+1];
}
}
return 1;
}
//10.按姓名删除学生信息
int student_delete_name(int n)
{
char name[50];
int result;
printf("请输入待删除的学生姓名:");
scanf("%s",name);
result=-1;
for(i= 0; i<n;++i)
{
if(strcmp(name,names[i])==0)
{
result= i;
break;
}
}
//最后判断q值
if(result==-1)
{
printf("没有该学生信息!\n");
return 0;
}
else//删除当前学生信息即为将数组从result的位置依次前挪一个位置
{
for(i=result; i<n-1;++i)//最后在main函数中,要将n的值减1
{
num[i]= num[i+1];
strcpy(names[i],names[i+1]);
math[i]= math[i+1];
english[i]= english[i+1];
computer[i]= computer[i+1];
sum[i]= sum[i+1];
}
}
return 1;
}
二、用C语言设计一个学生成绩管理系统
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#defineMAX1000
/*定义学生成绩信息结构*/
struct stu
{
char id[8];
char name[8];
扩展资料:
short:修饰int,短整型数据,可省略被修饰的int。(K&R时期引入)
long:修饰int,长整型数据,可省略被修饰的int。(K&R时期引入)
long long:修饰int,超长整型数据,可省略被修饰的int。(C99标准新增)
signed:修饰整型数据,有符号数据类型。(C89标准新增)
unsigned:修饰整型数据,无符号数据类型。(K&R时期引入)
restrict:用于限定和约束指针,并表明指针是访问一个数据对象的唯一且初始的方式。(C99标准新增)
复杂类型关键字
struct:结构体声明。(K&R时期引入)
union:联合体声明。(K&R时期引入)
enum:枚举声明。(C89标准新增)
typedef:声明类型别名。(K&R时期引入)
sizeof:得到特定类型或特定类型变量的大小。(K&R时期引入)
inline:内联函数用于取代宏定义,会在任何调用它的地方展开。(C99标准新增)
参考资料来源:百度百科-c语言
三、c语言大作业 学生成绩管理系统
给个参考你:
/*编制一个学生成绩管理系统,每个学生信息包括:学号、姓名、C语言、高数和英语成绩。具体功能:
(1)创建信息链表并以磁盘文件保存;
(2)读取磁盘文件并显示输出所有学生的成绩;
(3)按学号或姓名查询成绩;
(4)添加成绩记录;
(5)修改指定姓名或学号的学生的成绩并可存盘;
(6)显示输出60分以下、60~79、80~89、90分以上各分数段的学生信息。以C语言成绩为例*/
#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<string.h>
#define N 20
typedef struct
{
char name[10];
int num;
float c;
float math;
float english;
float aver;
}stu;
//菜单
void menu()/*便于操作员使用*/
{/*清屏*/
system("cls");
printf("学生平时成绩管理\n");
printf("=======================\n");
printf(" 1.成绩录入\n");
printf(" 2.计算\n");
printf(" 3.查询\n");
printf(" 4.修改\n");
printf(" 5.插入\n");
printf(" 6.显示\n");
printf(" 7.统计\n");
printf(" 8.删除\n");
printf(" 0.退出\n");
printf("=======================\n");
printf("请选择相应的功能:");
}
//成绩录入
void input()
{
FILE*fp;
stu xs;/*定义一个结构体变量来装从文件中读出来的数据*/
if((fp=fopen("student.dat","ab"))==NULL){printf("can't open file!\n");exit(0);}
printf("\n录入格式:姓名学号 C语言高数英语当输入姓名为ps结束录入\n");
while(1)/*中间加油break,可使循环中断*/
{
scanf("%s",xs.name);
if(strcmp(xs.name,"ps")==0) break;/*判断姓名是否为ps,用字符串判断*/
scanf("%d%f%f%f",&xs.num,&xs.c,&xs.math,&xs.english);
xs.aver=0;/*给平均分变量赋初值*/
fwrite(&xs,sizeof(stu),1,fp);//将成绩信息写入文件
}
fclose(fp);
}
//计算平均分
void sum()
{
int i=0,n;
stu xs[N];
FILE*fp;
if((fp=fopen("student.dat","rb+"))==NULL){printf("can't open file!\n");exit(0);}
while(!feof(fp))/*文件读入内存,读取指针未到文件尾时返回值为0,读到尾时返回值为1,加!取反后,结束即为0*/
{
fread(&xs[i],sizeof(stu),1,fp);/*读入结构体变量*/
if(feof(fp)) break;/*上面while循环那个会多读一次因为读到尾时那个0还没返回,这里判断如果以读到文件尾,则直接停止,避免重复输入*/
xs[i].aver=(xs[i].c+xs[i].math+xs[i].english)/3;
i++;
}
n=i;/*把i的末尾值给n,用于下面循环写入*/
i=0;
fclose(fp);
if((fp=fopen("student.dat","wb"))==NULL){printf("can't open file!\n");exit(0);}
while(i<n)
{
fwrite(&xs[i],sizeof(stu),1,fp);
i++;
}
fclose(fp);
}
void xingming()
{
FILE*fp;
stu xs;
char name[10];
printf("\n输入要查学生的姓名:");scanf("%s",name);
if((fp=fopen("student.dat","rb"))==NULL){printf("can't open file!\n");exit(0);}
while(!feof(fp))
{
fread(&xs,sizeof(stu),1,fp);
if(strcmp(xs.name,name)==0)/*按姓名查询时判断输入的姓名是否存在,会循环从数据中找取*/
{
printf("学生的信息如下:\n");
printf("\n%10s%6s%6s%6s%6s%6s\n","姓名","学号","C语言","高数","英语","平均成绩");
printf("%10s%6d%6.2f%6.2f%6.2f%6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
break;
}
}
if(feof(fp)) printf("查找失败!!!");/*学生不存在*/
fclose(fp);
}
void xuehao()
{
FILE*fp;
stu xs;
int num;
printf("\n输入要查学生的学号:");scanf("%d",&num);
if((fp=fopen("student.dat","rb"))==NULL){printf("can't open file!\n");exit(0);}
while(!feof(fp))
{
fread(&xs,sizeof(stu),1,fp);
if(xs.num==num)/*按学号查询时判断输入的学号是否存在,会循环从数据中找取*/
{
printf("学生的信息如下:\n");
printf("\n%10s%6s%6s%6s%6s%6s\n","姓名","学号","C语言","高数","英语","平均成绩");
printf("%10s%6d%6.2f%6.2f%6.2f%6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
break;
}
}
if(feof(fp)) printf("查找失败!!!");
fclose(fp);
}
//查询
void search()
{
char ch1;
system("cls");
printf("请输入按何种方式查询:\n");
printf("1-姓名,2-学号:");
ch1=getchar();/*用字符接收*/
switch(ch1)/*判断*/
{
case'1':xingming();break;
case'2':xuehao();break;
}
getch();/*让屏幕停留同时按任意键返回*/
}
//修改:输入学生的姓名,查找该学生,若找到则修改该生的成绩信息,并显示修改前后的结果;
void modi()
{
stu xs;
FILE*fp;
char name[10];
system("cls");
printf("\n输入要查学生的姓名:");scanf("%s",name);
if((fp=fopen("student.dat","rb+"))==NULL){printf("can't open file!\n");exit(0);}
while(!feof(fp))
{
fread(&xs,sizeof(stu),1,fp);
if(strcmp(xs.name,name)==0)/*判断输入要修改的姓名是否存在*/
{
printf("修改前学生的信息如下:\n");
printf("\n%10s%6s%6s%6s%6s%6s\n","姓名","学号","C语言","高数","英语","平均成绩");
printf("%10s%6d%6.2f%6.2f%6.2f%6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
printf("\n请输入该生的C语言成绩:");scanf("%f",&xs.c);
printf("\n高数成绩:");scanf("%f",&xs.math);
printf("\n英语成绩:");scanf("%f",&xs.english);
xs.aver=(xs.c+xs.math+xs.english)/3;
break;
}
}
if(!feof(fp))
{
printf("\n修改后的学生的信息如下:\n");
printf("\n%10s%6s%6s%6s%6s%6s\n","姓名","学号","C语言","高数","英语","平均成绩");
printf("%10s%6d%6.2f%6.2f%6.2f%6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
fseek(fp,sizeof(-stu),1);/*负号表示后退,1表示文件当前位置*/
fwrite(&xs,sizeof(stu),1,fp);/*再写入,同时把要修改的那个覆盖掉*/
}
else
printf("\n学生不存在,修改失败!!");
fclose(fp);
getch();
}
//插入:输入学生的平时的各项成绩,插入到指定位置;当指定的位置超出范围时,将其插入到全班的最后,并显示插入成功后的结果。
void insert()
{
int i=0,j,k,lenth;
FILE*fp;
stu s,xs[N];
system("cls");
printf("\n请输入插入的学生的姓名:");scanf("%s",&s.name);
printf("\n学生的学号:");scanf("%d",&s.num);
printf("\n学生的C成绩:");scanf("%f",&s.c);
printf("\n高数成绩:");scanf("%f",&s.math);
printf("\n英语成绩:");scanf("%f",&s.english);
s.aver=(s.c+s.math+s.english)/3;
printf("\n插入位置:");scanf("%d",&k);
// i=0;
if((fp=fopen("student.dat","rb"))==NULL){printf("can't open file!\n");exit(0);}
while(!feof(fp))
{
fread(&xs[i],sizeof(stu),1,fp);/*把数据读入到结构体数组中*/
if(feof(fp)) break;
i++;
}
fclose(fp);
lenth=i;
if(k<lenth&& k>=0)/*k的位置要位于数组范围之内*/
{//插入
for(j=lenth-1;j>=k;j--)
xs[j+1]=xs[j];/*一开始j是最大的,往后移一个这样移动避免数据被覆盖*/
/*循环是只循环这一句的*/
xs[k]=s;/*将输入的学生信息加入这个k位置*/
lenth++;/*长度+1*/
//写回
if((fp=fopen("student.dat","wb"))==NULL){printf("不能建立文件!!\n");exit(0);}
for(i=0;i<lenth;i++)
fwrite(&xs[i],sizeof(stu),1,fp);
}
else/*不再数组范围之内*/
{
if((fp=fopen("student.dat","ab"))==NULL){printf("不能建立文件!!\n");exit(0);}
fwrite(&s,sizeof(stu),1,fp);
}
fclose(fp);
}
//显示
void print()
{
FILE*fp;
stu s;
system("cls");
if((fp=fopen("student.dat","rb"))==NULL){printf("can't open file!\n");exit(0);}
printf("\n%10s%s%6s%6s%6s%6s\n","姓名","学号","C语言","高数","英语","平均成绩");
while(!feof(fp))
{
fread(&s,sizeof(stu),1,fp);//从文件中读取成绩信息
if(feof(fp)) break;//判断是否文件尾
printf("%10s%6d%6.2f%6.2f%6.2f%6.2f\n",s.name,s.num,s.c,s.math,s.english,s.aver);
}
fclose(fp);
getch();
}
//统计
void tongji()
{
int i=0,j=0,k=0,l=0,m=0,n,p,q,r,t,u;
FILE*fp;
stu s[N],*p1[N],*p2[N],*p3[N],*p4[N];/*用指针数组*/
system("cls");
if((fp=fopen("student.dat","rb"))==NULL){printf("cant't open file!\n");exit(0);}
while(!feof(fp))
{
fread(&s[i++],sizeof(stu),1,fp);/*读入数据*/
if(feof(fp)) break;
}
t=i;i=0;
for(u=0;u<t;u++)/*以下每个指针数组用于指向各分数段的学生信息*/
{
if(s[i].c<60){p1[j++]=&s[i++];continue;}/*每个学生信息只能位于一个分数段*/
if(s[i].c>=60&&s[i].c<80){p2[k++]=&s[i++];continue;}
if(s[i].c>=80&&s[i].c<90){p3[l++]=&s[i++];continue;}
if(s[i].c>=90){p4[m++]=&s[i++];continue;}
}
printf("不及格:姓名学号 C语言\n");
for(n=0;n<j-1;n++)
{
printf("%10s%6d%6.2f\n",p1[n]->name,p1[n]->num,p1[n]->c);
}
printf("60-79:姓名学号 C语言\n");
for(p=0;p<k;p++)
{
printf("%10s%6d%6.2f\n",p2[p]->name,p2[p]->num,p2[p]->c);
}
printf("80-89:姓名学号 C语言\n");
for(q=0;q<l;q++)
{
printf("%10s%6d%6.2f\n",p3[q]->name,p3[q]->num,p3[q]->c);
}
printf("90以上:姓名学号 C语言\n");
for(r=0;r<m;r++)
{
printf("%10s%6d%6.2f\n",p4[r]->name,p4[r]->num,p4[r]->c);
}
fclose(fp);
getch();
}
//删除:输入学生姓名,若该学生存在,则删除,并显示删除后余下的学生成绩信息
void dele()
{
stu xs[N];
FILE*fp;
char name[10];
int i=0,len,k=-1/*k<0是为后面if判断用的*/;
system("cls");
printf("\n输入要删除的学生姓名:");scanf("%s",name);
if((fp=fopen("student.dat","rb+"))==NULL){printf("can't open file!\n");exit(0);}
while(!feof(fp))
{
fread(&xs[i],sizeof(stu),1,fp);
if(feof(fp)) break;
if(strcmp(xs[i].name,name)==0) k=i;
i++;
}
fclose(fp);
//以下是删除后重新写文件
len=i;/*结构体数组上限*/
if(k>=0)/*k>0说明找到删除学生位置*/
{
if((fp=fopen("student.dat","wb+"))==NULL){printf("can't open file!\n");exit(0);}
for(i=0;i<len;i++)
{
if(i==k) continue;/*从这个位置开始写入*/
fwrite(&xs[i],sizeof(stu),1,fp);
}
fclose(fp);
}
else{printf("删除失败!!!\n");getch();}/*失败后重新返回菜单*/
print();
}
//菜单选择
void main()
{
char ch;
while(1)
{
menu();//显示菜单
ch=getch();//选择菜单
if(ch=='0') break;
switch(ch)//判断功能项
{
case'1':input();break;
case'2':sum();break;
case'3':search();break;
case'4':modi();break;
case'5':insert();break;
case'6':print();break;
case'7':tongji();break;
case'8':dele();break;
}
}
printf("\n欢迎使用!!!\n");
}
好了,关于一个C 的学生成绩管理系统作业和用C语言设计一个学生成绩管理系统的问题到这里结束啦,希望可以解决您的问题哈!