求指点一下,致命错误怎么弄,程序如下
#include <stdio.h>#include <stdlib.h>
#include <string.h>
#include <conio.h>
#include <time.h>
#define NAME 20
#define SORC 6
#define STUDENTMAX 1000 //学生最大人数
#define PASSWORD "123456" //系统登陆密码
/************************学生信息结构体**********************/
struct studentsorc //学生成绩结构
{
char name[NAME]; //学生姓名
int ID; //学生学号
float sorc[6]; //记录学生成绩
float aver; //平均分
float sum; //总分
};
struct allstudentinfo //学生全部结构
{
struct studentsorc student1;
};
FILE *sorcfile=NULL; //存学生成绩数据文件
char filename1[]="C:\\学生成绩.dat"; //记录学生成绩
/************************函数块声明****************************/
void password(); //密码验证
int showmeun(); //系统主菜单显示
int submeun(); //子菜单显示
void sorcmeun(struct allstudentinfo *); //成绩管理子菜单
void inputsorc(struct allstudentinfo *); //个人成绩录入
void mofsorc (struct allstudentinfo *); //修改成绩
void seasorc (struct allstudentinfo *); //查找个人成绩
void seaallsorc(struct allstudentinfo *); //浏览所有成绩
void delsorc (struct allstudentinfo *); //删除成绩
int sorcdatfile(struct allstudentinfo *); //成绩数据文件
void systemhelp(); //系统帮助信息
int main(void)
{
struct allstudentinfo studentmax[STUDENTMAX]; //最大学生人数
struct allstudentinfo *p_student; //指向结构指针
int in;
time_t start,end;
p_student=studentmax; //指向结构体
password(); //获取用户密码验证
do
{
system("cls");
in=showmeun(); //系统主菜单显示
switch(in)
{
case 1 : sorcmeun(p_student);break;
case 2 : systemhelp( );break;
case 3 : break;
default: printf("没有此选项,请按任意键返回重新选择!");
getch();
system("cls");
break;
}
}while(in!=3);
system("cls");
printf("\n\n\n\n\n\n\n\n\t\t\t");
printf("谢 谢 使 用 本 系 统 !");
start=time(NULL);
end=time(NULL);
while(end-start<1.5)
end=time(NULL);
return 0;
}
/************************密码验证*****************************/
void password()
{
char *pass=NULL; //初始化指针
int count;
time_t start,end; //时间函数
pass=(char *)malloc(255*sizeof(char)); //分配内存
while(1)
{
count=0;
printf("\n\n\n\n\n\t\t 中学生成绩管理系统\n");
printf("\n\t\t 用户名:小明 \n");
printf("\n\t\t 密 码:");
while((count>=0)&&(pass[count++]=getch())!=13) //密码输入
{
if(pass[0]=='\b')
{
count=0;
continue;
}
else if(pass[count-1]=='\b')
{
printf("%c%c%c",'\b','\0','\b');
count-=2;
}
else
putchar('*');
}
pass[--count]='\0';
if(!strcmp(pass,PASSWORD)) //开始验证
{
system("cls");
printf("\n\n\n\n\n\n\n\n\n\t\t\t");
printf(" 欢 迎 登 陆 中 学 生 成 绩 管 理 系 统 !");
start=time(NULL);
end=time(NULL);
while(end-start<1) //延时1秒执行以下程序
{
end=time(NULL);
}
system("cls");
free(pass); //释放储存密码的内存
return ;
}
free(pass); //释放密码错误的那块内存
pass=(char *)malloc(255*sizeof(char)); //重新分配储存密码内存
system("cls");
printf("\a\n\n\n\n\n\n\n\n\t\t\t\t密 码 错 误 !");
getch();
system("cls");
}
}
/***********************系统主菜单************************/
int showmeun()
{
int in;
char ch;
printf("\n\n\n\n");
printf("\t ╭──────────────────────────╮\n");
printf("\t ∣ 中学生个人成绩管理系统 ∣\n");
printf("\t |--------------------------|\n");
printf("\t | |\n");
printf("\t | \t 1. 学生个人成绩管理 |\n");
printf("\t | |\n");
printf("\t | \t 2. 关于本系统帮助 |\n");
printf("\t | |\n");
printf("\t | \t 3. 退 出 系 统 |\n");
printf("\t | |\n");
printf("\t ╰──────────────────────────╯\n");
printf("\t 请您正确选择:");
while(scanf("%d",&in)!=1)
{
while((ch=getchar())!='\n')
putchar(ch);
return in;
}
fflush(stdin);
return in;
}
/*************************中学生个人成绩管理*************************/
// 此子系统目前只支持学生的个人成绩的录入,修改,删除,查询等功能
/******************************************************************************/
void sorcmeun(struct allstudentinfo *p_student)
{
int in;
char ch;
do
{
system("cls");
printf("\n\n\n\n");
printf("\t\t ---------------------\n");
printf("\t\t | 中学生个人成绩管理 |\n");
printf("\t\t |--------------------|\n");
printf("\t\t | 1. 录入学生个人成绩 |\n");
printf("\t\t | |\n");
printf("\t\t | 2. 修改学生个人成绩 |\n");
printf("\t\t | |\n");
printf("\t\t | 3. 查询学生个人成绩 |\n");
printf("\t\t | |\n");
printf("\t\t | 4. 浏览所有学生的成绩 |\n");
printf("\t\t | |\n");
printf("\t\t | 5. 删除学生成绩 |\n");
printf("\t\t | |\n");
printf("\t\t | 6. 退出成绩管理系统 |\n");
printf("\t\t |--------------------|\n");
printf("\t\t 请您正确选择: ");
if(!(scanf("%d",&in)==1))
{
while((ch=getchar())!='\n')
putchar(ch);
printf(" 没有此选项,请正确选择!");
getch();
continue;
}
fflush(stdin);
switch(in)
{
case 1 : inputsorc(p_student); //录入成绩
break;
case 2 : mofsorc (p_student); //修改成绩
break;
case 3 : seasorc (p_student); //查询个人成绩
break;
case 4 : seaallsorc(p_student); //浏览所有学生成绩
break;
case 5 : delsorc (p_student); //删除学生成绩
break;
case 6 : return ; //返回
default: printf("没有此选项,请正确选择!");
break;
}
}while(1);
}
/************************个人成绩录入*************************/
void inputsorc(struct allstudentinfo *p_student)
{
int i,count,countinfo;
char *tempname,ch;
system("cls");
if((sorcfile=fopen(filename1,"a+b"))==NULL) //打开或新建成绩数据文件
{
printf("不能找开文件,请确认磁盘已满或文件是否存在");
getch();
exit(1);
}
rewind(sorcfile); //定位文件头
for(count=0;fread(&p_student[count].student1,sizeof(struct studentsorc),1,sorcfile)
==1;count++)
{
continue;
}
tempname=(char *)malloc(20*sizeof(char)); //分配内存
printf("请输入第%d学生的姓名:",count+1);
while(count<STUDENTMAX&&gets(tempname)!=NULL&&tempname[0]!='\0')
{
strcpy(p_student[count].student1.name,tempname);
printf("请输入该学生的学号:");
scanf("%d",&p_student[count].student1.ID); //输入学号
fflush(stdin); //刷新绶冲
printf("请输入该学生的5科成绩\n");
printf("-----------------------------\n");
printf("\n语文: ");
scanf("%f",&p_student[count].student1.sorc[0]);
fflush(stdin);
printf("\n数学: ");
scanf("%f",&p_student[count].student1.sorc[1]);
fflush(stdin);
printf("\n物理: ");
scanf("%f",&p_student[count].student1.sorc[2]);
fflush(stdin);
printf("\n英语: ");
scanf("%f",&p_student[count].student1.sorc[3]);
fflush(stdin);
printf("\n化学: ");
scanf("%f",&p_student[count].student1.sorc[4]);
fflush(stdin);
printf("\n政治: ");
scanf("%f",&p_student[count].student1.sorc[5]);
fflush(stdin);
printf("-----------------------------\n");
fwrite(&p_student[count++].student1,sizeof(struct studentsorc),1,sorcfile);
//写入文件
printf("确定要继续输入下一个学生的成绩吗(y/n)");
ch=getch();
if(ch=='y'||ch=='Y')
{
system("cls");
free(tempname); //释放内存重新分配
tempname=(char *)malloc(20*sizeof(char));
printf("请输入第%d个学生的姓名:",count+1);
continue;
}
else
{
system("cls");
free(tempname);
fclose(sorcfile);
return ;
}
}
printf("输入有误请返回重新选择操作.......!");
free(tempname);
fclose(sorcfile);
getch();
system("cls");
return ;
}
/************************修改学生成绩****************************/
void mofsorc(struct allstudentinfo *p_student)
{
int i,j,k,count;
float sorc;
char ch;
char *tempname;
count=sorcdatfile(p_student);
if(!count)
{
printf("读取数据失败,请确认已成功录入或文件是否损害");
getch();
system("cls");
return ;
}
tempname=(char *)malloc(20*sizeof(char)); //分配内存
printf("请输入要修改成绩的学生姓名:");
while(gets(tempname)!=NULL&&tempname[0]!='\0')
{
for(i=0;i<count;i++)
{
if(strcmp(tempname,p_student[i].student1.name))
{
continue;
}
else
{
printf("请选择要修改的科目成绩:1.语文 2.数学 3.物理 4.英语 5.化学 6.政治\n");
scanf("%d",&j);
fflush(stdin);
if(j==1)
{
printf("请重新输入%s的语文成绩: ",tempname);
scanf("%f",&sorc);
p_student[i].student1.sorc[0]=sorc;
fflush(stdin);
sorcfile=fopen(filename1,"w+b"); //把修改后的重新写入文件
for(k=0;k<count;k++)
{
if(fwrite(&p_student[k].student1,sizeof(struct studentsorc),1,sorcfile)!=1)
{
free(tempname);
fclose(sorcfile); //写入失败关闭文件
printf("修改失败,返回.......!");
getch();
system("cls");
return ;
}
}
free(tempname);
fclose(sorcfile);
printf("修改成功,返回!.......");
getch();
system("cls");
return ;
}
else if(j==2)
{
printf("请重新输入%s的数学成绩: ",tempname);
scanf("%f",&sorc);
p_student[i].student1.sorc[2]=sorc;
fflush(stdin);
sorcfile=fopen(filename1,"w+b"); //把修改后的重新写入文件
for(k=0;k<count;k++)
{
if(fwrite(&p_student[k].student1,sizeof(struct studentsorc),1,sorcfile)!=1)
{
free(tempname);
fclose(sorcfile); //写入失败关闭文件
printf("修改失败,返回.......!");
getch();
system("cls");
return ;
}
}
free(tempname);
fclose(sorcfile);
printf("修改成功,返回.......!");
getch();
system("cls");
return ;
}
else if(j==3)
{
printf("请重新输入%s的物理成绩: ",tempname);
scanf("%f",&sorc);
p_student[i].student1.sorc[1]=sorc;
fflush(stdin);
sorcfile=fopen(filename1,"w+b"); //把修改后的重新写入文件
for(k=0;k<count;k++)
{
if(fwrite(&p_student[k].student1,sizeof(struct studentsorc),1,sorcfile)!=1)
{
free(tempname);
fclose(sorcfile); //写入失败关闭文件
printf("修改失败,返回.......!");
getch();
system("cls");
return ;
}
}
free(tempname);
fclose(sorcfile);
printf("修改成功,返回.......!");
getch();
system("cls");
return ;
}
else if(j==4)
{
printf("请重新输入%s的英语成绩: ",tempname);
scanf("%f",&sorc);
p_student[i].student1.sorc[4]=sorc;
fflush(stdin);
sorcfile=fopen(filename1,"w+b"); //把修改后的重新写入文件
for(k=0;k<count;k++)
{
if(fwrite(&p_student[k].student1,sizeof(struct studentsorc),1,sorcfile)!=1)
{
free(tempname);
fclose(sorcfile); //写入失败关闭文件
printf("修改失败,返回.......!");
getch();
system("cls");
return ;
}
}
free(tempname);
fclose(sorcfile);
printf("修改成功,返回.......!");
getch();
system("cls");
return ;
}
else if(j==5)
{
printf("请重新输入%s的化学成绩: ",tempname);
scanf("%f",&sorc);
p_student[i].student1.sorc[4]=sorc;
fflush(stdin);
sorcfile=fopen(filename1,"w+b"); //把修改后的重新写入文件
for(k=0;k<count;k++)
{
if(fwrite(&p_student[k].student1,sizeof(struct studentsorc),1,sorcfile)!=1)
{
free(tempname);
fclose(sorcfile); //写入失败关闭文件
printf("修改失败,返回.......!");
getch();
system("cls");
return ;
}
}
free(tempname);
fclose(sorcfile);
printf("修改成功,返回.......!");
getch();
system("cls");
return ;
}
else if(j==6)
{
printf("请重新输入%s的政治成绩: ",tempname);
scanf("%f",&sorc);
p_student[i].student1.sorc[5]=sorc;
fflush(stdin);
sorcfile=fopen(filename1,"w+b"); //把修改后的重新写入文件
for(k=0;k<count;k++)
{
if(fwrite(&p_student[k].student1,sizeof(struct studentsorc),1,sorcfile)!=1)
{
free(tempname);
fclose(sorcfile); //写入失败关闭文件
printf("修改失败,返回.......!");
getch();
system("cls");
return ;
}
}
free(tempname);
fclose(sorcfile);
printf("修改成功,返回.......!");
getch();
system("cls");
return ;
}
else
{
printf("没有此科目,返回.......!");
free(tempname);
getch();
system("cls");
return ;
}
}
}
printf("没有找到%s的学习成绩,返回.......!",tempname);
free(tempname);
getch();
system("cls");
return ;
}
printf("输入有误,返回.......!");
free(tempname);
getch();
system("cls");
return ;
}
/************************查询学生个人成绩*************************/
void seasorc(struct allstudentinfo *p_student)
{
char *tempname;
int tempID,stuID;
int i,j,count;
float sum=0.0,aver;
count=sorcdatfile(p_student);
if(!count)
{
printf("读取数据失败,请确认数据是否存在或文件是否损害");
getch();
system("cls");
return ;
}
printf("请选择要操作的类形:\n");
printf("1.按姓名查找 2.按学号查找\n");
scanf("%d",&tempID);
fflush(stdin);
if(tempID==1) //按姓名查询
{
tempname=(char *)malloc(20*sizeof(char));
printf("请输入该学生的姓名:");
while(gets(tempname)!=NULL&&tempname[0]!='\0')
{
for(i=0;i<count;i++)
{
if(strcmp(tempname,p_student[i].student1.name))
{
continue;
}
else
{
for(j=0;j<6;j++)
{
sum+=p_student[i].student1.sorc[j]; //计算总分
}
aver=sum/6.0; //计算平均分
printf("%s的学生成绩表\n",tempname);
printf("--------------------------\n");
printf("\n学号: %d\n",p_student[i].student1.ID);
printf("\n姓名: %s\n",p_student[i].student1.name);
printf("\n语文: %.2f\n",p_student[i].student1.sorc[0]);
printf("\n数学: %.2f\n",p_student[i].student1.sorc[1]);
printf("\n物理: %.2f\n",p_student[i].student1.sorc[2]);
printf("\n英语: %.2f\n",p_student[i].student1.sorc[3]);
printf("\n化学: %.2f\n",p_student[i].student1.sorc[4]);
printf("\n政治: %.2f\n",p_student[i].student1.sorc[5]);
printf("\n总分: %.2f\n",sum);
printf("\n平均分: %.2f\n",aver);
printf("--------------------------\n");
printf("查询完毕,按任意键返回!");
free(tempname);
getch();
system("cls");
return ;
}
}
printf("找不到该学生的成绩,返回.......!");
free(tempname);
getch();
system("cls");
return ;
}
printf("输入有误,返回.......!");
free(tempname);
getch();
system("cls");
return ;
}
else if(tempID==2) //按学号查询
{
printf("请输入该学生的ID学号:");
scanf("%d",&stuID);
fflush(stdin);
for(i=0;i<count;i++)
{
if(stuID!=p_student[i].student1.ID)
{
continue;
}
else
{
for(j=0;j<6;j++)
{
sum+=p_student[i].student1.sorc[j]; //计算总分
}
aver=sum/6.0; //计算平均分
printf("学号为%d的学生成绩表\n",stuID);
printf("--------------------------\n");
printf("\n学号: %d\n",p_student[i].student1.ID);
printf("\n姓名: %s\n",p_student[i].student1.name);
printf("\n语文: %.2f\n",p_student[i].student1.sorc[0]);
printf("\n数学: %.2f\n",p_student[i].student1.sorc[1]);
printf("\n物理: %.2f\n",p_student[i].student1.sorc[2]);
printf("\n英语: %.2f\n",p_student[i].student1.sorc[3]);
printf("\n化学: %.2f\n",p_student[i].student1.sorc[4]);
printf("\n政治: %.2f\n",p_student[i].student1.sorc[5]);
printf("\n总分: %.2f\n",sum);
printf("\n平均分: %.2f\n",aver);
printf("--------------------------\n");
printf("查询完毕,按任意键返回.......!");
getch();
system("cls");
return ;
}
}
printf("没有找到该学号的成绩,返回.......!");
getch();
system("cls");
return ;
}
printf("没有此选择,返回.......!");
getch();
system("cls");
return ;
}
/************************浏览所有学生的成绩**************************/
void seaallsorc(struct allstudentinfo *p_student)
{
int i,j,count;
float aver,sum=0.0f;
count=sorcdatfile(p_student);
if(!count)
{
printf("读取数据失败,请确认已成功录入或文件是否损害!");
getch();
return ;
}
printf("\n\t\t\t学生成绩表\n");
for(i=0;i<count;i++)
{
sum=aver=0.0; //重新初始化,计算下一次
for(j=0;j<6;j++)
{
sum+=p_student[i].student1.sorc[j]; //计算总分
}
aver=sum/6.0; //计算平均分
printf("-----------------------------\n");
printf("学号: %d\n",p_student[i].student1.ID);
printf("姓名: %s\n",p_student[i].student1.name);
printf("语文成绩: %.2f\n",p_student[i].student1.sorc[0]);
printf("数学成绩: %.2f\n",p_student[i].student1.sorc[1]);
printf("物理成绩: %.2f\n",p_student[i].student1.sorc[2]);
printf("英语成绩: %.2f\n",p_student[i].student1.sorc[3]);
printf("化学成绩: %.2f\n",p_student[i].student1.sorc[4]);
printf("政治成绩: %.2f\n",p_student[i].student1.sorc[5]);
printf("总分成绩: %.2f\n",sum);
printf("平均分成绩: %.2f\n",aver);
printf("-----------------------------\n");
printf("请按任意键继续浏览.......!");
getch();
}
printf("浏览完毕,请返回.......!");
getch();
system("cls");
return ;
}
/************************删除学生成绩******************************/
void delsorc(struct allstudentinfo *p_student)
{
int in,stuID;
int i,count;
char ch;
char *tempname;
count=sorcdatfile(p_student);
if(!count)
{
printf("读取数据失败!请确认已成功录入功或文件是否损害!");
getch();
system("cls");
return ;
}
printf("请选择你操作的选项: 1. 按姓名查找删除 2. 按学号查找删除");
scanf("%d",&in);
fflush(stdin);
if(in==1)
{
tempname=(char *)malloc(20*sizeof(char));
printf("请输入你要删除的学生姓名: ");
gets(tempname);
for(i=0;i<count;i++)
{
if(strcmp(tempname,p_student[i].student1.name))
continue;
else
{
for(;i<count;i++)
{
p_student[i].student1=p_student[i+1].student1;
}
--count; //成绩减1
sorcfile=fopen(filename1,"w+b");
for(i=0;i<count;i++)
{
if(fwrite(&p_student[i].student1,sizeof(struct studentsorc),1,sorcfile)==1)
continue;
else
{
printf("删除失败...!");
free(tempname);
fclose(sorcfile);
getch();
system("cls");
return ;
}
}
printf("删除成功...!");
free(tempname);
fclose(sorcfile);
getch();
system("cls");
return ;
}
}
printf("找不到该学生,返回...!");
free(tempname);
getch();
system("cls");
return ;
}
else if(in==2)
{
printf("请输入你要删除的学生学号: ");
scanf("%d",&stuID);
fflush(stdin);
for(i=0;i<count;i++)
{
if(stuID!=p_student[i].student1.ID)
continue;
else
{
for(;i<count;i++)
{
p_student[i].student1=p_student[i+1].student1;
}
--count; //成绩减1
sorcfile=fopen(filename1,"w+b");
for(i=0;i<count;i++)
{
if(fwrite(&p_student[i].student1,sizeof(struct studentsorc),1,sorcfile)==1)
continue;
else
{
printf("删除失败...!");
fclose(sorcfile);
getch();
system("cls");
return ;
}
}
printf("删除成功...!");
fclose(sorcfile);
getch();
system("cls");
return ;
}
}
printf("找不到该学生,返回...!");
getch();
system("cls");
return ;
}
printf("输入有误,返回...!");
getch();
system("cls");
return ;
}
/**********************成绩数据文件***************************/
int sorcdatfile(struct allstudentinfo *p_student)
{
int count;
system("cls");
if((sorcfile=fopen(filename1,"rb"))==NULL)
{
printf("不能找开文件,请确认磁盘已满或文件是否存在!");
getch();
exit(1);
}
rewind(sorcfile); //指向文件头读取数据
for(count=0;fread(&p_student[count].student1,sizeof(struct studentsorc),1,sorcfile)
==1;count++)
{
continue;
}
fclose(sorcfile);
return count; //返回读到的结构块数
}
/*************************系统帮助信息***************************/
void systemhelp()
{
system("cls");
printf("\n\n\n\t\t\t系统消息\n");
printf("\t----------------------------\n");
printf("\t 本系统目前支持sogou汉字录入以及英语,拼音或其它\n");
printf("\t 助记方式录入。如要使用修改和删除功能请谨慎使用,\n");
printf("\t 或先将资料做好备份以免因系统出错造成数据丢失!\n");
printf("\t----------------------------\n");
printf(" 开发者: 小明\n");
printf(" 开发时间:2007-12\n");
getch();
system("cls");
return ;
}