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

网站保障体系建设西安发布最新通知公告

网站保障体系建设,西安发布最新通知公告,wordpress登录400错误,摄影之友官网目录 题目来源 题目描述 示例 提示 题目解析 算法源码 题目来源 42. 接雨水 - 力扣#xff08;LeetCode#xff09; 题目描述 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图#xff0c;计算按此排列的柱子#xff0c;下雨之后能接多少雨水。 示例1 输入…目录 题目来源 题目描述 示例 提示 题目解析 算法源码 题目来源 42. 接雨水 - 力扣LeetCode 题目描述 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图计算按此排列的柱子下雨之后能接多少雨水。 示例1 输入height [0,1,0,2,1,0,1,3,2,1,2,1] 输出6 解释上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图在这种情况下可以接 6 个单位的雨水蓝色部分表示雨水。  示例2 输入height [4,2,0,3,2,5] 输出9 提示 n height.length1 n 2 * 10^40 height[i] 10^5题目解析 本题要计算所有柱子的储水量之和而这个和其实可以分解求解每一个柱子的储水量。 而一个柱子要想储存住水则必然在其左边有一根高柱在其右边也有一根高柱因为这样才能形成“凹”才能在中间的低柱子上存储住水。  并且中间低柱子的储水量取决于其左边“最高的”柱子和其右边“最高的”柱子的较矮者比如下图中 绿色箭头指向的低柱子的储水量取决于其左边最高柱子和其右边最高柱子的较矮者。 因此本题其实是要我们求解每一根柱子的 左边最高柱子高度右边最高柱子高度这个求解可以使用动态规划来做 我们假设第 i 根柱子的高度为 h[i]第 i 根柱子的左边最高柱子高度表示为left[ i ] 则第 i 根柱子的左边的最高柱子高度为 left[ i ] max( left[ i - 1 ], h[ i - 1 ] ) 什么含义呢 第 i 根柱子左边的最高柱子 要么是 第 i - 1 根柱子即h[ i - 1 ]要么是 第 i - 1 根柱子的左边的最高柱子即 left[ i - 1 ] 我们只要从左到右完成left数组的初始化即可。 同理可得 right[ i ] max( right[ i  1 ], h[ i 1 ] ) 此时需要从右往左完成right数组的初始化。 这样的话第 i 根柱子的储水量 取决于其左边最高柱子和其右边最高柱子的较矮者即min(left[ i ] right[ i ]) 第 i 根柱子的储水量val  min(left[ i ] right[ i ]) - h[ i ] 注意val最小为0不能为负数。因此最终第 i 根柱子的储水量计算公式为 max(0, min(left[ i ] right[ i ]) - h[i]) 我们只要累加每根柱子的储水量即为题解。 Java算法源码 class Solution {public int trap(int[] h) {int n h.length;// left[i] 表示 第 i 根柱子的左边的最高的柱子的高度int[] left new int[n];for(int i1; in; i) {// 第 i 根柱子左边最高的柱子要么是h[i-1]即第i-1根柱子的高度要么是left[i-1]即第i-1根柱子的左边的最高的柱子的高度left[i] Math.max(left[i-1], h[i-1]);}// right[i] 表示 第 i 根柱子的右边的最高的柱子的高度int[] right new int[n];for(int in-2; i0; i--) {// 第 i 根柱子右边最高的柱子要么是h[i1]即第i1根柱子的高度要么是right[i1]即第i1根柱子的右边的最高的柱子的高度right[i] Math.max(right[i1], h[i1]);}int ans 0;for(int i1; in-1; i) {// 第i根柱子最多能蓄水的量取决于其左边最高的柱子和右边最高的柱子的较矮的那个且较矮的那根柱子 - 第i根柱子的高度就是第i根柱子的蓄水量注意蓄水量最少为0ans Math.max(0, Math.min(left[i], right[i]) - h[i]);}return ans;} } JS算法源码 /*** param {number[]} height* return {number}*/ var trap function(h) {const n h.length// left[i] 表示 第 i 根柱子的左边的最高的柱子的高度const left new Array(n).fill(0)for(let i1; in; i) {// 第 i 根柱子左边最高的柱子要么是h[i-1]即第i-1根柱子的高度要么是left[i-1]即第i-1根柱子的左边的最高的柱子的高度left[i] Math.max(left[i-1], h[i-1])}// right[i] 表示 第 i 根柱子的右边的最高的柱子的高度const right new Array(n).fill(0)for(let in-2; i0; i--) {// 第 i 根柱子右边最高的柱子要么是h[i1]即第i1根柱子的高度要么是right[i1]即第i1根柱子的右边的最高的柱子的高度right[i] Math.max(right[i1], h[i1])}let ans 0for(let i1; in-1; i) {// 第i根柱子最多能蓄水的量取决于其左边最高的柱子和右边最高的柱子的较矮的那个且较矮的那根柱子 - 第i根柱子的高度就是第i根柱子的蓄水量注意蓄水量最少为0ans Math.max(0, Math.min(left[i], right[i]) - h[i])}return ans }; Python算法源码 class Solution(object):def trap(self, h)::type height: List[int]:rtype: intn len(h)# left[i] 表示 第 i 根柱子的左边的最高的柱子的高度left [0]*nfor i in range(1, n):# 第 i 根柱子左边最高的柱子要么是h[i-1]即第i-1根柱子的高度要么是left[i-1]即第i-1根柱子的左边的最高的柱子的高度left[i] max(left[i-1], h[i-1])# right[i] 表示 第 i 根柱子的右边的最高的柱子的高度right [0]*nfor i in range(n-2,0,-1):# 第 i 根柱子右边最高的柱子要么是h[i1]即第i1根柱子的高度要么是right[i1]即第i1根柱子的右边的最高的柱子的高度right[i] max(right[i1], h[i1])ans 0for i in range(1, n-1):# 第i根柱子最多能蓄水的量取决于其左边最高的柱子和右边最高的柱子的较矮的那个且较矮的那根柱子 - 第i根柱子的高度就是第i根柱子的蓄水量注意蓄水量最少为0ans max(0, min(left[i], right[i]) - h[i])return ans
http://www.hkea.cn/news/14487644/

相关文章:

  • 南宁建设网站制作营销网络怎么写
  • 网站建设报价兴田德润建行个人手机银行app下载
  • 东莞企业网站建设开发公司石家庄网站到首页排名
  • 网站上的小动画咋做hyein seo
  • 建设厅官方网站河南品牌营销方案
  • 网站怎么无法访问一站式服务大厅
  • 手机响应式网站开发模板之家网络营销企业网站推广
  • wordpress网站设计九江濂溪区
  • 淘客优惠券网站建设广州档案馆建设网站
  • 建个企业网站备案需要多长时间手机功能网站案例
  • 青岛网站设计做暧暧网站
  • 南通企业建站程序海珠电子商务网站建设
  • 有哪些网站可以做全景效果图房价走势最新消息2022
  • 揭阳城乡建设局网站巴中手机网站建设
  • 做网站用什么语言山西seo谷歌关键词优化工具
  • 自己制作网站房产网站建设机构
  • 自己创建网站403磁力王
  • 网站维护运营优化公司超轻粘土做动漫网站
  • 涿州网站建设公司有哪些个人网站如何做淘宝客
  • 网站建设与管理试题国外wordpress主题破解版
  • 自己可以做一个网站吗Wordpress福利资源模板
  • php 公司网站源码怎么停止网站
  • it公司做网站用什么软件重庆市证书查询官网
  • 广州专业的网站建设公司深圳ui设计公司
  • 网站建设上传与发布流程个人主题网站设计
  • 网站开发好学不淄博个人承接网站制作
  • 视频网站建设技术方案云南微网站搭建
  • 站长统计是什么意思微信小程序赚钱
  • ps 做ui比较好的网站有哪些贵港北京网站建设
  • 购物网站建设价格陕西建设厅继续教育网站