#include<stdio.h> #include<stdlib.h> #include<string.h> #define N 3 typedef struct student { int id; //学号 char name[20]; //姓名 char subject[20]; float perf; float mid; float final; float total; char level[10]; }STU; void input(STU[], int); /*输入学生信息*/ void calc(STU[], int); /*计算总评和等级*/ int fail(STU[], STU [], int); /*不及格学生统计*/ void sort(STU[], int); /*排序*/ void print(STU[], int); /*输出学生信息*/ int main(void) { STU st[N],fst[N];//st——students, fst——failed students int k;//count failed students printf("录入学生成绩信息:\n"); input(st, N); printf("\n成绩处理...\n"); calc(st, N); k=fail(st, fst, N); sort(st, N); printf("\n学生成绩排名情况:\n"); print(st, N); printf("\n不及格学生信息:\n"); print(fst, k); return 0; } void input(STU s[], int n) { int i=0; for(i=0; i<n; i++) scanf("%d %s %s %f %f %f",&s[i].id,s[i].name,s[i].subject,&s[i].perf,&s[i].mid,&s[i].final); } void calc(STU s[], int n) { int i=0; for(i=0; i<n; i++) { s[i].total=s[i].perf*0.2+s[i].mid*0.2+s[i].final*0.6; if(s[i].total<60) strcpy(s[i].level,"Fail"); else if(s[i].total<70) strcpy(s[i].level,"Passed"); else if(s[i].total<80) strcpy(s[i].level,"Medium"); else if(s[i].total<90) strcpy(s[i].level,"Good"); else strcpy(s[i].level,"Excellent"); } } int fail(STU s[], STU t[], int n)//s->all,t->fail,n->number of s[] { int i,k=0; for(i=0; i<n; i++) if(s[i].total<60) t[k++]=s[i]; return k; } void sort(STU s[], int n) { int i,j; STU temp; for(i=0; i<n-1; i++) for(j=0; j<n-1-i; j++) if(s[j].total < s[j+1].total) { temp = s[i]; s[i] = s[j+1]; s[j+1] = temp; } } void print(STU s[], int n) { int i; printf("-----------------\n"); printf("学号 姓名 考试科目 平时成绩 期中成绩 期末成绩 总评成绩 成绩等级 \n"); for(i=0; i<n; i++) printf("%5d %10s %10s %15.1f %15.1f %15.1f %15.1f %15s\n",s[i].id,s[i].name,s[i].subject,s[i].perf,s[i].mid,s[i].final,s [i].total,s[i].level); }
#include <stdio.h> const int N=5; typedef struct student //定义结构体类型struct student,并定义STU为其别名 { long no; char name[20]; int score; }STU; void input(STU s[], int n);//函数声明 int findMinlist(STU s[], STU t[], int n); void output(STU s[], int n); int main() { STU stu[N], minlist[N]; int count; printf("录入%d个学生信息\n", N); input(stu, N); printf("\n统计最低分人数和学生信息...\n"); count = findMinlist(stu, minlist, N); printf("\n一共有%d个最低分,信息如下:\n", count); output(minlist, count); return 0; } void input(STU s[], int n) //输入n个学生信息,存放在结构体数组s中 { int i; for(i=0; i<n; i++) scanf("%ld %s %d", &s[i].no, s[i].name, &s[i].score); } void output(STU s[], int n) //输出结构体s中n个元素信息 { int i; for(i=0; i<n; i++) printf("%ld %s %d\n", s[i].no, s[i].name, s[i].score); } //在结构体数组s中,查找最低分学生的记录,将其存入结构体数组t中 //形参n是结构体数组s中元素个数 //函数返回最低分的学生人数 int findMinlist(STU s[], STU t[], int n) { /* 补足函数实现 */ int i=0, j, k, m=0; for(i=0; i<n-1; i++) { k=i; for(j=i+1; j<n; j++) if(s[j].score < s[k].score) k=j; for(i=0; i<n; i++) if(s[i].score==s[k].score) t[m++]=s[i]; } return m; }
#include<stdio.h> #include<string.h> const int N = 10; typedef struct student { long int id; char name[20]; float ob; float sub; float sum; char level[10]; }STU; void input(STU s[], int n); void output(STU s[], int n); void process(STU s[], int n); int main() { STU stu[N]; printf("录入%d个考生信息: 准考证号,姓名,客观题得分(<=40),操作题得分 (<=60)\n", N); input(stu, N); printf("\n对考生信息进行处理: 计算总分,确定等级\n"); process(stu, N); printf("\n打印考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级 \n"); output(stu, N); return 0; } //录入考生信息:准考证号,姓名,客观题得分,操作题得分 void input(STU s[], int n) { int i=0; for(i=0; i<n; i++) scanf("%ld %s %f %f",&s[i].id,s[i].name,&s[i].ob,&s[i].sub); } //输出考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级 void output(STU s[], int n) { int i=0; for(i=0; i<n; i++) printf("\n%ld %10s %6.2f %6.2f %6.2f %10s\n",s[i].id, s[i].name, s[i].ob, s[i].sub, s[i].sum, s[i].level); } //对考生信息进行处理:计算总分,排序,确定等级 void process(STU s[], int n) { int i,j,k; STU temp; for(i=0; i<n; i++) { s[i].sum = s[i].ob + s[i].sub; /* if(s[i].sum<60) strcpy(s[i].level,"Fail"); else if(s[i].sum<70) strcpy(s[i].level,"Pass"); else if(s[i].sum<80) strcpy(s[i].level,"Medium"); else if(s[i].sum<90) strcpy(s[i].level,"Good"); else strcpy(s[i].level,"Excellent");*/ } for(i=0;i<n-1;i++) for(j=0;j<n-1-i;j++) if(s[j].sum < s[j+1].sum) { temp = s[j]; s[j] = s[j+1]; s[j+1] = temp; } for(i=0; i<n; i++) { if(i<=0.1*N) strcpy(s[i].level,"Excellent"); else if(i<=0.5*N) strcpy(s[i].level,"Pass"); else strcpy(s[i].level,"Fail"); } }
原文:https://www.cnblogs.com/dywer/p/14188296.html