蓝桥杯摆烂第三天

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

请计算这次考试的最高分、最低分和平均分。

输入描述

输入的第一行包含一个整数 n (1≤n≤104),表示考试人数。

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

输出描述

输出三行。

第一行包含一个整数,表示最高分。

第二行包含一个整数,表示最低分。

第三行包含一个实数,四舍五入保留正好两位小数,表示平均分。

复制代码
import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        //在此输入您的代码...
      int n  =scan.nextInt();
        int max=0;
        int min=100;
      int sum=0;
        for(int i=0;i<n;i++){
          int j=scan.nextInt();
          if(max<j){
            max=j;
          }
          if(min>j){
            min=j;
          }
          sum+=j;

        }
         double avg=(double)sum/n;
         System.out.println(max);
         System.out.println(min);
         System.out.printf("%.2f",avg);
        scan.close();
    }
}

思路:用min表示范围0-100,max<j就交换,min>j就交换,注意两位小数表达方式同c语言,平均数用强转double或者定义输入n为double类型。


小蓝准备用 256MB 的内存空间开一个数组,数组的每个元素都是 32位 二进制整数,如果不考虑程序占用的空间和维护内存需要的辅助空间,请问256MB 的空间可以存储多少个 32 位二进制整数?

复制代码
import java.util.Scanner;
// 1:无需package
// 2: 类名必须Main, 不可修改

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        //在此输入您的代码...
     
        System.out.println(Math.abs(256*1024*1024*8/32));
        scan.close();
    }
}

思路:简单计算题

1MB = 1024KB 1KB = 1024字节(byte) 1字节 = 8位(bits),注意数值太大会变成负数,使用Math.abs()表示绝对值.

相关推荐
学习3人组几秒前
柔性排产时序算法+中间过程+阶段目标 细化表格
算法·mes
he___H8 分钟前
算法快与慢--哈希+双指针
算法·leetcode·哈希算法
呃呃本9 分钟前
算法题(回溯)
算法
刀法如飞20 分钟前
Rust数组去重的20种实现方式,AI时代用不同思路解决问题
人工智能·算法·ai编程
yxc_inspire24 分钟前
25年CCPC福建邀请赛补题
学习·算法
Raink老师26 分钟前
用100道题拿下你的算法面试(链表篇-4):合并 K 个有序链表
算法·链表·面试
Liangwei Lin1 小时前
LeetCode 20. 有效的括号
算法
IronMurphy1 小时前
【算法四十四】322. 零钱兑换
算法
凯瑟琳.奥古斯特1 小时前
力扣2760 C++滑动窗口解法
数据结构·c++·算法·leetcode·职场和发展
Hesionberger1 小时前
LeetCode96: 不同的二叉搜索树(多解)
算法