600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 【c语言学生管理系统】c语言学生成绩管理系统设计学生成绩信息包括:学号...

【c语言学生管理系统】c语言学生成绩管理系统设计学生成绩信息包括:学号...

时间:2019-09-15 07:01:00

相关推荐

【c语言学生管理系统】c语言学生成绩管理系统设计学生成绩信息包括:学号...

问题补充:

c语言 学生成绩管理系统设计学生成绩信息包括:学号,姓名,三门课程成绩(数学、英语和计算机)等。主要功能:(1) 计算各个学生的总分及平均分,并按平均分排出名次。(2) 统计全班学生平均分成绩,输出60分以下、60~79、80~89、90分以上各分数人数。(3) 能按学号查询学生成绩,并能输出学生的成绩单。(4) 输出不及格科目及学生名单。(5) 选做:在屏幕输出优等生名单(学号,三门课程成绩,平均成绩,名次),优等生必须满足下列条件:1)平均成绩大于90分;或平均分大于85分且至少有一门功课为100分;或者平均分大于85分且至少两门课程成绩为95分以上;2) 名次在前三名; 3) 每门功课及格以上;要求:系统以菜单方式工作。

答案:

【答案】 希望对你有所帮助。

#includestdio.h

#includestdlib.h

#includestring.h

#define N 3

typedef struct z1

{

char no[11];

char name[15];

int score[N];

float sum;

float average;

int order;

struct z1 *next;

}STUDENT;

STUDENT *init();

STUDENT *create();

STUDENT *del(STUDENT *h);

void print(STUDENT *h);

void search1(STUDENT *h);

void search2(STUDENT *h);

STUDENT *insert(STUDENT *h);

void sort(STUDENT *h);

void save(STUDENT *h);

void tongji(STUDENT *h);

int menu_select();

STUDENT *load();

void inputs(char *prompt,char *s,int count);

STUDENT *load();

main()

{

int i;

STUDENT *head;

head=init();

for(;;)

{

switch(menu_select())

{

case 0:head=init();break;

case 1:head=create();break;

case 2:head=insert(head);break;

case 3:save(head);break;

case 4:print(head);break;

case 5:search1(head);break;

case 6:head=del(head);break;

case 7:sort(head);break;

case 8:tongji(head);break;

case 9:search2(head);break;

case 10:exit(0);

}

}

}

int menu_select()

{

char *menu[]={************菜单************,

0. 初始化链表,

1. 输入学生成绩,

2. 插入学生成绩,

3. 保存学生记录,

4. 显示学生记录,

5. 按学号查找学生信息,

6. 删除指定学号的学生信息,

7. 按某一门课对学生成绩排序,

8. 统计某门课程的学生成绩,

9. 按姓名查找学生信息,

10. 退出系统};

char s[3];

int c,i;

for(i=0;i10);

return c;

}

STUDENT *init()

{

return NULL;

}

STUDENT *create()

{

int i;int s;

STUDENT *h=NULL,*info;

for(;;)

{

info=(STUDENT *)malloc(sizeof(STUDENT));

if(!info)

{

printf(\n内存不足);

return NULL;

}

inputs(输入学号:,info->no,11);

if(info->no[0]==@)break;

inputs(输入姓名:,info->name,15);

printf(开始输入%d门课的成绩\n,N);

s=0;

for(i=0;iscore[i]);

if(info->score[i]>100||info->score[i]score[i]>100||info->score[i]score[i];

}

info->sum=s;

info->average=(float)s/N;

info->order=0;

info->next=h;

h=info;

}

return h;

}

void inputs(char *prompt,char *s,int count)

{

char p[255];

do

{

printf(prompt);

scanf(%s,p);

if(strlen(p)>count)

printf(\n太长了!\n);

}while(strlen(p)>count);

strcpy(s,p);

}

void print(STUDENT *h)

{

int i=0;

STUDENT *p;

p=h;

printf(\n\n\n***********************学生***********************\n);

printf(|序号|学号 | 姓名 | 数学 | 英语 |计算机 | 总分 |平均分 |名次 |\n);

printf(|---|-------|--------|----|----|----|------|------|---|\n);

while(p!=NULL)

{

i++;

printf(|%3d |%-10s|%-8s|%4d|%4d|%4d|%4.2f|%4.2f|%3d|\n,i,p->no,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

p=p->next;

}

printf(***********************end***********************\n);

}

STUDENT *del(STUDENT *h)

{

STUDENT *p,*q;

char s[11];

printf(请输入要删除的学生的学号\n);

scanf(%s,s);

q=p=h;

while(strcmp(p->no,s)&&p!=NULL)

{

q=p;

p=p->next;

}

if(p==NULL)

printf(\n链表中没有学号为%s的学生\n,s);

else

{

printf(\n\n\n***********************找到了***********************\n);

printf(|学号 | 姓名 | 数学 | 英语 | 计算机 | 总分 | 平均分 | 名次 |\n);

printf(|----------|----------|----|----|----|------|------|---|\n);

printf(|%-10s|%-8s|%4d|%4d|%4d|%4.2f|%4.2f|%3d|\n,p->no,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

printf(***********************end***********************\n);

printf(请按任意键删除\n);

getchar();

if(p==h)

h=p->next;

else q->next=p->next;

free(p);

printf(\n已经删除学号为%s的学生\n,s);

printf(不要忘了保存数据\n);

}

return h;

}

void search1(STUDENT *h)

{

STUDENT *p;

char s[11];

printf(请输入你要查找的同学的学号\n);

scanf(%s,s);

p=h;

while(strcmp(p->no,s)&&p!=NULL)

p=p->next;

if(p==NULL)

printf( 没有学号为%s的学生\n,s);

else

{

printf(\n\n\n***********************找到了***********************\n);

printf(|学号| 姓名 | 数学 | 英语 | 计算机 | 总分 | 平均分 | 名次 |\n);

printf(|----------|-----------|----|----|----|------|------|---|\n);

printf(|%-10s|%-8s|%4d|%4d|%4d|%4.2f|%4.2f|%3d|\n,p->no,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

printf(***********************end***********************\n);

}

}

void search2(STUDENT *h)

{

STUDENT *p;

char s[11];

printf(请输入你要查找的同学的姓名\n);

scanf(%s,s);

p=h;

while(strcmp(p->name,s)&&p!=NULL)

p=p->next;

if(p==NULL)

printf(\n没有姓名为%s的学生\n,s);

else

{

printf(\n\n\n***********************找到了***********************\n);

printf(|学号| 姓名 | 数学 | 英语 | 计算机 | 总分 | 平均分 | 名次 |\n);

printf(|----------|-----------|----|----|----|------|------|---|\n);

printf(|%-10s|%-8s|%4d|%4d|%4d|%4.2f|%4.2f|%3d|\n,p->no,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

printf(***********************end***********************\n);

}

}

STUDENT *insert(STUDENT *h)

{

STUDENT *p,*q,*info;

char s[11];

int s1,i;

printf(请输入插入点的学生学号\n);

scanf(%s,s);

printf(\n请输入新的学生信息\n);

info=(STUDENT *)malloc(sizeof(STUDENT));

if(!info)

{

printf(\n内存不足!);

return NULL;

}

inputs(输入学号:,info->no,11);

inputs(输入姓名:,info->name,15);

printf(请输入%d门课的分数\n,N);

s1=0;

for(i=0;iscore[i]);

if(info->score[i]>100||info->score[i]score[i]>100||info->score[i]score[i];

}

info->sum=s1;

info->average=(float)s1/N;

info->order=0;

info->next=NULL;

p=h;

q=h;

while(strcmp(p->no,s)&&p!=NULL)

{q=p;p=p->next;}

if(p==NULL)

if(p==h)

h=info;

else q->next=info;

else

if(p==h)

{

info->next=p;

h=info;

}

else

{

info->next=p;

q->next=info;

}

printf(\n已经插入了%s这个学生\n,info->name);

printf(----不要忘了存盘啊--\n);

return(h);

}

void save(STUDENT *h)

{

FILE *fp;

STUDENT *p;

char outfile[10];

printf(请输入保存文件的文件名,例如 c:\\f1\\te.txt:\n);

scanf(%s,outfile);

if((fp=fopen(outfile,wb))==NULL)

{

printf(不能打开文件\n);

exit(1);

}

printf(\n正在保存......\n);

p=h;

while(p!=NULL)

{

fwrite(p,sizeof(STUDENT),1,fp);

p=p->next;

}

fclose(fp);

printf(------保存成功!!!------\n);

}

void sort(STUDENT *h)

{

int i=0,j;

STUDENT *p,*q,*t,*h1;

printf(请输入要按哪门课程的编号来排序:(1.数学 2.英语 3.计算机)\n);

scanf(%d,&j);

h1=h->next;

h->next=NULL;

while(h1!=NULL)

{

t=h1;

h1=h1->next;

p=h;

q=h;

while(t->score[j]score[j]&&p!=NULL)

{

q=p;

p=p->next;

}

if(p==q)

{

t->next=p;

h=t;

}

else

{

t->next=p;

q->next=t;

}

}

p=h;

while(p!=NULL)

{

i++;

p->order=i;

p=p->next;

}

print(h);

printf(排序成功!!!\n);

}

void tongji(STUDENT *h)

{

STUDENT *p;

int a,b,i;

printf(请输入课程编号\n);

scanf(%d,&i);

printf(请输入分数段:\n);

scanf(%d,%d,&a,&b);

p=h;

while(p!=NULL)

{

printf(\n\n\n***********************找到了***********************\n);

if(p->score[i]>=a&&p->score[i]no,p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);

}

p=p->next;

}

printf(***********************end***********************\n);

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。