关于力扣2025.10.4每日 11.盛最多雨水的容器

最主要的观察是 ,左右两个柱子中较矮的柱子决定了异侧柱子构成面积的上限。

故此时r便无需移动,l右移即可,反之同理。

python代码如下

python 复制代码
class Solution:
    def maxArea(self, height: List[int]) -> int:
        left = 0 
        n = len(height)
        right = n- 1
        ans  = 0 
        while left <= right:
            ans = max(ans,(right - left)*min(height[right],height[left]))
            if height[right] > height[left]:
                left += 1
            else:
                right -= 1
        return ans

c++代码如下

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        int l = 0 ;
        int n = height.size();
        int r = n - 1;
        int ans = 0;
        while (l <= r){
            ans = max(ans,(r-l)*(min(height[l],height[r])));
            if (height[l] > height[r]){
                r --;
            }else{
                l ++;
            }

        }
        return ans;
        
    }
};

学习了灵神的写法,用了一种

cpp 复制代码
height[left] < height[right] ? left++ : right--;

的写法。这种写法是一种三元运算符。当True选择前面 ,False选择后面。这样写能减少码量,使代码更加简洁,而功能与if else等效。

双指针写法的本质是排除必然不更优,而如何观察出必然不更优?

我的理解是先放指针,再尝试移动左右指针,若全部移动都不更优,那么更新就不更新同侧了。

时间复杂度O(n),空间复杂度O(1)

相关推荐
Omics Pro25 分钟前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
JAVA社区25 分钟前
Java高级全套教程(十)—— SpringCloudAlibaba超详细实战详解
java·开发语言·spring cloud·面试·职场和发展
voidmort33 分钟前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域1 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS2 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
小白兔奶糖ovo3 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll3 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程3 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan3 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h3 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash