【优选算法】4----盛最多水的容器

开始有点上强度了铁子们,这道算法题也是可以说很难理解的~

想了好久才想明白~

---------------------------------------begin---------------------------------------

题目解析:

这一道题刚看题目,根本不知道在讲啥,但看到体积就明白了,求体积呗,这种题目不就是看谁在宽很大的同时,宽也很宽嘛,好像也不是很难~

讲解算法原理:

但是,要是使用暴力算法的话,每种情况都算一遍,那个时间复杂度高的很,所以有这么一种思路:同样也是定义双指针,一个指向0位置,一个指向最后位置的前一位,将第一个指针位置与后一个指针位置的值比较,小的一方++或--即可~

编写代码:

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

想要做做题的铁子也可以自己去试一试哦~

11. 盛最多水的容器 - 力扣(LeetCode)

-----------------------------------------end---------------------------------------

相关推荐
Frostnova丶6 分钟前
(10)LeetCode 560. 和为K的子数组
算法·leetcode·哈希算法
AI专业测评10 分钟前
2026年AI写作软件底层技术全景解析:长篇AI写网文的工程化实践与AI消痕算法基准测试
人工智能·算法·ai写作
biter down11 分钟前
C++ 设计不可被继承的类
java·开发语言·c++
Once_day13 分钟前
C++之《程序员自我修养》读书总结(12)
c++·编译与链接
浅念-15 分钟前
C++ 异常
开发语言·数据结构·数据库·c++·经验分享·笔记·学习
2401_8845632415 分钟前
高性能日志库C++实现
开发语言·c++·算法
葳_人生_蕤16 分钟前
hot100——226.翻转二叉树
算法
czxyvX20 分钟前
C++ - 基于多设计模式下的同步&异步日志系统
c++·设计模式
handler0120 分钟前
基础算法:BFS
开发语言·数据结构·c++·学习·算法·宽度优先
2401_8795034121 分钟前
C++中的状态模式实战
开发语言·c++·算法