力扣(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.盛水最多的容器

相关推荐
深思慎考5 小时前
RabbitMQ 入门:基于 AMQP-CPP 的 C++ 实践指南与二次封装
开发语言·c++·分布式·rabbitmq·api
深思慎考5 小时前
Ubuntu 系统 RabbitMQ 安装指南与使用(含 C++ 客户端与 SSL 错误解决)
c++·ubuntu·rabbitmq·github·rabbitmqpp
沐浴露z5 小时前
【JVM】详解 垃圾回收
java·jvm·算法
代码欢乐豆5 小时前
编译原理机测客观题(7)优化和代码生成练习题
数据结构·算法·编译原理
草莓熊Lotso6 小时前
《C++ Web 自动化测试实战:常用函数全解析与场景化应用指南》
前端·c++·python·dubbo
东巴图6 小时前
分解如何利用c++修复小程序的BUG
开发语言·c++·bug
祁同伟.6 小时前
【C++】二叉搜索树(图码详解)
开发语言·数据结构·c++·容器·stl
恒者走天下6 小时前
AI智能网络检测项目(cpp c++项目)更新
开发语言·c++
Scc_hy6 小时前
强化学习_Paper_2000_Eligibility Traces for Off-Policy Policy Evaluation
人工智能·深度学习·算法·强化学习·rl