算法训练营Day34(贪心算法)

1005.K次取反后最大化的数组和

1005. K 次取反后最大化的数组和 - 力扣(LeetCode)

秒了

java 复制代码
class Solution {
    public int largestSumAfterKNegations(int[] nums, int k) {
        Arrays.sort(nums);
        // -4 -3 -2 -1 5
        //-2 -2 0 2 5
        int last = -1;
        for(int i = 0;i<nums.length;i++){
            if(k==0) break;
            if(nums[i]<0){
                k--;
                nums[i]=-nums[i];
                continue;
            }
            if(nums[i]>=0){
                break;
            }
        }
        Arrays.sort(nums);
        if(k%2==1) nums[0]*=-1;
        // while(k-->0){
        //     nums[0] = - nums[0];
        // }

        int res = 0;
        for(int i = 0;i<nums.length;i++){
            res += nums[i];
        }
        return res;
    }
}

134. 加油站

134. 加油站 - 力扣(LeetCode)

这个图,就是假设curSum之前选择,有可能让这个curSum>0的话,

那么假设中间开始,

从最左到最右已经确定和小于0,假设从中间到最右,和大于0

那么总体小于0,那么区间1就是<0,,这个节点就不能用了。要更新。

所以**:一遇到累加和curSum<0.区间start==i+1就可以了,curSum重新归0,**

至于环的问题,total排除掉了没有结果的案例,也就是说,一定是有结果的

那么curSum之前没有结果,那么一定再后面,也就不需要环了

java 复制代码
class Solution {
    public int canCompleteCircuit(int[] gas, int[] cost) {
        int curSum = 0;
        int totalSum = 0;
        int start = 0;
        for(int i = 0;i<gas.length;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;
    }
}

135. 分发糖果

135. 分发糖果 - 力扣(LeetCode)
涉及到一个思想,就是想处理好一边再处理另一边,不要两边想着一起兼顾

第二次遍历的时候注意取最大值就可以了

java 复制代码
class Solution {
    public int candy(int[] ratings) {
        int [] nums = new int[ratings.length];
        for(int i = 0;i<nums.length;i++){
            if(i==0){
                nums[i]=1;
            }
            if(i>0&&ratings[i]>ratings[i-1]){
                nums[i]=nums[i-1]+1;
            }else{
                nums[i]=1;
            }
        }


        for(int i = ratings.length-2;i>=0;i--){
            if(ratings[i]>ratings[i+1]){
                nums[i] = Math.max(nums[i+1]+1,nums[i]);
            }else{
                // nums[i] = Math.max(1,nums[i]);
                //不要这个else也可以
            }
        }
        int res = 0;
        for(int i = 0;i<nums.length;i++){
            res+=nums[i];
        }
        return res;
    }
}
相关推荐
BothSavage14 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn14 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽16 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术2 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize2 天前
初识DFS 与 BFS:递归、队列与图遍历
算法