大一C语言程序题细节复盘

7-1 学生成绩录入及查询

分数 26

全屏浏览题目

切换布局

作者 zym

单位 广东外语外贸大学

学生成绩表中,一名学生的信息包含如下信息:
学号(11位)、姓名、数学成绩、英语成绩、程序设计成绩、物理成绩。

本题要求编写程序,录入N条学生的信息,并且按查询要求显示学生成绩等信息。

输入格式:

输入在第一行给出正整数N(N<=10);随后N行,每行按格式:

学号 姓名 数学成绩 英语成绩 程序设计成绩 物理成绩

给出一名学生的信息。
其中学号是11位数字;姓名是不超过10个字符、不包含空格的非空字符串;成绩是<=100的非负整数;

在学生信息输入完成后,给出要查询的姓名。

输出格式:

对查询的姓名的每一名学生,在一行中按照如下格式输出:

学号  姓名 数学成绩 英语成绩 程序设计成绩 物理成绩

如果有相同姓名的同学,输出全部同学的信息,每名同学一行;
如果要查询的学生不存在,则输出:

Not Found!

输入样例:

在这里给出一组输入。例如:

4
20201003012 LiWen 68 90 78 86
20201003012 HeHua 91 88 80 82
20201002121 WangFang 78 78 82 90
20201002112 ZhengYi 56 83 77 80
ZhengYi

输出样例:

在这里给出相应的输出。例如:

20201002112 ZhengYi 56 83 77 80

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

 

#include<stdio.h>
#include<string.h>

struct Student{
	char id[12];
	char name[11];
	int math;
	int english;
	int cpp;
	int science; 
};

int main(){
	int N;
	scanf("%d",&N);
	struct Student stu[N];
	for(int i = 0;i<N;i++){
		scanf("%s %s %d %d %d %d",
		stu[i].id,stu[i].name,
		&stu[i].math,&stu[i].english,
		&stu[i].cpp,&stu[i].science);
	}
	char find[11];
	scanf("%s",find);
	int found = 0;
	for(int i = 0;i<N;i++){
		if(strcmp(find,stu[i].name)==0){
		  printf("%s %s %d %d %d %d\n",
		  stu[i].id,
		  stu[i].name,
		  stu[i].math,
		  stu[i].english,
		  stu[i].cpp,
		  stu[i].science);
		  found++;
		}
	}
	if(found==0){
		printf("Not Found!\n");
	}
	
	return 0;
	
	
}

1. scanf中,有%s的不需要&

2.strcmp需要写上==0

3.有四门学科,要有四个%d

4.是\n!

5.id是要为【12】 


7-4 学生成绩排序

分数 27

全屏浏览题目

切换布局

作者 张泳

单位 浙大城市学院

假设学生的基本信息包括学号、姓名、三门课程成绩以及个人平均成绩,定义一个能够表示学生信息的结构类型。输入n(n<50)个学生的成绩信息,按照学生的个人平均分从高到低输出他们的信息。如果平均分相同,按输入的先后顺序排列。

输入格式:

输入一个正整数n(n<50),下面n行输入n个学生的信息,包括:学号、姓名、三门课程成绩(整数)。

输出格式:

输出从高到低排序后的学生信息,包括:学号、姓名、平均分(保留两位小数)。

输入样例:

3
101 Zhang 78 87 85
102 Wang 91 88 90
103 Li 75 90 84

输出样例:

102,Wang,89.67
101,Zhang,83.33
103,Li,83.00

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

 

#include<stdio.h>
#include<string.h>

struct Student{
	int id;
	char name[12];
	int A;
	int B;
	int C;
	float avg;
	};

int main(){
	int N;
	scanf("%d",&N);
	struct Student stu[N];
	for(int i =0;i<N;i++){
		scanf("%d %s %d %d %d",&stu[i].id,stu[i].name,&stu[i].A,&stu[i].B,&stu[i].C);
		stu[i].avg = (stu[i].A+stu[i].B+stu[i].C)/3.00;
	}
	struct Student temp;
	for(int i = 0;i<N-1;i++){
		for(int j = 0;j<N-i-1;j++){
			if(stu[j].avg<stu[j+1].avg){
				temp = stu[j+1];
				stu[j+1]=stu[j];
				stu[j]=temp;
			}
		}
	}
	for(int i =0;i<N;i++){
		printf("%d,%s,%.2f\n",stu[i].id,stu[i].name,stu[i].avg);
	}
	return 0;
	}

1.题目没有说明是char 默认id为int

2.冒泡排序中,外层是N-1,内层是N-i-1(有待考究)

3.要看清楚要求的printf是以空格形式输出,还是逗号形式输出。