学生信息管理系统模拟 编程语言为C语言,编程环境为VC++ 6.0 在vc++6.0的环境中编程(c语言)要不要新建一个工程?是...

作者&投稿:成油 (若有异议请与网页底部的电邮联系)
/*
***这个是我写的,你可以参考下,我的编译器用的是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;
}

你想问什么

按以下要求,用C语言编一个程序——简单学生管理系统,使用的是VC++6.0这种编译器。。~

#include
#include
struct student
{
int num;
char n[50];
int a1,a2,a3,s1;
}stu[50],t;
static int b=0,i;
char a;
void display();
void x();
void p();
void c();
void s();
void main()
{printf("显示学员的信息:
");
display();
x();
p();
c();
s();
}
void display()
{
int i=0;
do{
printf("学号: ");
scanf("%d",&stu[i].num);
fflush(stdin);
printf("姓名: ");
gets(stu[i].n);
fflush(stdin);
printf("三门成绩:
");
printf("成绩1: ");
scanf("%d",&stu[i].a1);
printf("成绩2: ");
scanf("%d",&stu[i].a2);
printf("成绩3: ");
scanf("%d",&stu[i].a3);
stu[i].s1=(stu[i].a1+stu[i].a2+stu[i].a3)/3;
printf("是否继续: ");
fflush(stdin);
a=getchar();
i++,b++;
}while (a=='y');
}
void x()
{
int j;
printf("学号姓名平均成绩
");
for(j=0;j<b;j++)
{
printf("%d%s%d
",stu[j].num,stu[j].n,stu[j].s1);
}
}
void p()
{
int i,j;
for(i=0;i<b;i++)
{
for(j=0;j<b-i-1;j++)
{
if(stu[j].s1<stu[j+1].s1)
{
t=stu[j+1];
stu[j+1]=stu[j];
stu[j]=t;
}
}
}
printf("排序后的信息为:
");
x();
}
void c()
{
int i,j,t;
char a;
struct student stu1;
printf("是否要插入学员得信息: ");
fflush(stdin);
a=getchar();
while(a=='y')
{
printf("学号: ");
scanf("%d",&stu1.num);
fflush(stdin);
printf("
姓名: ");
gets(stu1.n);
fflush(stdin);
printf("三门成绩:
");
printf("
成绩1: "); scanf("%d",&stu1.a1);
printf("
成绩2: "); scanf("%d",&stu1.a2);
printf("
成绩3: "); scanf("%d",&stu1.a3);
t=stu1.a1+stu1.a2+stu1.a3;
stu1.s1=t/3;
for(i=0;i<b;i++)
{
if(stu[i].s1>stu1.s1)
break;
}
for(j=b;j>i;j--)
{
stu[j]=stu[j-1];
}
stu[i]=stu1;
b++;
printf("插入后学员的信息:
");
p();
break;
}
}
void s()
{
int i,j,n;
printf("是否要删除学员信息: ");
fflush(stdin);
a=getchar();
while(a=='y')
{
printf("输入删除学员的学号: ");
scanf("%d",&n);
fflush(stdin);
for(i=0;i<b;i++)
{
if(stu[i].num==n)
break;
}
for(j=i;j<b;j++)
{
stu[j]=stu[j+1];
}
b--;
printf("
删除后的学员信息:
");
x();
break;
}
}

这是我做的,不知道是否符合你的要求.因为是很久以前做的了,是不是符合你的要求就真的不记得了,你好好看看吧.是我学C做的第二个项目啊.如果符合你的要求就应该没有太大的问题.

vc也可以不见工程的,就在文件中新建一个c/c++ Source File就可以了,但推荐建工程了,点击Win32 Console Application ,再在工程名称处取个名字,位置随便改不改,再点击确定,建一个空的工程就行了