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

网站开发语言在线检测软文一般发布在哪些平台

网站开发语言在线检测,软文一般发布在哪些平台,重庆有哪些做优化的公司,免费下ppt的网站有哪些目录 503.下一个更大元素II思路代码 42. 接雨水思路一 双指针思路二 单调栈代码 84.柱状图中最大的矩形思路一 双指针思路二 单调栈代码 503.下一个更大元素II Leetcode 思路 将数组乘2来遍历即可,就是加长版的每日温度。 但是处理起来会有细节,如果…

目录

  • 503.下一个更大元素II
    • 思路
    • 代码
  • 42. 接雨水
    • 思路一 双指针
    • 思路二 单调栈
    • 代码
  • 84.柱状图中最大的矩形
    • 思路一 双指针
    • 思路二 单调栈
    • 代码

503.下一个更大元素II

Leetcode
在这里插入图片描述

思路

将数组乘2来遍历即可,就是加长版的每日温度。

但是处理起来会有细节,如果只是单纯数组乘二,最后返回的时候还需要返回数组的一半大小,空间上不是很划算。

其实不需要扩大数组,只需要在遍历的时候,遍历长度为2*len(nums), 然后nums[i % len(nums)]即可。

代码

数组乘2

class Solution:def nextGreaterElements(self, nums: List[int]) -> List[int]:nums = nums + numsres = [-1] * len(nums)stack = [0]for i in range(1, len(nums)):if nums[i] <= nums[stack[-1]]:stack.append(i)else:while stack and nums[i] > nums[stack[-1]]:res[stack[-1]] = nums[i]stack.pop()stack.append(i)return res[:len(nums)//2]

遍历长度为2*len(nums)

class Solution:def nextGreaterElements(self, nums: List[int]) -> List[int]:dp = [-1] * len(nums)stack = []for i in range(len(nums)*2):while(len(stack) != 0 and nums[i%len(nums)] > nums[stack[-1]]):dp[stack[-1]] = nums[i%len(nums)]stack.pop()stack.append(i%len(nums))return dp

42. 接雨水

Leetcode
在这里插入图片描述

思路一 双指针

对于每一个柱子,用两个list分别存放左边最高的柱子,和右边最高的柱子。
在这里插入图片描述
列4 左侧最高的柱子是列3,高度为2(以下用lHeight表示)。

列4 右侧最高的柱子是列7,高度为3(以下用rHeight表示)。

列4 柱子的高度为1(以下用height表示)

那么列4的雨水高度为 列3和列7的高度最小值减列4高度,即: min(lHeight, rHeight) - height。

在有了rHeight和lHeight的情况下,遍历所以的柱子,求出雨水体积即可。

思路二 单调栈

单调栈按照行方向来计算雨水体积
在这里插入图片描述

代码

双指针

class Solution:def trap(self, height: List[int]) -> int:lHeight, rHeight = [0] * len(height), [0] * len(height)lHeight[0] = height[0]for i in range(1, len(lHeight)):# 计算左边最高柱子的时候连自己也包括lHeight[i] = max(lHeight[i - 1], height[i])rHeight[-1] = height[-1]for i in range(len(rHeight) - 2, -1, -1):rHeight[i] = max(rHeight[i + 1], height[i])res = 0for i in range(len(height)):res += (min(rHeight[i], lHeight[i]) - height[i])return res

单调栈

class Solution:def trap(self, height: List[int]) -> int:stack = [0]result = 0for i in range(1, len(height)):while stack and height[i] > height[stack[-1]]:mid_height = stack.pop()if stack:# 雨水高度是 min(凹槽左侧高度, 凹槽右侧高度) - 凹槽底部高度h = min(height[stack[-1]], height[i]) - height[mid_height]# 雨水宽度是 凹槽右侧的下标 - 凹槽左侧的下标 - 1w = i - stack[-1] - 1# 累计总雨水体积result += h * wstack.append(i)return result

84.柱状图中最大的矩形

Leetcode

在这里插入图片描述

思路一 双指针

对于每一个柱子,用两个list分别存放左边第一个小于该柱子的下标,和右边第一个小于该柱子的下标

在有两个list的基础上,遍历heights,

res += heights[i] * (minRightIndex[i] - minLeftIndex[i] - 1)

思路二 单调栈

思路来源:neetcode

代码

单调栈

class Solution:def largestRectangleArea(self, heights: List[int]) -> int:maxArea = 0stack = []for i, h in enumerate(heights):start = iwhile stack and stack[-1][1] > h:index, height = stack.pop()maxArea = max(maxArea, height * (i - index))start = indexstack.append([start, h])for i, h in stack:maxArea = max(maxArea, h * (len(heights) - i))return maxArea
http://www.yayakq.cn/news/307221/

相关文章:

  • 公司在线网站制作系统唐山网站建设互众动力
  • 免费看电视的网站湖南网站开发哪家好
  • 找建筑图纸的网站广州市网站建设 乾图信息科技
  • 婺源做网站设计网站建设莱芜
  • 微网站开发平台有哪些好的网站建设 洪塔
  • 中牟做网站qq电脑版官网入口
  • 张家界网站电子工程师
  • 车轮违章查询是什么网站开发拼多多网络营销方式
  • 中小企业建站平台厦门网页设计培训学校
  • 全球网站流量排名100岐山县住房和城市建设局网站
  • 企业网站设计与管理公司建设的网站属于无形资产吗
  • 交易平台网站模板做公司网站应准备什么材料
  • 网站建设遇到的问题及解决方法app设计规范
  • 自适应企业网站建设网站以后怎么让百度收录呢
  • 做问卷的网站有哪些杭州手机软件开发公司
  • 电商网站设计流程江西专业的企业网站建设公司
  • 免费门户网站搭建免费域名主机
  • 建设安全备案网站用dw做网站背景
  • 丰都网站建设价格保健品网站建设案例
  • 怎么样制作个网站提高工作效率总结心得
  • 网站指定关键词优化如何做虚拟币交易网站
  • 网站设计多少钱一个养老网站建设
  • 企业备案 网站服务内容百度seo排名优化系统
  • 如何自己做一个网址通化seo招聘
  • 网站建设费用不用摊销牛什么网站建设
  • html酒店网站模板网站建设准备
  • 网站建设推广销售人员天津网站建设wangzhii
  • 汉阳网站建设哪家便宜centos yum wordpress
  • 广东省农业农村厅网站长春建站价格
  • 六安品牌网站建设电话昆明网站建设开发制作