【蓝桥杯】历届试题 成绩统计(省赛)Java

资源限制

        内存限制:256.0MB   C/C++时间限制:1.0s   Java时间限制:3.0s   Python时间限制:5.0s

问题描述

        小蓝给学生们组织了一场考试,卷面总分为 100 分,每个学生的得分都是一个 0 到 100 的整数。

如果得分至少是 60 分,则称为及格。如果得分至少为 85 分,则称为优秀。

请计算及格率和优秀率,用百分数表示,百分号前的部分四舍五入保留整数。

输入格式

        输入的第一行包含一个整数 n,表示考试人数。

        接下来 n 行,每行包含一个 0 至 100 的整数,表示一个学生的得分。

输出格式

        输出两行,每行一个百分数,分别表示及格率和优秀率。百分号前的部分四舍五入保留整数。

样例输入

7

80

92

56

74

88

100

样例输出

71%

43%

评测用例规模与约定

        对于50%的评测用例,1≤ n ≤100。

        对于所有评测用例,1<n≤10000。

思路与分析

        这道题感觉就是送分题,没有什么难度。非常基础的遍历过程中判断。属于是一眼就能出思路,一遍过的题。不过我也是试了两遍才OJ(真的是因为自己太蠢了orz)

        我犯了一个很低级的错误,导致我在思路正确的情况下好几次出现运行错误的情况。

        在检查代码后,发现问题出现在:" / " 运算符必须要求两边的数据类型要一致才可以,不然就会出现运行性错误。而我想求double类型的数字却直接用int类型的学生个数去当做被除数,因此在运行时出现了问题。改正之后就没问题了。

代码

import java.util.Scanner;

public class Main{
	public static void main(String[] args){
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int[] arr = new int[n];
		for(int i=0; i<arr.length; i++){
			arr[i] = sc.nextInt();
		}
		
		int jiGe=0;
		int youXiu=0;
		for(int i=0; i<arr.length; i++){
			if(arr[i]>=60){
				jiGe++;
			}			
			if(arr[i]>=85){
				youXiu++;
			}
		}

		double ans = n;
		String str1 = String.format("%.2f", jiGe/ans);
		String str2 = String.format("%.2f", youXiu/ans);
		
		String r1 = str1.substring(2);
		String r2 = str2.substring(2);
		System.out.println(r1+"%");
		System.out.println(r2+"%");
	}
}

小结

        这个故事告诉我们,一定不能忽视哪怕一点微小的错误,不然就会和该拿的分数失之交臂。若日后在面试题中遇到,更是会白白失去一个offer 共勉。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
青蛙跳杯子是蓝桥杯历届试题中的一道典型题目。题目要求模拟一个青蛙跳杯子的游戏,给定n个杯子和m次操作,每次操作可以选择一个杯子,并将其放置在当前位置前面或者后面的位置。最后,要求输出经过m次操作后,杯子从左到右的顺序。 下面是一个可能的Java代码实现: ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); // 杯子的数量 int m = scanner.nextInt(); // 操作的次数 int[] cups = new int[n]; // 初始化杯子的初始顺序 for (int i = 0; i < n; i++) { cups[i] = i+1; } // 执行m次操作 for (int i = 0; i < m; i++) { int index = scanner.nextInt(); // 选择的杯子的位置 int direction = scanner.nextInt(); // 移动的方向,1表示前面,2表示后面 // 将选择的杯子移动到指定位置 if (direction == 1) { for (int j = index-1; j > 0; j--) { int temp = cups[j]; cups[j] = cups[j-1]; cups[j-1] = temp; } } else if (direction == 2) { for (int j = index-1; j < n-1; j++) { int temp = cups[j]; cups[j] = cups[j+1]; cups[j+1] = temp; } } } // 输出最终的杯子顺序 for (int i = 0; i < n; i++) { System.out.print(cups[i] + " "); } } } ``` 该代码首先读取输入的杯子数量n和操作次数m,然后创建一个数组用来保存杯子的顺序。从1到n依次填充数组的初始顺序。接下来,执行m次操作,根据输入的位置和方向调整杯子的顺序,最后输出调整后的杯子顺序。 需要注意的是,该代码没有进行输入合法性的验证,实际应用中可能需要对输入进行适当的验证和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值