- #include <stdio.h>
- #include <stdlib.h>
- const int N=5;
- // 定义结构体类型 struct student, 并定义 STU 为其别名
- typedef struct student {
- 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);
- system("pause");
- return 0;
- }
- // 输入 n 个学生信息, 存放在结构体数组 s 中
- void input(STU s[], int n) {
- int i;
- for(i=0; i<n; i++)
- scanf("%ld %s %d", &s[i].no, s[i].name, &s[i].score);
- }
- // 输出结构体 s 中 n 个元素信息
- void output(STU s[], int 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) {
- STU temp;
- int min=s[0].score;
- int i,k;
- for(i=0;i<n;i++)
- if(s[i].score<min)
- min=s[i].score;
- for(i=0;i<n;i++)
- if(min==s[i].score)
- t[k++]=s[i];
- return k;
- }
- 2
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- const int N = 10;
- // 定义结构体类型 struct student, 并定义其别名为 STU
- typedef struct student {
- long int id;
- char name[20];
- float objective; /* 客观题得分 */
- float subjective; /* 操作题得分 */
- 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);
- system("pause");
- return 0;
- }
- // 录入考生信息: 准考证号, 姓名, 客观题得分, 操作题得分
- void input(STU s[], int n) {
- int i;
- for(i=0; i<n; i++)
- scanf("%ld %s %f %f",&s[i].id,&s[i].name,&s[i].objective,&s[i].subjective);
- }
- // 输出考生完整信息: 准考证号, 姓名, 客观题得分, 操作题得分, 总分, 等级
- void output(STU s[], int n) {
- int i;
- for(i=0; i<n; i++)
- printf("%ld %s %.2f %.2f %.2f %s\n",s[i].id,s[i].name,s[i].objective,s[i].subjective,s[i].sum,s[i].level);
- }
- // 对考生信息进行处理: 计算总分, 排序, 确定等级
- void process(STU s[], int n) {
- int i,j;
- STU temp;
- for(i=0;i<n;i++)
- s[i].sum= s[i].objective+s[i].subjective;
- for(i=0;i<n-1;i++)
- {
- for(j=0;j<n-i-1;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<=(n-1)*0.1)
- strcpy(s[i].level,"优秀");
- else if(i>(n-1)*0.1&&i<=(n-1)*0.5)
- strcpy(s[i].level,"合格");
- else
- strcpy(s[i].level,"不合格");
- }
- }
结论: 输入时修饰符不能用;;
冒泡排序要更多的练习;
strycpy 函数进行字符串复制
实验六
来源: http://www.bubuko.com/infodetail-3344567.html