1.6 log 134. 加油站,135. 分发糖果

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

这道题的贪心就是如果加油和耗油和为负,则直接从下一个加油站出发,因为前面的累加都只能为负,之前每次加油和耗油和都为正,对下一个加油和耗油都是正向增益,所以前面累加只能为负,只能选取下一个节点为出发节点,如果选到最后一个节点都不满足条件,则,必定是总耗油量大于加油量,返回-1

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

这是这道题的暴力解法,for循环适合从头到尾遍历,while循环适合环形遍历,代码巧妙的一点是利用取余实现数组的闭环循环。

135. 分发糖果

cpp 复制代码
class Solution {
public:
    int candy(vector<int>& ratings) {
        vector<int> sugar(ratings.size(),1);
        for(int i=1;i<ratings.size();i++){
            if(ratings[i]>ratings[i-1]) sugar[i]=sugar[i-1]+1;
        }
        for(int i=ratings.size()-2;i>=0;i--){
           if(ratings[i]>ratings[i+1]) sugar[i]=max(sugar[i],sugar[i+1]+1);
        }
        int count=0;
        for(int a:sugar){
            count+=a;
        }
        return count;
    } 
};

先判断从左到右,ratingi>ratingi-1的情况,再判断从右到左,ratingi>ratingi+1的情况,为什么不能从左到右再来一遍,因为ratingi>ratingi+1,从左到右不能影响下一次判断。

对于ratingi>ratingi-1&&ratingi>ratingi+1的情况,sugari要选取两次判断的最大值

相关推荐
无限码力13 分钟前
阿里算法岗 0530笔试真题 - 寻找满足条件的最优子序列
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试真题·阿里算法题
@小阿宝19 分钟前
机器人正向逆向运动学
算法·机器人
小雨下雨的雨21 分钟前
数独算法与求解器鸿蒙PC Electron框架完成深度解析
javascript·人工智能·算法·游戏·华为·electron·鸿蒙系统
HZ·湘怡23 分钟前
数据结构之排序算法 (1)--插入排序
c语言·数据结构·算法·排序算法
ouliten24 分钟前
[Triton笔记7]融合注意力 (Fused Attention)
人工智能·笔记·算法
开源Z24 分钟前
LeetCode 238 · 除自身以外数组的乘积:左右两遍扫描,不用除法
算法·leetcode
BAGAE35 分钟前
FEC-RS前向纠错编码理论及工程实施研究
c语言·c++·qt·算法·决策树·链表
酉鬼女又兒39 分钟前
零基础入门计算机网络:集线器与交换机区别、以太网交换机自学习转发流程及生成树协议STP全解析
服务器·网络·网络协议·tcp/ip·计算机网络·考研·职场和发展
兰令水39 分钟前
leecodecode【状态机DP】【2026.6.9打卡-java版本】
java·开发语言·算法
8Qi81 小时前
LeetCode 5:最长回文子串(Longest Palindromic Substring)—— 题解
算法·leetcode·职场和发展·动态规划