LeetCode 42

如下图:

class Solution {

public:

int trap(vector& height) {

int n = height.size();

if(n<=2) return 0;

int ans = 0;

for(int i=1;i<n-1;i++) {

int h1 = 0, h2 = 0;

for(int j=i;j>=0;j–) h1 = max(h1,height[j]);

for(int j=i;j<n;j++) h2 = max(h2,height[j]);

ans += min(h1,h2) - height[i];

}

return ans;

}

};

前缀(后缀)最大


类似于前缀和的思想,预处理一下。

时间复杂度: O ( n ) O(n) O(n)

class Solution {

public:

int trap(vector& height) {

int ans = 0,n = height.size();

if(n<=2) return 0;

vector lm(n),rm(n);

for(int i=0;i<n;i++){

if(i == 0) lm[i] = height[i];

else lm[i] = max(lm[i-1],height[i]);

}

for(int i=n-1;i>=0;i–){

if(i == n-1) rm[i] = height[i];

else rm[i] = max(rm[i+1],height[i]);

}

for(int i=1;i<n-1;i++){

ans += min(lm[i],rm[i])-height[i];

}

return ans;

}

};

双指针


上面是从左向右遍历来累加水柱。

如果考虑从左右两边来遍历的话,就可以这样解决。

记 leftmax, rightmax 分别为从左到右遍历、从右到左遍历的最大值,

而left、right 分别是从左到右、从右到左的指针,

这个时候 ,left的水柱对答案对贡献的为 m i n ( l e f t m a x , r i g h t m a x ) min(leftmax,rightmax) min(leftmax,rightmax);

但是此时leftmax的值已经求出,但是rightmax的值尚未求出,所以,如果此时leftmax小于等于rightmax的话,left的水柱对答案的贡献就知道了,然后更新leftmax,left右移。

反之亦然。

class Solution {

public:

int trap(vector& height) {

int ans = 0, n = height.size();

if(n<=2) return 0;

int l = 1 , r = n - 2;

int leftmax = height[0], rightmax = height[n-1];

while(l <= r){

if(leftmax <= rightmax){

ans += max(0,leftmax - height[l]);

leftmax = max(leftmax,height[l++]);

}else{

ans += max(0,rightmax - height[r]);

rightmax = max(rightmax,height[r–]);

}

}

return ans;

}

};

按行枚举

====================================================================

换一种分割思路,将“水”按行进行划分。如下图:

暴力法


时间复杂度: O ( m a x H ∗ n ) O(maxH*n) O(maxH∗n)

class Solution {

public:

int trap(vector& height) {

int ans = 0,n = height.size();

if(n<=2) return 0;

int maxH = *max_element(height.begin(),height.end());

for(int h = 0; h < maxH ; h++){

vector v;

for(int i=0;i<n;i++){

if(height[i]>h){

最后

这份《“java高分面试指南”-25分类227页1000+题50w+字解析》同样可分享给有需要的朋友,感兴趣的伙伴们可挑战一下自我,在不看答案解析的情况,测试测试自己的解题水平,这样也能达到事半功倍的效果!(好东西要大家一起看才香)

image

image

最后

这份《“java高分面试指南”-25分类227页1000+题50w+字解析》同样可分享给有需要的朋友,感兴趣的伙伴们可挑战一下自我,在不看答案解析的情况,测试测试自己的解题水平,这样也能达到事半功倍的效果!(好东西要大家一起看才香)

[外链图片转存中…(img-9UzghzOH-1719165123674)]

[外链图片转存中…(img-xt2zPSK9-1719165123675)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值