【数据结构和算法】盛最多水的容器

其他系列文章导航

Java基础合集
数据结构与算法合集

设计模式合集

多线程合集

分布式合集

ES合集


文章目录

其他系列文章导航

文章目录

前言

一、题目描述

二、题解

2.1 方法一:暴力枚举

2.2 方法二:双指针

三、代码

3.1 方法一:暴力枚举

3.2 方法二:双指针

四、复杂度分析

4.1 方法一:暴力枚举

4.2 方法二:双指针


前言

这是力扣的 11 题,难度为中等,解题方案有很多种,本文讲解我认为最奇妙的两种。


一、题目描述

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

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

返回容器可以储存的最大水量。

说明:你不能倾斜容器。

示例 1:

输入:[1,8,6,2,5,4,8,3,7]
输出:49 
解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。

示例 2:

输入:height = [1,1]
输出:1

提示:

  • n == height.length
  • 2 <= n <= 105
  • 0 <= height[i] <= 104

二、题解

2.1 方法一:暴力枚举

思路与算法:

顾名思义,暴力枚举,设定两个循环。

  • 第一个循环,循环左挡板。
  • 第二个循环,循环右挡板。

每次计算 area ,存入 maxArea 。

面积公式:S(i,j)=min(h[ i ] ,h[ j ])×(j−i)

2.2 方法二:双指针

思路与算法:

在每个状态下,无论长板或短板向中间收窄一格,都会导致水槽 底边宽度 −1​ 变短:

  • 若向内 移动短板 ,水槽的短板 min(h[i],h[j]) 可能变大,因此下个水槽的面积 可能增大 。
  • 若向内 移动长板 ,水槽的短板 min(h[i],h[j])​ 不变或变小,因此下个水槽的面积 一定变小 。

因此,初始化双指针分列水槽左右两端,循环每轮将短板向内移动一格,并更新面积最大值,直到两指针相遇时跳出;即可获得最大面积。

算法流程

  1. 初始化: 双指针 i , j 分列水槽左右两端;
  2. 循环收窄: 直至双指针相遇时跳出;
  3. 更新面积最大值 res ;
  4. 选定两板高度中的短板,向中间收窄一格;
  5. 返回值: 返回面积最大值 res 即可;

三、代码

3.1 方法一:暴力枚举

Java版本:

class Solution {public int maxArea(int[] height) {int n = height.length, max = 0, area;for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {area = Math.min(height[i], height[j]) * (j - i);if (area > max) max = area;}}return max;}
}

C++版本:

class Solution {
public:int maxArea(vector<int>& height) {int n = height.size(), maxArea = 0;for (int i = 0; i < n; i++) {for (int j = i + 1; j < n; j++) {int area = min(height[i], height[j]) * (j - i);maxArea = max(maxArea, area);}}return maxArea;}
};

Python版本:

class Solution:def maxArea(self, height: List[int]) -> int:n = len(height)max_area = 0for i in range(n):for j in range(i+1, n):area = min(height[i], height[j]) * (j - i)max_area = max(max_area, area)return max_area

3.2 方法二:双指针

Java版本(易懂版):

class Solution {public int maxArea(int[] height) {int i = 0, j = height.length - 1, max = 0, area;while (i != j) {area = Math.min(height[i], height[j]) * (j - i);if (area > max) max = area;if (height[i] < height[j]) {i++;} else {j--;}}return max;}
}

Java版本(优化版): 

class Solution {public int maxArea(int[] height) {int i = 0, j = height.length - 1, max = 0;while (i != j) {max = height[i] < height[j] ?Math.max(max, (j - i) * height[i++]) : Math.max(max, (j - i) * height[j--]);}return max;}
}

C++版本:

class Solution {
public:int maxArea(vector<int>& height) {int i = 0, j = height.size() - 1, max_area = 0;while (i < j) {max_area = max(max_area, (j - i) * min(height[i], height[j]));if (height[i] < height[j]) {i++;} else {j--;}}return max_area;}
};

Python版本:

class Solution:def maxArea(self, height: List[int]) -> int:i, j, max_area = 0, len(height) - 1, 0while i < j:max_area = max(max_area, (j - i) * min(height[i], height[j]))if height[i] < height[j]:i += 1else:j -= 1return max_area

四、复杂度分析

4.1 方法一:暴力枚举

  • 时间复杂度 O(N^2) 
  • 空间复杂度 O(1)

4.2 方法二:双指针

  • 时间复杂度 O(N) : 双指针遍历一次底边宽度 N​​ 。
  • 空间复杂度 O(1) : 变量 i , j , res 使用常数额外空间。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/283645.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【VScode】设置语言为中文

1、下载安装好vscode 2、此时可看到页面为英文&#xff0c;为方便使用可切换为中文 3、键盘按下 ctrlshiftP 4、在输入框内输入configure display language 5、选择中文&#xff0c;restart即可&#xff08;首次会有install安装过程&#xff0c;等待安装成功后重启即可&am…

ISCTF(a)

where_is_the_flag 答案应该被分成了三份了 蚁剑连接看看 第一个 第二个 第三个&#xff0c;在www下 Yunxi{0797d78c-0cb2-4cfb-87e6-f9c102f716f3} 命令执行 POST : 1 system ( tac flag.php ); 1 system ( tac /flag2 ); 1 system ( env ); 1z_Ssql 使用万能密码 后…

初识Dubbo学习,一文掌握Dubbo基础知识文集(3)

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

Android Stuido报错处理

仅用作报错记录。防止以后出项问题不知如何解决。 报错1 Dependency‘androidx.annotation:xx requires libraries and applications … 需要修改CompileSDKVersion更改为报错中提示的版本 打开项目build.gradle文件&#xff0c;将compileSdk和targetSdk修改为报错中提示的版…

Vue 详细教程

Vue实战 1. Vue 引言 渐进式 JavaScript 框架 --摘自官网 官网地址&#xff1a;Vue.js - 渐进式 JavaScript 框架 | Vue.js # 渐进式 1. 易用 html css javascript 2. 高效 开发前端页面 非常高效 3. 灵活 开发灵活 多样性 # 总结 Vue 是一个javascript 框架 js 简化页面js操作…

超结MOS/低压MOS在5G基站电源上的应用-REASUNOS瑞森半导体

一、前言 5G基站是5G网络的核心设备&#xff0c;实现有线通信网络与无线终端之间的无线信号传输&#xff0c;5G基站主要分为宏基站和小基站。5G基站由于通信设备功耗大&#xff0c;采用由电源插座、交直流配电、防雷器、整流模块和监控模块组成的电气柜。所以顾名思义&#xf…

【兔子王赠书第12期】赠ChatGPT中文范例的自然语言处理入门书

文章目录 写在前面自然语言处理图书推荐图书简介编辑推荐 推荐理由粉丝福利写在后面 写在前面 小伙伴们好久不见吖&#xff0c;本期博主给大家推荐一本入门自然语言处理的经典图书&#xff0c;一起来看看吧~ 自然语言处理 自然语言处理&#xff08;Natural Language Process…

程序人生15年人生感悟

计算机程序员并不是一件什么高大上的职业。而仅仅是一份普通的工作。就像医生能治病救人&#xff0c;我们能治蓝屏救程序&#xff0c;我们都在为这个世界默默的做出自己的贡献。刻意或无意宣扬某个职业高大上&#xff0c;其实质是对其它行业从业者的不公平。但是有些人却常常这…

低代码开发平台的优势及应用场景分析

文章目录 低代码是什么&#xff1f;低代码起源低代码分类低代码的能力低代码的需求市场需要专业开发者需要数字化转型需要 低代码的趋势如何快速入门低代码开发低代码应用领域 低代码是什么&#xff1f; 低代码&#xff08;Low-code&#xff09;是著名研究机构Forrester于2014…

人工智能中的核心概念

1 概述 人工智能英文缩写为AI&#xff0c;是一种由人制造出来的机器&#xff0c;该机器可以模仿人的思想和行为&#xff0c;从而体现出一种智能的反应。 人工智能的产业链分为基础层、技术层、应用层三个层次。 基础层包括&#xff1a;芯片、大数据、算法系统、网络等多项基础…

快速排序(一)

目录 快速排序&#xff08;hoare版本&#xff09; 初级实现 问题改进 中级实现 时空复杂度 高级实现 三数取中 快速排序&#xff08;hoare版本&#xff09; 历史背景&#xff1a;快速排序是Hoare于1962年提出的一种基于二叉树思想的交换排序方法 基本思想&#xff1a…

备忘录怎么分享 分享备忘录的方法

在现代社会&#xff0c;分享已经成为我们生活中必不可少的一部分。无论是工作中的合作&#xff0c;还是生活中的点滴&#xff0c;我们都需要与他人分享信息。而备忘录作为我们常用的信息记录工具&#xff0c;其分享功能也显得尤为重要。 那么&#xff0c;如何快速地分享备忘录…