代码随想录算法训练营第二十八天 | 买卖股票的最佳实际、跳跃游戏、K次取反后最大化的数组和

买卖股票的最佳时机

这里可以得到当有利润就会卖出得到当前的股票,然后就是向后移动一位就可以了,判断卖出那天买入,后一天卖出会不会有收益,有收益就加上,因为同一天的买入和卖出相当于没有操作,因此逻辑性不变,详细代码如下所示:

python 复制代码
class Solution(object):
    def maxProfit(self, prices):
        """
        :type prices: List[int]
        :rtype: int
        """
        if len(prices) <=1:
            return 0
        count = 0
        pre = 0
        cur = 1
        while(pre<len(prices)-1):
            if prices[cur] - prices[pre] > 0:
                count += prices[cur] - prices[pre]
            pre+=1
            cur+=1
        return count

跳跃游戏

这里的思路是不断更新覆盖范围,看覆盖大小是不是一在更新,如果说覆盖范围到达最后的元素,那么符合,但是如果到了覆盖范围的最后一个还没有到达目的地,那么就不可行,直接返回False,详细代码如下所示:

python 复制代码
class Solution(object):
    def canJump(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        if len(nums)<=1:
            return True
        cover = 0
        index = 0
        while(index<=cover):
            cover = max(cover,nums[index]+index)
            if cover >= len(nums) - 1:
                return True
            index+=1
        return False

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

思路如下,我觉得还是比较好的:

1.​​预处理排序​​:先排序,再按策略翻转,避免重复计算最小值。

2.​​优先处理负数​​:先翻转所有负数(因为翻转负数能直接增加总和)。

3.​​剩余次数的数学处理​​:若剩余翻转次数 k 为奇数,只需翻转当前最小元素一次。

详细代码如下所示:

python 复制代码
class Solution(object):
    def largestSumAfterKNegations(self, nums, k):
        nums.sort()  # 排序,O(n log n)
        
        # 第一阶段:优先翻转所有负数
        for i in range(len(nums)):
            if nums[i] < 0 and k > 0:
                nums[i] = -nums[i]
                k -= 1
        
        # 第二阶段:若剩余k为奇数,翻转当前最小元素(可能是0)
        if k % 2 == 1:
            nums.sort()  # 重新排序找到最小值
            nums[0] = -nums[0]
        
        return sum(nums)  # 总和计算,O(n)
        

由于浏览器清空内存之后,原有代码会消失,因此此处链接放的是代码随想录的链接。

相关推荐
We་ct3 分钟前
深度剖析浏览器跨域问题
开发语言·前端·浏览器·跨域·cors·同源·浏览器跨域
风筝在晴天搁浅4 分钟前
字节高频题 小于n的最大数
算法
LabVIEW开发6 分钟前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
身如柳絮随风扬10 分钟前
多数据源切换实战:从业务场景到3种实现方案全解析
java·分布式·微服务
AI科技星12 分钟前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
skywalk816312 分钟前
在考虑双轨制,即在中文语法的基础上,加上数学公式的支持,这样像很多计算将更加简单方便,就像现在的小学数学课本里面一样,比如:定x=2*x + 1
开发语言
风筝在晴天搁浅14 分钟前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
小书房15 分钟前
Kotlin的by
android·开发语言·kotlin·委托·by
王老师青少年编程27 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
就叫飞六吧31 分钟前
QT写一个桌面程序exe并动态打包基本流程(c++)
开发语言·c++