【单调栈】【哈希】

单调栈

在python中,列表能实现栈的功能

stack.append(),stack.pop(),stack[-1]

1.最大温度

python 复制代码
class Solution:
    def dailyTemperatures(self, temperatures: List[int]) -> List[int]:
        stack = []
        n = len(temperatures)
        res = [0]*n

        for i in range(n):
            while stack and temperatures[i]>temperatures[ stack[-1]]:
                index = stack.pop()
                res[index] = i-index
            stack.append(i)

        return res

代码中注意两个部分,一个是while的条件,stack要不为空,用循环能够一次性找到多个匹配的下标,在每个循环的最后进行append

2.接雨水

这里用了跟上面一样的思路,重点在于不只弹出当前的,还要考虑左边的墙壁,遍历时while判断是否能作为右边的墙壁

算雨水总量的时候,是按照每个下标相加的

python 复制代码
class Solution:
    def trap(self, height: List[int]) -> int:
        res = 0
        n = len(height)
        stack = []
        for i in range(n):
            h = height[i]
            while stack and height[stack[-1]]<h:
                top = stack.pop()
                if not stack:
                    break
                left = stack[-1]
                w = i-left-1
                h0 = min(h,height[left])-height[top]
                res+=h0*w
            stack.append(i)
        return res

哈希

python 复制代码
class Solution:
    def firstMissingPositive(self, nums: List[int]) -> int:
        n = len(nums)
        for i in range(n):
            while 1<=nums[i]<=n and nums[nums[i]-1]!=nums[i]:
                index = nums[i]-1
                nums[i],nums[index] = nums[index],nums[i]

        for i in range(n):
            if nums[i]!=i+1:
                return i+1
        return n+1

注意代码中在交换时只处理了在0-n范围内的数,我们需要不断地交换,直到当前位置 i 放了一个不属于 [1, N] 范围的废数,或者放了一个已经归位的正确数,才能继续处理下一个位置 i+1

每个元素最多只会被交换一次到它正确的位置上,一旦归位,就不会再被移动,所以总的交换次数绝对不会超过N次,均摊下来是严格的 O(n)

(目前做了这几题,后续会更新)

相关推荐
扶摇接北海17614 小时前
洛谷:B4477 [语言月赛 202601] 考场安排
数据结构·c++·算法
爱丽_14 小时前
AQS 的 `state`:volatile + CAS 如何撑起原子性与可见性
java·前端·算法
2301_7887705514 小时前
OJ模拟5
数据结构·算法
羊小猪~~14 小时前
算法/力扣--字符串经典题目
c++·考研·算法·leetcode·职场和发展·哈希算法
攒了一袋星辰14 小时前
10万级用户数据日更与定向推送系统的可靠性设计
java·数据库·算法
nap-joker14 小时前
PIPE4:快速PPI预测器,用于综合的跨物种和跨物种相互作用组
算法·多模态生物医学数据分析·蛋白质互作网络
磊 子15 小时前
类和对象—>析构+拷贝+运算符重载
开发语言·c++·算法
人道领域15 小时前
LeetCode【刷题日记】:数组篇(1)含原理讲解
算法·leetcode·职场和发展
RTC老炮15 小时前
webrtc弱网-BBRv2算法原理
网络·算法·webrtc
RTC老炮15 小时前
webrtc弱网-BBRv1算法原理
网络·算法·webrtc