力扣第四十二题 接雨水(困难难度,c语言附着解析)

请添加图片描述

代码如下请添加图片描述
这个代码是双指针算法,我参考了别人的解法,大致的思路如下,我们先使用两个指针,分别从数组开始和末尾开始遍历,并且我们使用了两个变量,分别记录当前我们遍历到的左边和右边遇到的最大高度。

这里为什么要进行height[l]小于或大于的判断再进行相加,根据木桶效应,我们需要知道哪一个高度是比较小的,如果是左边小,那么我们就以左边的高度来进行计算,反之亦然。

可能会有人疑惑,如果出现一直单调递增或递减的高度那会怎么样,如果是单调递增的高度,那我们的lmax就一直是当下我们所指向的数组的值,这时lmax-height[l++]就为0了,sum的值不会变,只有当不是单调递增或者递减时我们这时才会进行积水,sum这时才会相加。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值