leetcode911

题目链接
leetcode911

class TopVotedCandidate {

    private int[] persons;
    private int[] times;
    private int length;
    int[] dp;
    int[] count;

    public TopVotedCandidate(int[] persons, int[] times) {
        this.persons = persons;
        this.times = times;
        this.length = times.length;
        dp = new int[length];
        count = new int[length];
        int max = 0;
        //求出dp[i],dp数组含义为当前下标为i,选举的人
        for (int i = 0; i < length; i++) {
            int person = persons[i];
            if(++count[person] >= max){
                dp[i] = person;
                max = count[person];
            }else{
                dp[i] = dp[i -1];
            }
        }
        System.out.println(Arrays.toString(dp));
    }

    /**
     * 二分查找找到左边界第一个小于等于t的index
     *
     * @param t
     * @return
     */
    public int q(int t) {
        int left = 0;
        int right = length - 1;
        while (left < right) {
            int mid = (right - left + 1) / 2 + left;
            if (times[mid] > t) {
                right = mid - 1;
            } else {
                left = mid;
            }
        }
        return dp[left];
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值