Day34 贪心算法part03

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

python 复制代码
for num in nums:
            if k == 0:
                break
            if num < 0:
                num = -num
                k -= 1

这种直接遍历元素的赋值的话不改变数组里面的数!

得写成下面这个样子

python 复制代码
for i in range(len(nums)):
            if k == 0:
                break
            if nums[i] < 0:
                nums[i] = -nums[i]
                k -= 1
python 复制代码
A.sort(key=lambda x: abs(x), reverse=True)  # 第一步:按照绝对值降序排序数组A

这个按绝对值排序的没见过,学一下

加油站

暴力法

如何控制起点?That is brilliant

python 复制代码
rest > 0 && index != i

index = (index + 1) % len(gas)

贪心法

贪心算法完全想不到啊

python 复制代码
class Solution:
    def canCompleteCircuit(self, gas: List[int], cost: List[int]) -> int:
        if sum(gas) < sum(cost):
            return -1
        
        curSum = 0
        start = 0
        for i in range(len(cost)):
            curSum += gas[i] - cost[i]

            if curSum < 0:
                start = i + 1
                curSum = 0
        
        return start
        

Candy

要一边一边地比

不要同时比较两边

maya还要改变遍历顺序这谁能想得到

相关推荐
tudficdew14 小时前
类型安全容器设计
开发语言·c++·算法
naruto_lnq14 小时前
C++与Docker集成开发
开发语言·c++·算法
LYS_061814 小时前
寒假学习(7)(C语言7+模数电7)
c语言·学习·算法
砚边数影14 小时前
逻辑回归实战(二):Java + DL4J 实现模型,评估指标(准确率/召回率)计算
java·数据库·算法·机器学习·逻辑回归·金仓数据库
Cher ~14 小时前
【数据结构】hash表(unordered_map)
java·数据结构·c++·算法·哈希算法
一起养小猫14 小时前
Flutter for OpenHarmony 实战:食物生成算法与难度递增系统
算法·flutter
u01092727114 小时前
自定义类型转换机制
开发语言·c++·算法
hetao173383714 小时前
2026-01-27 hetao1733837 的刷题笔记
c++·笔记·算法
Tisfy14 小时前
LeetCode 3650.边反转的最小路径总成本:Dijkstra算法
算法·leetcode··dijkstra·题解·迪杰斯特拉
2401_8384725114 小时前
自定义操作符重载指南
开发语言·c++·算法