算法D33 | 贪心算法3 | 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果

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

本题简单一些,估计大家不用想着贪心 ,用自己直觉也会有思路。

代码随想录

Python:

python 复制代码
class Solution:
    def largestSumAfterKNegations(self, nums: List[int], k: int) -> int:
        nums.sort(key=lambda x: abs(x), reverse=True) # 关键:按绝对值降序排列
        for i in range(len(nums)):
            if nums[i]<0 and k>0:
                nums[i] = -nums[i]
                k -= 1
        if k%2==1: 
            nums[-1] *= -1
        return sum(nums)

C++:

cpp 复制代码
class Solution {
static bool cmp(int a, int b) {
    return abs(a) > abs(b);
}
public:    
    int largestSumAfterKNegations(vector<int>& nums, int k) {
        sort(nums.begin(), nums.end(), cmp); //注意:这里cmp是static method
        for (int i=0; i<nums.size(); i++) {
            if (nums[i]<0 && k>0) {
                nums[i] *= -1;
                k--;
            }
        }
        if (k%2==1) nums[nums.size()-1] *= -1;
        int ans = 0;
        for (int a:nums) ans+=a;
        return ans;
    }
};

134. 加油站

本题有点难度,不太好想,推荐大家熟悉一下方法二

代码随想录

Python:

情况三是比较难想到的,从后向前看如何覆盖cum_sum of net gas.

  • 情况三:如果累加的最小值是负数,汽车就要从非0节点出发,从后向前,看哪个节点能把这个负数填平,能把这个负数填平的节点就是出发节点。
python 复制代码
class Solution:
    def canCompleteCircuit(self, gas: List[int], cost: List[int]) -> int:
        cum_sum = 0
        min_net = float('inf')
        for i in range(len(gas)):
            cum_sum += gas[i] - cost[i]
            if cum_sum < min_net:
                min_net = cum_sum
        if cum_sum < 0: return -1
        if min_net > 0: return 0
        for i in reversed(range(len(gas))):
            min_net += gas[i] - cost[i]
            if min_net >= 0:
                return i
        return -1

C++:

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

135. 分发糖果

本题涉及到一个思想,就是想处理好一边再处理另一边,不要两边想着一起兼顾,后面还会有题目用到这个思路

代码随想录

Python:

cpp 复制代码
class Solution:
    def candy(self, ratings: List[int]) -> int:
        n = len(ratings)
        if n == 1: return 1
        ans = [1] * n 
        for i in range(1, n): # 从前往后
            if ratings[i] > ratings[i-1]:
                ans[i] = ans[i-1] + 1
        for i in reversed(range(n-1)): # 从后往前
            if ratings[i] > ratings[i+1]:
                ans[i] = max(ans[i], ans[i+1]+1)
        return sum(ans)

C++:

cpp 复制代码
class Solution {
public:
    int candy(vector<int>& ratings) {
        if (ratings.size()==1) return 1;
        vector<int> candyVec(ratings.size(), 1);    
        for (int i=1; i<ratings.size(); i++) {
            if (ratings[i] > ratings[i-1]) candyVec[i] = candyVec[i-1] + 1;
        }
        for (int i=ratings.size()-2; i>=0; i--) {
            if (ratings[i] > ratings[i+1]) candyVec[i] = max(candyVec[i], candyVec[i+1]+1);
        }
        int ans = 0;
        for (int c: candyVec) ans += c;
        return ans;
    }
};
相关推荐
love530love13 小时前
【实践指南】Windows 下 Stable Diffusion WebUI 与 ComfyUI 模型库“完美共存”指南
人工智能·windows·python·stable diffusion·大模型·aigc·comfyui
Aerelin13 小时前
爬虫图片采集(自动化)
开发语言·前端·javascript·爬虫·python·html
roman_日积跬步-终至千里13 小时前
【模式识别与机器学习(4)】主要算法与技术(中篇:概率统计与回归方法)之线性回归模型
算法·机器学习
曲幽13 小时前
Flask路由参数处理:GET与POST的实战指南
python·web·route·form·get·post
小李小李快乐不已13 小时前
图论理论基础(2)
java·开发语言·c++·算法·图论
yddddddy13 小时前
Django在项目中的作用
数据库·python·django
CNRio13 小时前
第五章-综合实战:从零开始部署一个Flask应用
后端·python·容器·flask
子午13 小时前
【水果识别系统】Python+TensorFlow+Django+人工智能+深度学习+卷积神经网络算法
人工智能·python·深度学习
点云SLAM13 小时前
四元数 (Quaternion)微分-单位四元数 q(t) 的导数详细推导(10)
算法·计算机视觉·机器人·slam·imu·四元数·单位四元数求导
B站计算机毕业设计之家13 小时前
电商数据实战:python京东商品爬取与可视化系统 大数据 Hadoop spark 优秀项目(源码)✅
大数据·hadoop·python·机器学习·spark·echarts·推荐算法