如下图:
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+字解析》同样可分享给有需要的朋友,感兴趣的伙伴们可挑战一下自我,在不看答案解析的情况,测试测试自己的解题水平,这样也能达到事半功倍的效果!(好东西要大家一起看才香)
最后
这份《“java高分面试指南”-25分类227页1000+题50w+字解析》同样可分享给有需要的朋友,感兴趣的伙伴们可挑战一下自我,在不看答案解析的情况,测试测试自己的解题水平,这样也能达到事半功倍的效果!(好东西要大家一起看才香)
[外链图片转存中…(img-9UzghzOH-1719165123674)]
[外链图片转存中…(img-xt2zPSK9-1719165123675)]