第二十九天 第八章 贪心算法 part03 134. 加油站 135. 分发糖果 860.柠檬水找零 406.根据身高重建队列

news/2024/7/8 11:09:00 标签: 贪心算法, 算法, 数据结构, leetcode

134. 加油站  

两种情况讨论,(容量-消耗量)的累加和小于0时不可环绕一周,反之即可,同时如果当前容量-消耗量小于0,那么当前加油站也不是加油站,往后推一站,但是我们一定能找到一个加油站作为开始加油站环绕一圈。

class Solution {
public:
    int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
        int sum=0;
        int cur=0;
        int begin=0;
        for(int i=0;i<gas.size();i++){
           cur+=gas[i]-cost[i];
           sum+=gas[i]-cost[i];
           if(cur<0)
           {
            begin=i+1;
            cur=0;
           }
        }
        if(sum<0) return -1;
        return begin;
    }
};

135. 分发糖果  

一开始我只对相邻评分进行比较,两边一起考虑一定会顾此失彼。

其中要注意一个细节,在进行反向比较时,res[i-1]=max(res[i]+1,res[i-1]);我们比相邻数目多的同时,还要同原本自己的数量相比,取较大的一个值。

class Solution {
public:
    int candy(vector<int>& ratings) {
    vector<int> res(ratings.size(),1);
    //从前往后
    for(int i=1;i<ratings.size();i++){
        if(ratings[i-1]<ratings[i])  res[i]=res[i-1]+1;
    }   
    //从后往前
    for(int i=ratings.size()-1;i>=1;i--){
        if(ratings[i-1]>ratings[i])  res[i-1]=max(res[i]+1,res[i-1]);
    } 
    int sum=0;
    for(int i=0;i<res.size();i++){
        sum+=res[i];
    }  
    return sum; 
    }
};

860.柠檬水找零  

这题相对容易,但是要考虑到,如果顾客给的是20,我们要先考虑使用10+5的方式找零钱,而不是全使用5元的零钱。

class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
        int five = 0;
        int ten = 0;
        for(int i=0;i<bills.size();i++){
            if(bills[i]==5) 
            {
                five++;
            }
            if (bills[i]==10) 
            {
              if(five<=0) return false;
                ten++;
                five--;            
            }
           if (bills[i]==20) {
                if(ten>0 && five>0){
                ten--;
                five--;
                }
                else if(five>=3) 
                {
                five-=3;
                }
                
                else{
                return false;
                }
            }
        }
        return true;
    }
};

406.根据身高重建队列 

当一个题需要考虑两个维度时,我们要一个一个的考虑。

这题先考虑身高,再考虑位置。(这里需要讨论,如果我们先对位置排序,排序后确定不了最终的位置)

class Solution {
public:
    static bool campare(const vector<int> &a,const vector<int> &b){
        if(a[0]==b[0])  return a[1]<b[1];
        return a[0]>b[0];
    }
    vector<vector<int>> reconstructQueue(vector<vector<int>>& people) {
        vector<vector<int>> res;
        sort(people.begin(),people.end(),campare);
        for(int i=0;i<people.size();i++){
            int position=people[i][1];
            res.insert(res.begin()+position,people[i]);
        }
        return res;
    }
};


http://www.niftyadmin.cn/n/5537034.html

相关文章

字节跳动 AML 前端 一面

时长55mins 1. 自我介绍 1. 怎么接触的前端&#xff1f;学了多久&#xff1f; 1. 问项目 1. 为什么要做组件库&#xff1f; 1. 问到我的组件库和AntD之类的有什么区别&#xff0c;我说区别可能就是我的功能更少&#xff1f;hhhh 1. 设计一个组件的思路&#x…

LeetCode:3047. 求交集区域内的最大正方形面积(Java 枚举)

目录 3047. 求交集区域内的最大正方形面积 题目描述&#xff1a; 原理思路&#xff1a; 3047. 求交集区域内的最大正方形面积 题目描述&#xff1a; 在二维平面上存在 n 个矩形。给你两个下标从 0 开始的二维整数数组 bottomLeft 和 topRight&#xff0c;两个数组的大小都是…

(PADS学习)第三章:PCB基础知识 第四部分

第三章&#xff1a;PCB基础知识 五、PCB设计流程创建新设计流程布局设计电路分类通用器件布局器件布局注意事项时钟布局注意事项以太网布局注意事项光口布局注意事项滤波器件布局注意事项 布局拓扑设计点对点拓扑星型拓扑远端簇拓扑菊花链拓扑fly-by拓扑T型拓扑 叠层设计叠层设…

项目中上传功能过段时间就报错,解决方案

实际项目中&#xff0c;发现过段时间上传功能就报错&#xff0c;报错如下&#xff1a; 排查问题&#xff1a; 在服务器的 /tmp目录下发现并没有 /tomcat目录&#xff0c;也就验证了上面找不到这个文件的报错 那么这个临时给tomcat的上传目录怎么就没有了呢&#xff1f; 其实临…

银河麒麟高级服务器操作系统(通用)安装和编译指定的python3版本

银河麒麟高级服务器操作系统&#xff08;通用&#xff09;安装和编译指定的python3版本 一 系统环境二 安装python3.12.42.1 安装编译需要的依赖包2.2 下载官网目前最新的python源码包2.3 解压Python-3.12.4.tar.xz2.4 配置python-3.12.42.5 编译安装2.6 配置环境变量使其生效2…

实现Java Web应用的高性能负载均衡方案

实现Java Web应用的高性能负载均衡方案 大家好&#xff0c;我是微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在高并发的网络环境中&#xff0c;负载均衡是确保Web应用程序高性能和可靠性的关键策略之一。本文将探讨如何…

基于机器学习的零售商品销售数据预测系统

1 项目介绍 1.1 研究目的和意义 在电子商务日益繁荣的今天&#xff0c;精准预测商品销售数据成为商家提升运营效率、优化库存管理以及制定营销策略的关键。为此&#xff0c;开发了一个基于深度学习的商品销售数据预测系统&#xff0c;该系统利用Python编程语言与Django框架&a…

SwanLinkOS首批实现与HarmonyOS NEXT互联互通,软通动力子公司鸿湖万联助力鸿蒙生态统一互联

在刚刚落下帷幕的华为开发者大会2024上&#xff0c;伴随全场景智能操作系统HarmonyOS Next的盛大发布&#xff0c;作为基于OpenHarmony的同根同源系统生态&#xff0c;软通动力子公司鸿湖万联全域智能操作系统SwanLinkOS首批实现与HarmonyOS NEXT互联互通&#xff0c;率先攻克基…