力扣(LeetCode) ——11.盛水最多的容器(C++)

题目:11.盛水最多的容器

给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0)(i, height[i])

找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。
说明: 你不能倾斜容器。

解题思路:

解法一: 使用暴力求解,通过两个循环来遍历查找最大值。时间复杂度为:O(n^2^)

解法二: 使用双指针来求解,遍历一遍数组即可找到最大值。时间复杂度为:O(n)

  1. left指向第一个位置,right指向最后一个位置;
  2. left大于right结束循环;
  3. 通过leftright的位置算出当前能够容纳水的值,用一个临时变量存储,用max函数取最大值;
  4. 再判断两个位置的值,当left下标位置的值小时++,right下标位置小时--;
  5. 重复循环第三步和第四步直到循环结束则求出了最大值。

最终代码:

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

赶紧动起手来吧!!!

点击下方即可跳转
11.盛水最多的容器

相关推荐
blasit16 小时前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
AI软著研究员16 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish16 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱17 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者1 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮1 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者1 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考1 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx2 天前
CART决策树基本原理
算法·机器学习
Wect2 天前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript