当前位置: 首页 > news >正文

代码随想录算法训练营第五十九天丨503. 下一个更大元素 II、42. 接雨水

503. 下一个更大元素 II

还是比较容易想的,扩展数组一倍即可。

class Solution:def nextGreaterElements(self, nums: List[int]) -> List[int]:extended_nums = nums * 2n = len(nums)mono = []res = [- 1] * nfor i, num in enumerate(extended_nums):while mono and extended_nums[mono[-1]] < num:if mono[-1] < n:res[mono[-1]] = nummono.pop()mono.append(i)return res

看了代码随想录的题解可以用%运算减少空间复杂度。

class Solution:def nextGreaterElements(self, nums: List[int]) -> List[int]:n = len(nums)mono = []res = [- 1] * nfor i in range(2 * n):while mono and nums[mono[-1]] < nums[i % n]:res[mono[-1]] = nums[i % n]mono.pop()mono.append(i % n)return res

42. 接雨水

手撕成功!

维护单调栈找右边第一个大的就是右边界,这时候把当前元素pop出来,如果栈不为空,说明左边也有比当前元素大的左边界,那么这俩边界之间就可以接雨水!!!

class Solution:def trap(self, height: List[int]) -> int:res = 0mono = []for right in range(len(height)):while mono and height[mono[-1]] < height[right]:cur = mono.pop()if mono:left = mono[-1]res += (right - left - 1) * (min(height[left], height[right]) - height[cur])mono.append(right)return res

信心巨大增强!!!

记录一下双指针暴力解法:

class Solution:def trap(self, height: List[int]) -> int:n = len(height)if n == 0:return 0ans = 0for i in range(1, n - 1):  # 对于每个位置max_left = max(height[:i])  # 找到左边的最大值max_right = max(height[i+1:])  # 找到右边的最大值# 计算当前位置能接的雨水量water = min(max_left, max_right) - height[i]if water > 0:ans += waterreturn ans

动态规划解法:

class Solution:def trap(self, height: List[int]) -> int:n = len(height)left_max = [0] * nright_max = [0] * nans = 0# 从左向右计算左侧最大高度left_max[0] = height[0]for i in range(1, n):left_max[i] = max(left_max[i - 1], height[i])# 从右向左计算右侧最大高度right_max[n - 1] = height[n - 1]for i in range(n - 2, -1, -1):right_max[i] = max(right_max[i + 1], height[i])# 计算每个位置能接的雨水量,并累加for i in range(n):ans += min(left_max[i], right_max[i]) - height[i]return ans

双指针究极优化:

class Solution:def trap(self, height: List[int]) -> int:left, right = 0, len(height) - 1  # 初始化左右指针left_max, right_max = height[left], height[right]  # 初始化左右最大值ans = 0while left < right:# 更新左侧最大值和右侧最大值left_max = max(left_max, height[left])right_max = max(right_max, height[right])# 根据当前的最大值,计算能接的雨水,并移动指针if left_max < right_max:ans += left_max - height[left]left += 1else:ans += right_max - height[right]right -= 1return ans

今日总结:

接雨水一刷AC,虽然花了1小时,成就感满满。

http://www.lryc.cn/news/316972.html

相关文章:

  • 全代码分享|R语言孟德尔随机化怎么做?TwoSampleMR包MR一套标准流程
  • 【AI视野·今日NLP 自然语言处理论文速览 第八十四期】Thu, 7 Mar 2024
  • 英伟达推出免训练,可生成连贯图片的文生图模型ConsiStory,生成角色一致性解决新方案
  • Jmeter 性能 —— 50TPS与秒杀分析!
  • 【前端】如何计算首屏及白屏时间
  • 重学SpringBoot3-ServletWebServerFactoryAutoConfiguration类
  • FileZillaClient连接被拒绝,无法连接
  • 每日一面——成员初始化列表、移动构造和拷贝构造
  • OPC UA 服务器的Web访问
  • docker 子网
  • QT使用RabbitMQ
  • 什么是R语言?什么是R包?-R语言001
  • Java17 --- springCloud之LoadBalancer
  • Mac(含M1) 使用 brew 安装nvm
  • 优秀的前端框架vue,原理剖析与实战技巧总结【干货满满】
  • <2024最新>ChatGPT逆向教程
  • C#编程技巧--2
  • 设计模式 代理模式
  • 关于学习时间
  • Github:Your browser did something unexpected. Please try again.
  • Django性能优化
  • 全网最详细Docker命令(分类总结)
  • 运维自动化之ANSIBLE
  • 算法训练day42leetcode01背包问题 416. 分割等和子集
  • VulnHub - DarkHole
  • 前端学习笔记 | WebAPIs(DOM+BOM)
  • 简易内存池(100%用例)C卷(JavaPythonC++Node.jsC语言)
  • 【算法与数据结构】队列的实现详解
  • GPT-3后的下一步:大型语言模型的未来方向
  • 基于机器学习的曲面拟合方法