【CSP:202012-2】期末预测之最佳阈值(Java)

题目链接

题目描述




求解思路

前缀和

  1. 根据题意我们可以得知:θ θ θ 值为 a[i].y 时的预测正确的次数等于 a[i].y 前面有多少个 result = 0 以及后面有多少个result = 1
  2. 定义Score类用来存储yresult,其中sum0表示a[1]a[i]有多少个result = 0sum1表示a[1]a[i]有多少个result = 1sum表示阈值取到a[i].y时预测正确的次数。然后写一个类的比较方法用于排序。
  3. 数组a[]用来存放每个同学的yresult
  4. 对数组进行排序,并求得sum0sum1
  5. 遍历数组,如果相邻的两个学生的安全指数相同,则不用处理直接得出sum值;否则利用前缀和计算出当前的sum,然后和max进行比较,相同的话取大的那个。

实现代码

java 复制代码
import java.util.Arrays;
import java.util.Scanner;

class Score {
    int y;
    int result;
    int sum0; // 记录a[1]------a[i] 有多少result = 0
    int sum1; // 记录a[1]------a[i] 有多少result = 1
    int sum; //a[i].y时的预测正确次数

    public int compare(Score score) {
        if (this.y > score.y) {
            return 1;
        } else if (this.y < score.y) {
            return -1;
        } else {
            return Integer.compare(this.result, score.result);
        }
    }
}

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int m = in.nextInt();
        Score[] a = new Score[m + 1];
        a[0] = new Score();
        for (int i = 1; i <= m; i++) {
            a[i] = new Score();
            a[i].y = in.nextInt();
            a[i].result = in.nextInt();
        }
        Arrays.sort(a, Score::compare);

        for (int i = 1; i <= m; i++) {
            if (a[i].result == 1) {
                a[i].sum0 = a[i - 1].sum0;
                a[i].sum1 = a[i - 1].sum1 + 1;
            } else {
                a[i].sum0 = a[i - 1].sum0 + 1;
                a[i].sum1 = a[i - 1].sum1;
            }
        }

        int ans = 0;
        int max = 0;
        for (int i = 1; i <= m; i++) {
            if (a[i].y == a[i - 1].y) {
                a[i].sum = a[i - 1].sum;
            } else {
                a[i].sum = a[i - 1].sum0 + a[m].sum1 - a[i - 1].sum1;
            }
            if (max <= a[i].sum) {
                max = a[i].sum;
                ans = a[i].y;
            }
        }
        System.out.println(ans);
    }
}
相关推荐
Stardep几秒前
算法入门20——二分查找算法——搜索插入位置
数据结构·算法·leetcode
qwerasda1238523 分钟前
青豆质量分类识别_YOLOv5_SPDConv_改进算法_目标检测_深度学习_计算机视觉
算法·计算机视觉·分类
CCPC不拿奖不改名7 分钟前
python基础面试编程题汇总+个人练习(入门+结构+函数+面向对象编程)--需要自取
开发语言·人工智能·python·学习·自然语言处理·面试·职场和发展
晓13138 分钟前
第二章:Redis常见命令与Java客户端
java·数据库·redis
老鼠只爱大米9 分钟前
LeetCode经典算法面试题 #141:环形链表(快慢指针、标记节点等多种方法详细解析)
算法·leetcode·链表·快慢指针·floyd算法·环形链表
invicinble9 分钟前
对于springboot
java·spring boot·后端
2501_9444241213 分钟前
Flutter for OpenHarmony游戏集合App实战之数字拼图滑动交换
android·开发语言·flutter·游戏·harmonyos
alanesnape15 分钟前
什么是字面量?代码中的常量表示方式解析
算法
偷星星的贼1119 分钟前
C++中的访问者模式实战
开发语言·c++·算法
莫问前路漫漫19 分钟前
JRE 核心实操指南:安装、配置、调优与问题排查
java·eclipse·tomcat·jre