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

巴中商城网站建设淮南做网站的

巴中商城网站建设,淮南做网站的,找客户的十大方法,咸阳学校网站建设多少钱给定 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] …

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

示例 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.length
1 <= n <= 2 ∗ 10 4 2 * 10^4 2104
0 <= height[i] <= 10 5 10^5 105


知识点:
数组、双指针


解:
首先,这是一题双指针的题目(当然也有其他方法:dp、单调栈)。根据双指针的常用方法,设置两个指针pipj分别指向数组的两端,并且左指针向右移动,右指针向左移动

观察图示,所接雨水的量,取决于当前遍历的这个元素左右两侧的更小的那个高度,因此用两个变量lMaxrMax分别存储左边的最大值、右边的最大值。当左/右指针指向一个新的元素时,要判断当前元素的高度是否比对应的lMax/rMax大,若是,则取当前元素的高度,否则保留lMaxrMax的值。因此得到:

lMax = Math.max(height[pi], lMax);
rMax = Math.max(height[pj], rMax);

这里,只要左侧最大高度lMax比右侧最大高度rMax大,就处理左边;否则,处理右边(实际上这是考虑最高的柱子在数组的中间,而不是两侧)。
当处理左侧/右侧时:
①首先,计算当前遍历的元素所对应的面积,公式为(max-height[p])*1,其中,max对应lMaxrMax,p对应pipj。这里面积×1是因为题目指明了每个柱子的宽度为1。
②然后,加计算出来的面积加入结果变量sum中。

最后,只要不满足左指针<右指针,就退出循环,并返回最终的变量sum。

对于测试样例1,有以下分析过程:
测试样例1分析过程
对于测试样例2,有以下分析过程:
测试样例2分析过程
时间复杂度: O ( n ) O(n) O(n),最多遍历一次整个数组的所有元素
空间复杂度: O ( 1 ) O(1) O(1)

class Solution {public int trap(int[] height) {int sum = 0;int n = height.length;//定义双指针int pi = 0;int pj = n - 1;//定义变量存储左右最大的heightint lMax = 0;int rMax = 0;//只要左指针<右指针,就继续循环while (pi < pj) {//获取当前遍历的lMax、rMax,是当前遍历的高度与变量的值的更大的那个lMax = Math.max(height[pi], lMax);rMax = Math.max(height[pj], rMax);//对于两个max中更小的数,用对应的指针(lMax更小,当前用pi;rMax更小,当前用pj)if (lMax < rMax) {//计算当前凹槽所接雨水量int cur = (lMax - height[pi]) * 1;sum += cur;//更新左指针(向右移动)pi++;} else {//计算当前凹槽所接雨水量int cur = (rMax - height[pj]) * 1;sum += cur;//更新右指针(向左移动)pj--;}}return sum;}
}
http://www.dtcms.com/wzjs/549941.html

相关文章:

  • 工程建设公司网站wordpress 页面制作
  • 网站同时做竞价和优化可以昆明做网站的公司有哪些
  • 网站建设找单网站建设报价方案
  • 珠海网站制作哪家好中国商务网官网
  • 网站程序如何上传新公司网站怎么做推广
  • 一级a做爰片免费网站 小说门户网站开发过程视频
  • 自己建的网站有乱码广州天华建筑设计有限公司
  • 门户网站 开发注意网站建设流程要多少钱
  • 网网站开发天津如何做seo优化服务
  • 兰州做网站的公司有哪些社区电商平台排行榜
  • 教学网站模板东莞建网站公司动
  • 网站建设不包括哪个阶段seo的网站建设
  • 郓城网站建设价格东莞推广就莞用服务平台
  • 设计网站界面微信浏览为网站的缓存怎么清理
  • 吉林省舒兰市建设银行网站创建网站的公司
  • 物流网站模板免费大气集团企业网站模板
  • 做文案的网站如何验证网站
  • 品牌网站建设小8蝌蚪有谁做分销网站
  • 做代理记账网站南京网站建设丁豆褒
  • 企业域名多少钱优化seo技术
  • WordPress建站收费深圳市创同盟科技有限公司
  • 辽宁网站建设推广哪家便宜邵阳多用户商城网站建设
  • 免费推广引流平台汕头网站快速优化排名
  • 网站策划内容制作网站监控推荐
  • 做外贸自己做网站么百度seo站长工具
  • 定制网站开发app费用做网站的开发语言
  • 网站栏目划分免费logo设计网站推荐
  • 永久免费网站建商城建设信用网站的目的
  • 网站开发与管理课程怎么样制作一个公众号
  • 源码搭建网站seo工作内容有哪些