hot100-贪心

121. 买卖股票的最佳时机

121. 买卖股票的最佳时机 - 力扣(LeetCode)

python 复制代码
class Solution(object):
    def maxProfit(self, prices):
        """
        :type prices: List[int]
        :rtype: int
        """
        # 贪心思路:因为仅仅买卖一次,所以找到最低点和最高点即可【最低点要在最高点左侧】
        minf = float('inf')
        maxf = 0
        for p in prices:
            maxf = max(p-minf,maxf)
            minf = min(p,minf)
        return maxf

时间复杂度:O(n)

空间复杂度:O(1)

动态规划是解决股票问题的最佳思路【本题股票:仅允许买卖一次,无手续费】

python 复制代码
class Solution(object):
    def maxProfit(self, prices):
        """
        :type prices: List[int]
        :rtype: int
        """
        # 股票买卖,其实dp思路非常好理解
        # dp[i][0]  表示持有股票的最大收益
        # dp[i][1]  表示卖出股票的最大收益
        dp = [[0,0] for _ in prices]
        dp[0][0] = -prices[0]
        dp[0][1] = 0
        for i in range(1,len(prices)):
            dp[i][0] = max(dp[i-1][0],-prices[i])  # 要么继续前一天的持有,要么直接从今天开始买入
            dp[i][1] = max(dp[i-1][1],dp[i-1][0]+prices[i])  # 要么继续前一天的卖出,要么卖出前一天的持有
        return max(dp[-1][0],dp[-1][1])

时间复杂度:O(n)

空间复杂度:O(n)

55. 跳跃游戏

55. 跳跃游戏 - 力扣(LeetCode)

python 复制代码
class Solution(object):
    def canJump(self, nums):
        """
        :type nums: List[int]
        :rtype: bool
        """
        # 在每一个节点,跳跃的最大步数是元素值,元素值以内的步数都可以跳跃!
        # 所以我们只要保证所有点的最大值范围可以到达终点[并且中间不可以间断!]
        maxl = 0
        for i in range(len(nums)):
            if i>maxl:
                # 这意味着i位置在之前根本不可达!
                return False
            maxl = max(maxl,i+nums[i])
        return True

时间复杂度:O(n)

空间复杂度:O(1)

45. 跳跃游戏II

45. 跳跃游戏 II - 力扣(LeetCode)

python 复制代码
class Solution(object):
    def jump(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        # 当我们已经达到当前的最大覆盖度,那么接下来我们就需要真正的跳一次
        # 这样得到的就是最小跳跃次数
        n = len(nums)
        if n<=1:
            return 0  # 就一个点,不需要跳跃
        # 当前节点位置如果已经达到了过去的最大覆盖位置,那么就需要跳出去
        # 如果跳出去以后发现最大覆盖位置达到了终点,那么就结束
        curl = 0
        nextl = 0
        count = 0
        for i in range(n):
            nextl = max(nextl,i+nums[i])
            if i == curl:
                count += 1
                curl = nextl
                if nextl >= n-1:
                    break
        return count

时间复杂度:O(n)

空间复杂度:O(1)

763. 划分字母区间

763. 划分字母区间 - 力扣(LeetCode)

python 复制代码
class Solution(object):
    def partitionLabels(self, s):
        """
        :type s: str
        :rtype: List[int]
        """
        # 我们需要先存储每个元素的最远位置
        # 然后不断的更新最大所需要的右边界,当前位置等于右边界的时候,就可以做一次切断
        # 注意存储的是切断的这一段的长度
        # 然后更新左边界为当前位置+1
        d = {}
        for i in range(len(s)):
            d[s[i]] = i
        left = right = 0
        res = []
        for i in range(len(s)):
            right = max(right, d[s[i]])
            if i == right:
                res.append(right-left+1)
                left = i+1
        return res

时间复杂度:O(n)

空间复杂度:O(∣Σ∣) # 其实这里的∣Σ∣最大是26

相关推荐
夜天炫安全4 小时前
数据结构中所需的C语言基础
c语言·数据结构·算法
小陳参上5 小时前
用Python创建一个Discord聊天机器人
jvm·数据库·python
2301_789015625 小时前
DS进阶:AVL树
开发语言·数据结构·c++·算法
minstbe7 小时前
IC设计私有化AI助手实战:基于Docker+OpenCode+Ollama的数字前端综合增强方案(进阶版)
人工智能·python·语言模型·llama
zyq99101_18 小时前
优化二分查找:前缀和降复杂度
数据结构·python·蓝桥杯
qyzm8 小时前
天梯赛练习(3月13日)
开发语言·数据结构·python·算法·贪心算法
逆境不可逃8 小时前
LeetCode 热题 100 之 64. 最小路径和 5. 最长回文子串 1143. 最长公共子序列 72. 编辑距离
算法·leetcode·动态规划
CoderCodingNo9 小时前
【GESP】C++五级练习题 luogu-P1182 数列分段 Section II
开发语言·c++·算法
放下华子我只抽RuiKe59 小时前
机器学习全景指南-直觉篇——基于距离的 K-近邻 (KNN) 算法
人工智能·gpt·算法·机器学习·语言模型·chatgpt·ai编程
kisshuan123969 小时前
[特殊字符]【深度学习】DA3METRIC-LARGE单目深度估计算法详解
人工智能·深度学习·算法