学生信息管理系统模拟 编程语言为C语言,编程环境为VC++ 6.0

第一部分存储结构设计任务设计学生结构体。编程要求1.结构体设计“学生”结构体包含“学号”、“姓名”、“性别”、“英语成绩”、“C语言成绩”。2.存储结构要求在实现各个模块... 第一部分 存储结构设计
任务
设计学生结构体。
编程要求
1. 结构体设计
“学生”结构体包含“学号”、“姓名”、“性别”、“英语成绩”、“C语言成绩”。
2. 存储结构要求
在实现各个模块的功能时, 根据该模块的具体要求确定存储结构。

第二部分 菜单(界面)设计
任务
编程实现系统的菜单
编程要求
“登陆”菜单(选做,有加分)
1----------用户登陆
0----------退出系统

主菜单样式如下:
1----------学生录入
2----------学生浏览
3----------学生查询
4----------学生删除
5----------成绩统计
0----------退出系统

第三部分 功能和函数设计
任务
通过函数完成各个菜单模块的功能,要求合理设计主函数和各个子函数,合理设计各个函数之间的调用关系。
编程要求
1. 主函数:显示主菜单。
2. 如果设计并编写登陆菜单,要求合理设计登陆界面,要求用户输入用户名和密码,如果全都正确则进入主菜单,如果有一项不对,系统再提供两次机会输入,三次都错退出系统。(此部分有加分)
3. 编写函数完成“学生录入”功能,要求能将用户由键盘输入的若干学生信息追加到student.txt或student.dat中,存储结构可以使用数组,也可以使用链表。
4. 编写函数完成“学生浏览”功能,要求能将student.txt或student.dat文件中的全部学生信息显示出来,存储结构可以使用数组,也可以使用链表。
5. 编写函数完成“学生查询”功能,要求能按照学号或姓名对学生进行查询。
6. 编写函数完成“学生删除”功能,要求按照学号或姓名将某个学生删除,并将删除后的结果写回到文件中,此功能要求存储结构必须使用链表。
7. 设计并编写编写函数完成“成绩统计”功能,可以对“英语成绩”、“C语言成绩”进行单科浏览(降序排列),按某个学生统计总分和平均分,按英语和C语言两科成绩对学生进行排序。
帮忙编写这个程序。。。。。。。。。。。。。。。。。学生信息管理系统。。。要求都写着了。。。。。。。。。。。。。。。。谢谢
展开
dapengbusi
2012-04-09 · TA获得超过211个赞
知道答主
回答量:113
采纳率:0%
帮助的人:72.3万
展开全部
/*
***这个是我写的,你可以参考下,我的编译器用的是devC++,可以说我的代码效率是非常之高,同时界面精工细作的,很完美,得到老师的高度赞扬,只是没用到数据库,唯一的缺憾,vc下运行编译可能会报错,主要是两个编译器对于循环的变量声明,限制是不一致的,具体细节你可以改改就好,程序是非常对的,就是变量的声明先后,或者位置在vc下会报错,往注意,如果好的好,请及时散分。哥也很忙,这个没时间来细看了,抱歉。
*
/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include<conio.h>
int shoudsave=0; /* */
struct student
{
char num[10];/*学号*/
char name[20];
int cgrade;
int mgrade;
int egrade;
int totle;
int ave;
};

typedef struct node
{
struct student data;
struct node *next;
} Node,*Link;

void menu()
{
printf("\t\t\t\t学生成绩管理系统\n\t\t\t-------------------------------\n");
printf("********************************************************************************");
printf("\t1输入学生资料\t\t\t\t\t2删除学生资料\n");
printf("\t3查询学生资料\t\t\t\t\t4修改学生资料\n");
printf("\t5显示学生资料\t\t\t\t\t6统计学生成绩\n");
printf("\t7排序学生成绩\t\t\t\t\t8保存学生资料\n");
printf("\t9获取帮助信息\t\t\t\t\t0退出系统\n");
printf("********************************************************************************\n");
}

void printstart()
{
printf("-----------------------------------------------------------------------\n");
}
void Wrong()
{
printf("\n=====>提示:输入错误!\n");
}

void Nofind()
{
printf("\n=====>提示:没有找到该学生!\n");
}

void printc() /* 本函数用于输出中文标题 */
{
printf("学号 姓名 英语成绩 数学成绩 C语言成绩 总分 平均分\n");
}

void printe(Node *p)/*本函数用于输出中文标题下的具体内容 */
{
printf("\t%s \t%s \t%d \t%d \t%d \t%d \t%d\n",p->data.num,p->data.name, p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.totle,p->data.ave);
}//少个名字的打印

Node *Locate(Link l,char findmess[],char nameornum[]) /*该函数用于定位连表中符合要求的接点,并返回该指针 */
{
Node *r;
if(strcmp(nameornum,"num")==0) /*按学号查询*/
{
r=l->next;
while(r)
{
if(strcmp(r->data.num,findmess)==0)
return r;
r=r->next;
}
}
else if(strcmp(nameornum,"name")==0) /*按姓名查询 */
{
r=l->next;
while(r)
{
if(strcmp(r->data.name,findmess)==0)
return r;
r=r->next;
}
}
return 0;
}

void Add(Link L) /*增加学生头指针用大写便于区分*/
{
system("cls");//清屏
Node *p,*r,*s;
char num[10];
while(1)
{
r=L;
s=L->next;
while(r->next!=NULL)
r=r->next;
printf("请你输入学号(以'0'返回上一级菜单:)");
scanf("%s",num);
getchar();
if(strcmp(num,"0")==0)
break;
while(s)
{
if(strcmp(s->data.num,num)==0)
{
system("cls");
printf("=====>提示:学号为'%s'的学生已经存在,请重新添加!\n",num);//改动换行
printstart();
printc();
printe(s);
printstart();
printf("\n");
printf("请你输入学号(以'0'返回上一级菜单):");
scanf("%s",num);
getchar();
s=L->next;//返回重新查找,是否新的输入已经存在
}
else
s=s->next;//没有匹配的继续找。。。
}

p=(Node *)malloc(sizeof(Node));

strcpy(p->data.num,num);
printf("请你输入姓名:");
scanf("%s",p->data.name);
getchar();//程序暂停等待输入
printf("请你输入c语言成绩:");
scanf("%d",&p->data.cgrade);
getchar();
printf("请你输入数学成绩:");
scanf("%d",&p->data.mgrade);
getchar();
printf("请你输入英语成绩:");
scanf("%d",&p->data.egrade);
getchar();
p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade;
p->data.ave=p->data.totle / 3;/*信息输入已经完成*/

p->next=NULL;
r->next=p;
//r=p;此处多余
shoudsave=1;

}
printf("按任意键返回!");
getch();
}

void Qur(Link l) /*查询学生*/
{
int sel;
char findmess[20];
Node *p;
char choice;
while(1){
system("cls");
if(!l->next)
{
printf("\n=====>提示:没有资料可以查询!\n");
//不用返回return;
printf("请先添加一个数据吧,亲。。。\n");
break;
}
printf("\n=====>1按学号查找\n=====>2按姓名查找\n");
scanf("%d",&sel);
if(sel==1)/*学号*/
{
printf("请你输入要查找的学号:");
scanf("%s",findmess);
p=Locate(l,findmess,"num");
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else if(sel==2) /*姓名*/
{
printf("请你输入要查找的姓名:");
scanf("%s",findmess);
p=Locate(l,findmess,"name");
if(p)
{
printf("\t\t\t\t查找结果\n");
printstart();
printc();
printe(p);
printstart();
}
else
Nofind();
}
else
Wrong();
printf("\n是否继续查询(y/n):");//选择是否继续查询
getchar();
scanf("%c",&choice);
if(choice=='n'){
printf("按任意键返回!亲");
getch();
break;}
}
}

void Del(Link l) /*删除*/
{
int sel;
Node *p,*r;
char choice;
char findmess[20];
while(1){
system("cls");
if(!l->next)
{
printf("\n=====>提示:没有资料可以删除!\n");
printf("返回重新选择吧,亲。。。");//return;
break;
}
printf("\n=====>1按学号删除\n=====>2按姓名删除\n");
scanf("%d",&sel);
if(sel==1)
{
printf("请你输入要删除的学号:");
scanf("%s",findmess);
p=Locate(l,findmess,"num");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
shoudsave=1;
printf("\n是否继续删除(y/n):");//选择是否继续删除
getchar();
scanf("%c",&choice);
if(choice=='n')
break;

}
else{
Nofind();
break;
}
}
else if(sel==2)
{
printf("请你输入要删除的姓名:");
scanf("%s",findmess);
p=Locate(l,findmess,"name");
if(p)
{
r=l;
while(r->next!=p)
r=r->next;
r->next=p->next;
free(p);
printf("\n=====>提示:该学生已经成功删除!\n");
shoudsave=1;
printf("\n是否继续删除(y/n):");//选择是否继续删除
getchar();
scanf("%c",&choice);
if(choice=='n')
break;

}
else{
Nofind();
break;
}
}
else
Wrong();
system("pause");
}
printf("按任意键返回哦,亲");
getch();
}
void Modify(Link l)
{
system("cls");
Node *p,*s;
s=l->next;
char findmess[20];
int key=1;
while(1){
if(!l->next)
{
printf("\n=====>提示:没有资料可以修改!\n");
break;
}
while(key){
system("cls");
getchar();
printf("请你输入要修改的学生学号:");
scanf("%s",findmess);
//添加一个检验是否有该学生号的函数
while(s)
{
if(strcmp(s->data.num,findmess)==0)
{
system("cls");
printf("=====>提示:学号为'%s'的学生已经找到,请修改!\n",findmess);
printstart();
printc();
printe(s);
printstart();
printf("\n");
key=0;//跳出大循环
break;//跳出内循环
}
else
s=s->next;//没有匹配的继续找。。。
}
//如果扫描完,仍没有找到,则提示重新输入
if(!s)
printf("\n该学号不存在,请检查是否输入正确!\n");
system("pause");
}
p=Locate(l,findmess,"num");
if(p)
{
// printf("请你输入新的c语言成绩(原来是%d分):",p->data.cgrade);
// scanf("%d",&p->data.cgrade);
printf("请你输入新的姓名:");
scanf("%s",p->data.name);
getchar();//程序暂停等待输入
printf("请你输入新的c语言成绩:");
scanf("%d",&p->data.cgrade);
getchar();
printf("请你输入新的数学成绩:");
scanf("%d",&p->data.mgrade);
getchar();
printf("请你输入新的英语成绩:");
scanf("%d",&p->data.egrade);
getchar();
p->data.totle=p->data.egrade+p->data.cgrade+p->data.mgrade;//修改后总成绩以及平均成绩都要变化
p->data.ave=p->data.totle / 3;/*信息输入已经完成*/
printf("\n=====>提示:资料修改成功!\n");
shoudsave=1;
}
else
Nofind();
break;
}
printf("请按任意键继续。。。");
getch();
}

void Disp(Link l)
{
system("cls");
int count=0;
Node *p;
p=l->next;
while(1){
if(!p)
{
printf("\n=====>提示:没有资料可以显示!\n");
//回复毛啊return;
break;
}
printf("\t\t\t\t显示结果\n");
printstart();
printc();
printf("\n");
while(p)
{
printe(p);
p=p->next;
}
printstart();
printf("\n");
break;//修改过
}
printf("按任意键返回!");
getch();
}

//sort排序函数
int SortData(Link L)//采用最简单冒泡排序方法按总成绩排名
{
struct student temp;
Node *r=L->next,*p1,*p2;
int count=0,i,j;
while(r)
{r=r->next;
count++;
}//计算链表的长度
for(i=1;i<=count-1;i++){

for(r=L->next,j=1;j<=count-i;r=r->next)
{
if(r->data.totle<r->next->data.totle)
{temp=r->data;
r->data=r->next->data;
r->next->data=temp;}
/*p1=r->next;
r->next=r->next->next;
p2=r->next->next->next;
r->next->next=p1;
r->next->next->next=p2;*/
j++;
}
}
printf("已排序成功!请返回主界面查询!");
getch();
return 0;
}
void StatisData(Link L)
{ system("cls");
struct student temp;
Node *r=L->next,*p1,*p2;
int count=0,i,j;
while(r)
{r=r->next;
count++;
}//计算链表的长度
for(i=1;i<=count-1;i++){

for(r=L->next,j=1;j<=count-i;r=r->next)
{
if(r->data.ave<r->next->data.ave)
{temp=r->data;
r->data=r->next->data;
r->next->data=temp;}
/*p1=r->next;
r->next=r->next->next;
p2=r->next->next->next;
r->next->next=p1;
r->next->next->next=p2;*/
j++;
}
}
printf("\n平均分最高的是:\t%s,%d",L->next->data.name,L->next->data.ave);
for(i=1;i<=count-1;i++){

for(r=L->next,j=1;j<=count-i;r=r->next)
{
if(r->data.cgrade<r->next->data.cgrade)
{temp=r->data;
r->data=r->next->data;
r->next->data=temp;}
/*p1=r->next;
r->next=r->next->next;
p2=r->next->next->next;
r->next->next=p1;
r->next->next->next=p2;*/
j++;
}
}
printf("\nc语言成绩最高的是:\t%s,%d",L->next->data.name,L->next->data.cgrade);
for(i=1;i<=count-1;i++){

for(r=L->next,j=1;j<=count-i;r=r->next)
{
if(r->data.mgrade<r->next->data.mgrade)
{temp=r->data;
r->data=r->next->data;
r->next->data=temp;}
/*p1=r->next;
r->next=r->next->next;
p2=r->next->next->next;
r->next->next=p1;
r->next->next->next=p2;*/
j++;
}
}
printf("\n数学成绩最高的是:\t%s,%d",L->next->data.name,L->next->data.mgrade);
for(i=1;i<=count-1;i++){

for(r=L->next,j=1;j<=count-i;r=r->next)
{
if(r->data.egrade<r->next->data.egrade)
{temp=r->data;
r->data=r->next->data;
r->next->data=temp;}
/*p1=r->next;
r->next=r->next->next;
p2=r->next->next->next;
r->next->next=p1;
r->next->next->next=p2;*/
j++;
}
}
printf("\n英语成绩最高的是:\t%s,%d",L->next->data.name,L->next->data.egrade);
for(i=1;i<=count-1;i++){

for(r=L->next,j=1;j<=count-i;r=r->next)
{
if(r->data.totle<r->next->data.totle)
{temp=r->data;
r->data=r->next->data;
r->next->data=temp;}
/*p1=r->next;
r->next=r->next->next;
p2=r->next->next->next;
r->next->next=p1;
r->next->next->next=p2;*/
j++;
}
}//
printf("\n总成绩最高的是:\t%s,%d",L->next->data.name,L->next->data.totle);
system("pause");
}
void Save(Link l)
{
system("cls");
FILE *fp;
Node *p;
int flag=1,count=0;
fp=fopen("c:\\student.txt","wb");
if(fp==NULL)
{
printf("\n=====>提示:重新打开文件时发生错误!\n");
exit(1);
}
p=l->next;

while(p)
{
if(fwrite(p,sizeof(Node),1,fp)==1)
{
p=p->next;
count++;
}
else
{
flag=0;
break;
}
}
if(flag)
{
printf("\n=====>提示:文件保存成功.(有%d条记录已经保存.)\n",count);
shoudsave=0;
}
fclose(fp);
system("pause");
}

int main()
{
Link l;/*连表*/
FILE *fp; /*文件指针*/
int sel;
char ch;
system("color 4f");
int count=0;
Node *p,*r;
//加入menu函数中了 printf("\t\t\t\t学生成绩管理系统\n\t\t\t-------------------------------\n");
l=(Node*)malloc(sizeof(Node));
l->next=NULL;
r=l;

fp=fopen("C:\\student.txt","ab+");
if(fp==NULL)
{
printf("\n=====>提示:文件不能打开!\n");
exit(0);
}
printf("\n=====>提示:文件已经打开,正在导入记录......\n");
while(!feof(fp))
{
p=(Node*)malloc(sizeof(Node));
if(fread(p,sizeof(Node),1,fp)==1) /*将文件的内容放入接点中 */
{
p->next=NULL;
r->next=p;
r=p; /*将该接点挂入连中*/
count++;
}
}

fclose(fp); /*关闭文件 */

while(1)
{
system("cls");
printf("\n=====>提示:文件已经打开,正在导入记录......\n");
menu();//调入主循环
printf("请你选择操作:");
scanf("%d",&sel);

if(sel==0)
{
if(shoudsave==1)
{ getchar();
printf("\n=====>提示:资料已经改动,是否将改动保存到文件中(y/n)?\n");
scanf("%c",&ch);
if(ch=='y'||ch=='Y')
Save(l);
}
printf("\n=====>提示:你已经退出系统,再见!\n");
break;
}
switch(sel)
{
case 1:Add(l);break; /*增加学生*/
case 2:Del(l);break;/*删除学生*/
case 3:Qur(l);break;/*查询学生*/
case 4:Modify(l);break;/*修改学生*/
case 5:Disp(l);break;//显示信息
case 6:StatisData(l);break;//统计函数
case 7:SortData(l);break;//排序
case 8:Save(l);break;/*保存学生 */
case 9:printf("\t\t\t==========帮助信息==========\n");menu();system("pause");break;
default: Wrong();getchar();break;
}
}

while (l){ /*释放链表l(不是1)所占用的内存!*/
p = l;
l = l->next;
free(p);
}

getchar();

return 0;
}
温文尔雅又深挚灬风光u
2012-04-08 · TA获得超过1313个赞
知道小有建树答主
回答量:1384
采纳率:0%
帮助的人:514万
展开全部
你想问什么
追问
帮忙编写这个程序。。。。。。。。。。。。。。。。。学生信息管理系统。。。要求都写着了。
追答
http://wenku.baidu.com/view/8994e441be1e650e52ea999d.html我只能给你教程 其余的自己弄不喜欢别问别说别骂
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式