C语言:实验3-7 统计学生成绩.2021-07-17

实验3-7 统计学生成绩 (15 分)

本题要求编写程序读入N个学生的百分制成绩,统计五分制成绩的分布。百分制成绩到五分制成绩的转换规则:

  • 大于等于90分为A;
  • 小于90且大于等于80为B;
  • 小于80且大于等于70为C;
  • 小于70且大于等于60为D;
  • 小于60为E。

输入格式:

输入在第一行中给出一个正整数N(≤1000),即学生人数;第二行中给出N个学生的百分制成绩,其间以空格分隔。

输出格式:

在一行中输出A、B、C、D、E对应的五分制成绩的人数分布,数字间以空格分隔,行末不得有多余空格。

输入样例:

7
77 54 92 73 60 65 69

输出样例:

1 0 2 3 1

参考答案: 

一些超出官网判断程序的内容:之所以选用了float类型没有使用int,因为float不仅可以接收整数也可以接收小数,可以避免输入非整数成绩带来的问题,同时也能接收更多的分数的个数,float的取值范围远大于int

#include<stdio.h>

int main ()
{
    float n,i,num,a=0,b=0,c=0,d=0,e=0;
    
    scanf("%f",&n);
    for(i=0;i<n;i++)
    {
        scanf("%f",&num);
        if(60>num) e+=1;
        else if(70>num&&60<=num) d+=1;
        else if(80>num&&70<=num) c+=1;
        else if(90>num&&80<=num) b+=1;
        else if(100>=num&&90<=num) a+=1;
    }
    printf("%.0f %.0f %.0f %.0f %.0f",a,b,c,d,e);
}

### 回答1: 好的,我会用文回答您的问题。 假设您输入的第一行为一个正整数n,表示学生人数,第二行为n个非负整数,表示这n位学生成绩,以空格分隔。 要将这些成绩进行处理,您可以将它们存储在一个列表,然后对列表进行排序或其他操作。具体的实现方法可以参考以下示例代码: ``` n = int(input()) # 输入学生人数 scores = list(map(int, input().split())) # 输入学生成绩并转换为整数类型的列表 scores.sort() # 对成绩进行排序 print(scores) # 输出排序后的成绩列表 ``` 上述代码首先将输入学生人数转换为整数类型的变量n,然后将输入成绩字符串转换为一个整数类型的列表,使用了`map()`和`split()`函数来实现。然后对成绩列表进行排序,最后输出排序后的成绩列表。 希望这个示例能够帮助您解决问题。 ### 回答2: 题目描述: 输入一个正整数 n,代表学生人数。接下来输入 n 个非负整数,表示每位学生成绩。 思路分析: 这道题是求学生们的平均成绩,因此,我们可以先用数组 arr 存储每个学生成绩,然后遍历数组,将所有成绩相加,再除以学生人数,得到平均成绩。 代码实现: num = int(input()) #读入学生人数 arr = list(map(int,input().split())) #将学生成绩读入一个数组 sum = 0 #定义总成绩 for i in range(num): sum += arr[i] #循环累加每个学生成绩 avg = sum / num #计算平均成绩 print('{:.2f}'.format(avg)) #打印输出平均成绩,保留两位小数 输入样例: 5 80 90 92 65 85 输出样例: 82.40 解释: 5 个学生的总成绩 sum = 412,平均成绩 avg = sum / 5 = 82.4,保留两位小数输出。 ### 回答3: 题目描述 输入在第一行给出正整数n,即学生人数。第二行给出n个非负整数,即这n位学生成绩,其间以空格分隔。 输出格式: 在一行输出最高分、最分的学生的学号及其成绩间用一个空格分隔。 输入样例: 3 100 90 87 输出样例: 1 100 3 87 解题思路 读入成绩后遍历找出最高分和最分,同时记录它们的下标。最后输出得到的下标及分数。 Python代码 n = int(input()) # 先读入学生数目 score = input().split() # 再读入学生成绩,用 split() 方法读入一行多个数据并分隔为相应的字符串元素列表 # 定义变量存储最高、最分数和对应下标 max_score, min_score = int(score[0]), int(score[0]) max_index, min_index = 0, 0 for i in range(n): if int(score[i]) > max_score: max_score = int(score[i]) max_index = i if int(score[i]) < min_score: min_score = int(score[i]) min_index = i # 输出结果为 max_index+1 和 min_index+1 print('{} {} {} {}'.format(max_index+1, max_score, min_index+1, min_score))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

用户的昵称

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值