代码随想录算法训练营DAY29第八章 贪心算法 part03

目录

[134. 加油站](#134. 加油站)

[135. 分发糖果](#135. 分发糖果)

[860. 柠檬水找零](#860. 柠檬水找零)

[406. 根据身高重建队列](#406. 根据身高重建队列)


134. 加油站

cpp 复制代码
class Solution {
public:
    int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
        int ans=0;
        int sum=0;
        int minsum=0;
        for(int i=0;i<gas.size();i++){
            sum+=gas[i]-cost[i];
            if(sum<minsum){
                minsum=sum;
                ans=i+1;
            }
        }
        if(sum<0)return -1;
        else return ans;
    }
};

135. 分发糖果

cpp 复制代码
class Solution {
public:
    int candy(vector<int>& ratings) {
        int n=ratings.size();
        int ans=n;
        vector<int> left(n);
        for(int i=0;i<n;i++){
            if(i&&ratings[i]>ratings[i-1])left[i]=left[i-1]+1;
            else left[i]=0;
        }
        int right=0;
        for(int i=n-1;i>=0;i--){
            if(i!=n-1&&ratings[i]>ratings[i+1])right++;
            else right=0;
            ans+=max(left[i],right);
        }
        return ans;
    }
};

860. 柠檬水找零

cpp 复制代码
class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
        unordered_map<int,int> map;
        for(int t:bills){
            if(t==5)map[5]++;
            else if(t==10){
                if(map[5])map[5]--;
                else return false;
                map[10]++;
            }
            else {
                if(map[10]&&map[5]){
                    map[10]--;
                    map[5]--;
                }
                else if(map[5]>=3){
                    map[5]-=3;
                }
                else return false;
                map[20]++;
            }
        }
        return true;
    }
};

406. 根据身高重建队列

cpp 复制代码
class Solution {
    static bool com(vector<int>& a,vector<int>& b){
        if(a[0]!=b[0])return a[0]>b[0];
        else return a[1]<b[1];
    }
public:
    vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {
        vector<vector<int>>ans;
        sort(people.begin(),people.end(),com);
        for(int i=0;i<people.size();i++){
            int k=people[i][1];
            ans.insert(ans.begin()+k,people[i]);
        }
        return ans;
    }
};
相关推荐
会编程的土豆7 分钟前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移9 分钟前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业30 分钟前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
空中海2 小时前
Kubernetes 入门基础与核心架构
贪心算法·架构·kubernetes
智者知已应修善业3 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.5483 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove4 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊4 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf5 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃5 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划