【题解】二分答案+贪心-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;
    }
};

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

相关推荐
DoraBigHead29 分钟前
小哆啦解题记——两数失踪事件
前端·算法·面试
不太可爱的大白29 分钟前
Mysql分片:一致性哈希算法
数据库·mysql·算法·哈希算法
Tiandaren4 小时前
Selenium 4 教程:自动化 WebDriver 管理与 Cookie 提取 || 用于解决chromedriver版本不匹配问题
selenium·测试工具·算法·自动化
岁忧5 小时前
(LeetCode 面试经典 150 题 ) 11. 盛最多水的容器 (贪心+双指针)
java·c++·算法·leetcode·面试·go
chao_7896 小时前
二分查找篇——搜索旋转排序数组【LeetCode】两次二分查找
开发语言·数据结构·python·算法·leetcode
秋说7 小时前
【PTA数据结构 | C语言版】一元多项式求导
c语言·数据结构·算法
Maybyy8 小时前
力扣61.旋转链表
算法·leetcode·链表
卡卡卡卡罗特10 小时前
每日mysql
数据结构·算法
chao_78910 小时前
二分查找篇——搜索旋转排序数组【LeetCode】一次二分查找
数据结构·python·算法·leetcode·二分查找
lifallen11 小时前
Paimon 原子提交实现
java·大数据·数据结构·数据库·后端·算法