【题解】二分答案+贪心-2

文章目录

1.准时到达的列车最小时速

题目链接:准时到达的列车最小时速

代码如下:

cpp 复制代码
class Solution {
public:
    int minSpeedOnTime(vector<int>& dist, double hour) {
        int l=1, r = 1e7, n = dist.size();
        long long hr = llround(hour*100);
        if(hr <= (n-1) * 100) return -1;
        auto check = [&](int mid)->bool{
            long long t = 0;//前n-1段的时间
            for(int i=0; i<n-1; ++i){
                t += (dist[i] + mid - 1) / mid;
            }
            t *= mid;
            t += dist[n-1];
            return (t*100 <= hr*mid);
        };

        while(l < r){
            int mid = l + (r - l) / 2;
            if(check(mid)) r = mid;
            else l = mid + 1;
        }
        return l;
    }
};

2.每个小孩最多能分到多少糖果

题目链接:每个小孩最多能分到多少糖果

代码如下:

cpp 复制代码
class Solution {
public:
    int maximumCandies(vector<int>& candies, long long k) {
        int l = 1, r = *max_element(candies.begin(), candies.end());
        int n = candies.size();
        //检查每个小孩分到i个糖果是否可以满足要求
        auto check = [&](int mid)->bool{
            long long res = 0;
            for(int i=0; i<n; ++i){
                res += candies[i] / mid;
            }
            return res >= k;
        };
        while(l <= r){
            int mid = l + (r-l)/2;
            if(check(mid)) l = mid+1;
            else r = mid-1;
        }
        return l-1;
    }
};

3.完成旅途的最少时间

题目链接:完成旅途的最少时间

代码如下:

cpp 复制代码
class Solution {
public:
    long long minimumTime(vector<int>& time, int totalTrips) {
        long long l=1;
        long long r = (long long)totalTrips*(*max_element(time.begin(), time.end()));
        int n = time.size();
        auto check = [&](long long k)->bool{
            long long res = 0;
            for(int i=0; i<n; ++i){
                res += k/time[i];
            }
            return res >= totalTrips;
        };
        while(l < r) {
            long long mid = l + (r-l) / 2;
            if(check(mid)) r = mid;
            else l = mid+1;
        }
        return l;
    }
};

4.礼盒的最大甜蜜度

题目链接:礼盒的最大甜蜜度

代码如下:

cpp 复制代码
class Solution {
public:
    int maximumTastiness(vector<int>& price, int k) {
        int n = price.size();
        sort(price.begin(), price.end());
        int l=0, r=price[n-1] - price[0];
        //检查mid的甜蜜度是否可以被满足
        auto check = [&](int mid)->bool{
            int cnt = 0, pre = INT_MIN >> 1;
            for(int p : price){
                if(p - pre >= mid){
                    cnt++;
                    pre = p;
                }
            }
            return cnt >= k;
        };
        while(l < r){
            int mid = (l+r+1)/2;
            if(check(mid)) l=mid;
            else r=mid-1;
        }
        return l;
    }
};

这两篇的二分答案和贪心都是同一类型,可以放在一起做

相关推荐
信奥卷王42 分钟前
[GESP202503 五级] 原根判断
java·数据结构·算法
兮山与43 分钟前
算法4.0
算法
nju_spy44 分钟前
力扣每日一题(二)任务安排问题 + 区间变换问题 + 排列组合数学推式子
算法·leetcode·二分查找·贪心·排列组合·容斥原理·最大堆
初听于你1 小时前
高频面试题解析:算法到数据库全攻略
数据库·算法
翟天保Steven1 小时前
ITK-基于Mattes互信息的二维多模态配准算法
算法
代码对我眨眼睛1 小时前
226. 翻转二叉树 LeetCode 热题 HOT 100
算法·leetcode·职场和发展
黑色的山岗在沉睡2 小时前
LeetCode 494. 目标和
算法·leetcode·职场和发展
haoly19895 小时前
数据结构和算法篇-线性查找优化-移至开头策略
数据结构·算法·移至开头策略
学Linux的语莫8 小时前
机器学习数据处理
java·算法·机器学习
earthzhang20219 小时前
【1007】计算(a+b)×c的值
c语言·开发语言·数据结构·算法·青少年编程