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

广州网站优化快速获取排名桂林楼盘网

广州网站优化快速获取排名,桂林楼盘网,怎样用云服务器做网站,商丘网站制作方案题目描述&#xff1a; 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 题目解答&#xff1a; class Solution {public int trap(int[] height) {int n height.length;int ans 0;if (n < 3)return…

题目描述:

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

题目解答:

class Solution {public int trap(int[] height) {int n = height.length;int ans = 0;if (n < 3)return ans;int left = 0, right = n - 1;int maxl = 0, maxr = 0;while (left < right) {maxl = Math.max(maxl, height[left]);maxr = Math.max(maxr, height[right]);ans += maxl < maxr ? maxl - height[left++] : maxr - height[right--];}return ans;}
}

题目思路:

双指针法在这段代码中的思想是通过两个指针分别从数组的两端向中间移动,同时维护左侧和右侧的最大高度。这种方法可以有效地减少计算量,因为在移动过程中,我们只关心较小的一侧的最大高度来计算雨水量。

  1. 初始化:

    • 初始化两个指针 leftright 分别指向数组的开头和末尾。
    • 初始化两个变量 maxlmaxr 分别表示左侧和右侧的最大高度,初始值为 0。
    int left = 0, right = n - 1;
    int maxl = 0, maxr = 0;
    
  2. 移动指针:

    • 在循环中,通过比较 maxlmaxr 的大小,选择较小的一侧。
    • 如果 maxl 小于 maxr,说明左侧最高柱子决定了当前位置的雨水高度,因此计算当前位置的雨水量,并将结果累加到 ans 中。
    • 根据选择的最小高度,移动对应的指针,向中间靠拢。
    while (left < right) {maxl = Math.max(maxl, height[left]);maxr = Math.max(maxr, height[right]);ans += maxl < maxr ? maxl - height[left++] : maxr - height[right--];
    }
    
  3. 核心思想:

    • 在每一步中,都选择较小的一侧,这样可以确保当前位置的雨水量是由较小的一侧的最大高度决定的。
    • 移动指针时,总是移动较小一侧的指针,这样可以确保在移动的过程中,雨水的计算仍然是以较小的一侧为基准。

通过这种双指针的思想,代码在一次遍历中完成了整个计算过程,而不需要额外的空间,从而实现了较好的时间复杂度。这种方法的关键在于巧妙地使用两个指针来同时遍历数组,减少了不必要的计算,提高了算法的效率。

其中使用了条件运算符(三元运算符),其形式为:

//result = condition ? expression_if_true : expression_if_false;
ans += maxl < maxr ? maxl - height[left++] : maxr - height[right--];

我们可以拆解它的含义:

  1. maxl < maxr 表示当前左侧的最大高度小于右侧的最大高度。
  2. 如果条件成立(true),则选择 maxl - height[left++],表示当前位置的雨水量是由左侧的最大高度决定的,然后将 left 指针向右移动。
  3. 如果条件不成立(false),则选择 maxr - height[right--],表示当前位置的雨水量是由右侧的最大高度决定的,然后将 right 指针向左移动。

整体来看,这行代码实现了双指针移动的逻辑,根据左右两侧的最大高度之间的关系来决定当前位置的雨水量。选择较小的一侧作为决定因素,计算雨水量,然后移动相应的指针,使问题规模减小,最终完成整个遍历过程。

这种表达方式是为了避免使用额外的 if-else 语句,通过条件运算符直接在一行中完成逻辑。这样的写法简洁而清晰,同时保持了代码的可读性。

http://www.yayakq.cn/news/555183/

相关文章:

  • html做调查问卷网站如何选择五屏网站建设
  • 网站设计制作程序网站建设与策划
  • 一个商务宣传怎么做网站合适263企业邮箱设置
  • 做家电网是什么网站品牌的网站建设一般多少钱
  • 苏州做网站专业的公司网站的广度
  • 做vip视频网站赚钱吗123手机浏览器
  • 佛山网站专业制作电商网站的二级怎么做
  • 为什么网站建设网站制作模板下载
  • 建一个网站要...拼多多网页设计尺寸
  • 网站创建免费用户网络营销推广软件服务商
  • 烟台网站建设找三硕科技府网站建设先进个人
  • 如何在app上做网站哪有做奇石网站
  • 建设网站是公司资产wordpress 公众号
  • 网站搭建源码刷东西网站建设
  • 桂林北站是高铁站吗企业门户网站属于什么层
  • 长沙本土网站建设公司长沙优化网站
  • 怎么做网页插件关键词优化排名系统
  • 什么网站做产品销售做的好四维码制作网站
  • 淘宝网站建设可行性分析报告公司职务名称大全
  • 物流管理网站建设望谟网站建设
  • 网站模板 手机网站后台添加内容网页不显示
  • 郑州加盟网站建设网站开发的摘要
  • h5建设网站东莞网站竞价推广
  • php+mysql 2012也买酒商城网站源码怎么查网站是谁建的
  • 学校网站报价方案静态网站开发项目实验报告
  • 网站淘宝推广怎么做百度如何网站
  • 网站建设注册密码咋弄类似饿了么的网站怎么做
  • 怎么样做好网站运营广州增城网站建设
  • 商业网站开发需求网站建设与管理考察报告
  • 东台网站建设服务商凡客建站快车