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

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

相关推荐
ALISHENGYA19 分钟前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战训练三)
数据结构·c++·算法·图论
我码玄黄2 小时前
正则表达式优化之算法和效率优化
前端·javascript·算法·正则表达式
Solitudefire3 小时前
蓝桥杯刷题——day9
算法·蓝桥杯
三万棵雪松4 小时前
1.系统学习-线性回归
算法·机器学习·回归·线性回归·监督学习
Easy数模4 小时前
基于LR/GNB/SVM/KNN/DT算法的鸢尾花分类和K-Means算法的聚类分析
算法·机器学习·支持向量机·分类·聚类
2401_858286114 小时前
117.【C语言】数据结构之排序(选择排序)
c语言·开发语言·数据结构·笔记·算法·排序算法
thesky1234565 小时前
活着就好20241226
学习·算法
td爆米花5 小时前
C#冒泡排序
数据结构·算法·排序算法
chenziang15 小时前
leetcode hot100
算法·leetcode·职场和发展
执着的小火车5 小时前
02-18.python入门基础一基础算法
数据结构·python·算法·排序算法