【LeetCode最详尽解答】11-盛最多水的容器 Container-With-Most-Water
欢迎收藏Star我的Machine Learning Blog:https://github.com/purepisces/Wenqing-Machine_Learning_Blog。如果收藏star, 有问题可以随时与我交流, 谢谢大家!
链接:
- 11-盛最多水的容器
直觉
这个问题可以通过可视化图表来理解和解决。
通过图形化这个问题,可以简化解决过程。我们可以使用双指针技术来解决它。起初,左指针设置在数组的起点,右指针设置在数组的终点。目标是找到最大的可能面积,这个面积受指针指向的较短高度的限制。面积可以通过公式 min(height[left], height[right]) * (right - left)
计算。容器的高度受较短的两个高度之一限制。
为了最大化面积,我们应该移动指向较短高度的指针。这是因为移动指向较高高度的指针不会有助于找到更大的面积,因为容器的高度仍然会受较短高度的限制。具体来说,新高度将是 min(height[left], height[new_right])
,它将小于或等于之前的较短高度,并且间隔距离也会缩小。因此,如果左指针指向较短高度,我们将其向右移动。相反,如果右指针指向较短高度,我们将其向左移动。
方法
- 初始化两个指针:左指针在数组起点,右指针在数组终点。
- 初始化一个变量
res
来存储最大面积。 - 使用公式
res = max(res, min(height[left], height[right]) * (right - left))
来计算面积并更新res
。 - 移动指向较短高度的指针以尝试找到更大的面积。
- 设置提前停止条件:设
h
为数组中的最大高度。如果(right - left) * h
小于res
,则意味着不可能找到更大的面积,因此我们可以跳出循环。
复杂度
- 时间复杂度:
O ( n ) O(n) O(n)- 我们只用两个指针遍历数组一次,时间复杂度为线性。
- 空间复杂度:
O ( 1 ) O(1) O(1)- 无论输入大小如何,我们只使用了常量空间。
代码
class Solution(object):def maxArea(self, height):""":type height: List[int]:rtype: int"""l = 0r = len(height) -1h = max(height)res = 0while l < r:if (r-l) * h <= res:breakres = max(res, min(height[l],height[r]) * (r-l))if height[l] <= height[r]:l+=1elif height[l] > height[r]:r-=1return res
相关文章:
![](https://img-blog.csdnimg.cn/direct/c24793cff9b74e27a03a5c1dd8d84f1b.png)
【LeetCode最详尽解答】11-盛最多水的容器 Container-With-Most-Water
欢迎收藏Star我的Machine Learning Blog:https://github.com/purepisces/Wenqing-Machine_Learning_Blog。如果收藏star, 有问题可以随时与我交流, 谢谢大家! 链接: 11-盛最多水的容器 直觉 这个问题可以通过可视化图表来理解和解决。 通过图形化这个…...
![](https://img-blog.csdnimg.cn/direct/471972f7201d462ab30f0a2a379ff23e.png)
redis 缓存jwt令牌设置更新时间 BUG修复
大家好,今天我又又又来了,hhhhh。 上文中 我们永redis缓存了token 但是我们发现了 一个bug ,redis中缓存的token 是单用户才能实现的。 就是 我 redis中存储的键 名 为token 值 是jwt令牌 ,但是如果 用户a 登录 之后 创建一个…...
![](https://www.ngui.cc/images/no-images.jpg)
nginx精准禁止特定国家或者地区IP访问
1、安装依赖 dnf -y install gcc-c libtool gd-devel pcre pcre-devel openssl openssl-devel zlib zlib-devel libmaxminddb-devel pcre-devel zlib-devel gcc gcc-c make git2、获取NGINX安装包并安装 wget https://nginx.org/download/nginx-1.26.1.tar.gz git clone http…...
![](https://img-blog.csdnimg.cn/direct/7149692326c044ed8ceecf86b77f1352.png)
单片机课设-基于单片机的电子时钟设计(仿真+代码+报告)
基于单片机的电子时钟设计 前言一、课设任务是什么?二、系统总体方案硬件设计2.1 系统硬件总体设计2.2 键盘电路设计2.3 DS1302实时时钟芯片电路设计2.4 复位电路2.5 LCD电路设计 三、软件设计3.1 主程序流程图3.2 主要程序设计代码3.3 修改时间函数3.4 扫描键盘函数 四、仿真…...
![](https://img-blog.csdnimg.cn/direct/27900581796c48eeb783270f3531a444.png)
.net 6 api 修改URL为小写
我们创建的api项目,url是[Route(“[controller]”)],类似这样子定义的。我们的controller命名是大写字母开头的,显示在url很明显不是很好看(url不区分大小写)。转换方式: var builder WebApplication.Crea…...
![](https://img-blog.csdnimg.cn/img_convert/0193039c4efe71b78d487cde5549a095.png#pic_center)
Windows电脑部署Jellyfin服务端并进行远程访问配置详细教程
文章目录 前言1. Jellyfin服务网站搭建1.1 Jellyfin下载和安装1.2 Jellyfin网页测试 2.本地网页发布2.1 cpolar的安装和注册2.2 Cpolar云端设置2.3 Cpolar本地设置 3.公网访问测试4. 结语 前言 本文主要分享如何使用Windows电脑本地部署Jellyfin影音服务并结合cpolar内网穿透工…...
![](https://www.ngui.cc/images/no-images.jpg)
rsync同步目录脚本
假设有两台服务器的示例 IP 地址为: Server A: 192.168.1.100Server B: 192.168.1.200 现在来解释如何使用这个脚本进行服务器之间文件夹内容的同步,保留路径和服务器信息的抽象化。 1. 脚本文件位置和权限 假设脚本文件位于 /root/script.sh&#x…...
![](https://img-blog.csdnimg.cn/direct/d6354872df994bd4aac2f26254835f30.png)
LeetCode 6. Z 字形变换
LeetCode 6. Z 字形变换 将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。 比如输入字符串为 “PAYPALISHIRING” 行数为 3 时,排列如下: 之后,你的输出需要从左往右逐行读取,产生…...
![](https://img-blog.csdnimg.cn/direct/91929a3db0c0426eb6b4e093007dd4eb.png)
RTC实时时钟
一、Unix时间戳 1、Unix 时间戳 (1)Unix 时间戳(Unix Timestamp)定义为从UTC/GMT的1970年1月1日0时0分0秒开始所经过的秒数,不考虑闰秒 (2)时间戳存储在一个秒计数器中,秒计数器为…...
![](https://www.ngui.cc/images/no-images.jpg)
WHAT - React 学习系列(一)
官方文档 If you have a lot of HTML to port to JSX, you can use an online converter. You’ll get two things from useState: the current state (count), and the function that lets you update it (setCount). To “remember” things, components use state.To mak…...
![](https://img-blog.csdnimg.cn/direct/43ea9a045a044dd69cbea3cc6ebd7fa0.png)
代理模式(静态代理/动态代理)
代理模式(Proxy Pattern) 一 定义 为其他对象提供一种代理,以控制对这个对象的访问。 代理对象在客户端和目标对象之间起到了中介作用,起到保护或增强目标对象的作用。 属于结构型设计模式。 代理模式分为静态代理和动态代理。…...
![](https://img-blog.csdnimg.cn/img_convert/51beceda88eaf8dc7942bc8aa05982d9.png)
Word2Vec基本实践
系列文章目录 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 例如:第一章 Python 机器学习入门之pandas的使用 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目…...
![](https://img-blog.csdnimg.cn/direct/344135e7cb974469ae859366e4e2bf37.png)
IIS配置網站登錄驗證,禁止匿名登陸
需要維護一個以前的舊系統,這個系統在內網運行,需要抓取電腦的登陸賬號,作為權限管理的一部分因此需要在IIS配置一下...
![](https://img-blog.csdnimg.cn/direct/b2d7b5c39261455c9491ca30f1431385.png)
抖音矩阵系统搭建,AI剪辑短视频,一键管理矩阵账号
目录 前言: 一、抖音矩阵系统有哪些功能? 1.AI智能文案 2.多平台账号授权 3.多种剪辑模式 4. 矩阵一键发布,智能发布 5.抖音爆店码功能 6.私信实时互动 7.去水印及外链 二、抖音矩阵系统可以解决哪些问题? 总结ÿ…...
![](https://img-blog.csdnimg.cn/direct/ce56741fcaf94e3192fee4d3190fcf4d.jpeg)
山东大学软件学院创新项目实训开发日志——收尾篇
山东大学软件学院创新项目实训开发日志——收尾篇 项目名称:ModuFusion Visionary:实现跨模态文本与视觉的相关推荐 -------项目目标: 本项目旨在开发一款跨模态交互式应用,用户可以上传图片或视频,并使用文本、点、…...
![](https://www.ngui.cc/images/no-images.jpg)
vue2.7支持组合式API,但是对应的vue-router3并不支持useRoute、useRouter。
最近在做一个项目,因为目标用户浏览器版本并不确定,可能会有较旧版本,于是采用vue2.7而不是vue3,最近一年多使用vue3开发的项目都碰到了很多chrome 63-73版本,而对应UI 库 element plus又问题很多。 为了不碰到这些问…...
![](https://img-blog.csdnimg.cn/img_convert/a892f6f400721f08b40c4ebebf3886fa.png)
摊位纠纷演变肢体冲突,倒赔了500:残疾夫妇与摊主谁之过?
在一个小商贩密集的街区,一起由摊位纠纷引发的肢体冲突事件在当地社区和网络上引起了热议。涉事双方为一名摊主和一对残疾夫妇,他们的争执源自对一个摊位的使用权。本是口头上的争吵,却由于双方情绪激动,迅速升级为肢体冲突&#…...
![](https://img-blog.csdnimg.cn/img_convert/8cd716831d1d7c6eda4ea4c7d4d43540.png)
深入理解和实现Windows进程间通信(消息队列)
常见的进程间通信方法 常见的进程间通信方法有: 管道(Pipe)消息队列共享内存信号量套接字 下面,我们将详细介绍消息队列的原理以及具体实现。 什么是消息队列? Windows操作系统使用消息机制来促进应用程序与操作系…...
![](https://www.ngui.cc/images/no-images.jpg)
Web网页前端教程免费:引领您踏入编程的奇幻世界
Web网页前端教程免费:引领您踏入编程的奇幻世界 在当今数字化时代,Web前端技术已成为互联网发展的重要驱动力。想要踏入这一领域,掌握相关技能,却苦于找不到合适的教程?别担心,本文将为您带来一份免费的We…...
![](https://img-blog.csdnimg.cn/direct/ab8b88cb3f29496f81661ad60de957c5.jpeg)
北斗短报文终端在应急消防通信场景中的应用
在应对自然灾害和紧急情况时,北斗三号短报文终端以其全球覆盖、实时通信和精准定位的能力,成为应急消防通信的得力助手。它不仅能够在地面通信中断的极端条件下保障信息传递的畅通,还能提供精准的位置信息,为救援行动提供有力支持…...
![](https://www.ngui.cc/images/no-images.jpg)
Java跳动爱心代码
1.计算爱心曲线上的点的公式 计算爱心曲线上的点的公式通常基于参数方程。以下是两种常见的参数方程表示方法,用于绘制爱心曲线: 1.1基于 (x, y) 坐标的参数方程 x a * (2 * cos(θ) - sin(θ))^3 y a * (2 * sin(θ) - cos(θ))^3 其中ÿ…...
![](https://www.ngui.cc/images/no-images.jpg)
Swift Combine — Operators(常用Filtering类操作符介绍)
目录 filter(_: )tryFilter(_: )compactMap(_: )tryCompactMap(_: )removeDuplicates()first(where:)last(where:) Combine中对 Publisher的值进行操作的方法称为 Operator(操作符)。 Combine中的 Operator通常会生成一个 Publisher,该 …...
![](https://img-blog.csdnimg.cn/direct/64796c996fac4d67b143a62d5fea4c37.png)
Windows11+CUDA12.0+RTX4090如何配置安装Tensorflow2-GPU环境?
1 引言 电脑配置 Windows 11 cuda 12.0 RTX4090 由于tensorflow2官网已经不支持cuda11以上的版本了,配置cuda和tensorflow可以通过以下步骤配置实现。 2 步骤 (1)创建conda环境并安装cuda和cudnn,以及安装tensorflow2.10 con…...
![](https://img-blog.csdnimg.cn/direct/80db7d440d9041e59d123b27a39beef7.png)
韩顺平0基础学Java——第27天
p548-568 明天开始坦克大战 Entry 昨天没搞明白的Map、Entry、EntrySet://GPT教的 Map 和 Entry 的关系 1.Map 接口:它定义了一些方法来操作键值对集合。常用的实现类有 HashMap、TreeMap 等。 2. Entry接口:Entry 是 Map 接口的一个嵌…...
![](https://img-blog.csdnimg.cn/direct/a98fac722f33469c85937ca096e72edf.png)
YesPMP探索Python在生活中的应用,助力提升开发效率
Python是一种简单易学、高效强大的编程语言,正变成越来越多人选择的热门技能。学习Python不仅可以提供更多就业机会,还能让自己在职场更加有竞争力,那可以去哪里拓展自己的技能呢? YesPMP平台 为熟练掌握Python语言的程序员提供了…...
![](https://img-blog.csdnimg.cn/img_convert/df071cc3a3dd5b210e8c281e786768d7.jpeg)
TikTok账号运营:静态住宅IP为什么可以防封?
静态住宅IP代理服务是一种提供稳定、静态IP地址并可隐藏用户真实IP地址的网络代理服务。此类代理服务通常使用高速光纤网络来提供稳定、高速的互联网体验。与动态IP代理相比,静态住宅IP代理的IP地址更稳定,被封的可能性更小,因此更受用户欢迎…...
![](https://img-blog.csdnimg.cn/direct/029c06d04e5c412d862ebe4cbaebbf06.png)
linux系统宝塔服务器temp文件夹里总是被上传病毒php脚本
目录 简介 上传过程 修复上传漏洞 tmp文件夹总是被上传病毒文件如下图: 简介 服务器时不时的会发送短信说你服务器有病毒, 找到了这个tmp文件, 删除了之后又有了。 确实是有很多人就这么无聊, 每天都攻击你的服务器。 找了很久的原因, 网上也提供了一大堆方法,…...
![](https://img-blog.csdnimg.cn/direct/8d8e22dfce9847448c6ddc8dca1f69d6.jpeg)
HTML+CSS+PHP实现网页留言板功能(需要创建数据库)
话说前头,我这方面很菜滴。这是我网页作业的一部分。 1.body部分效果展示(不包括footer) 2、代码 2.1 leaving.php(看到的网页) <!DOCTYPE html> <html lang"en"> <head> <met…...
![](https://www.ngui.cc/images/no-images.jpg)
【谷歌】实用的搜索技巧
1、使用正确的谷歌网址 我们知道https://www.google.com是谷歌的网址。但根据国家,用户可能会被重定向到 google.fr(法国)或google.co.in(印度)。 最主要的URL——google.com是为美国用户准备的(或是针对全世界所有用户的唯一URL))。当你在谷歌上搜索时,了解这一点是相…...
![](https://img-blog.csdnimg.cn/direct/4649ecdb5ad5484184a364be446b973e.png)
打造完美启动页:关键策略与设计技巧
启动页(Splash Screen)设计是指在应用程序启动时,首先展示给用户的界面设计。这个界面通常在应用加载或初始化期间显示,其主要目的是为用户提供一个视觉缓冲,展示品牌标识,并减少用户在等待过程中的焦虑感。…...
![](/images/no-images.jpg)
wordpress前台主题切换/扫一扫识别图片
文章目录1、闭包的概念2、实现一个闭包3、在闭包中外函数把临时变量绑定给内函数4、闭包中内函数修改外函数局部变量5、注意:6、练习:1、闭包的概念 请大家跟我理解一下,如果在一个函数的内部定义了另一个函数,外部的我们叫他外函…...
![](https://www.oschina.net/img/hot3.png)
南阳做网站优化的公司/济南seo怎么优化
2019独角兽企业重金招聘Python工程师标准>>> 方法一:Spring Boot 将所有的错误默认映射到/error, 实现ErrorController Controller RequestMapping(value "error") public class BaseErrorController implements ErrorController …...
![](https://img-blog.csdnimg.cn/img_convert/5b7ef2df7d14ef87684123689425577c.png)
做网站应该会什么软件/抖音关键词用户搜索排名靠前
写在前面 大家都知道 Github 是一个程序员福地,这里有各种厉害的开源框架、软件或者教程。这些东西对于我们学习和进步有着莫大的进步,所以我有了这个将 Github 上非常棒的 Java 开源项目整理下来的想法。觉得不错的话,欢迎小伙伴们去star一…...
燕窝网站怎么做/云南百度推广开户
整理 | 李雪敬出品 | 程序人生(ID:coder_life)据微博用户程序员的那些事 透露,一名来自洛阳的程序员在离职后的第二个月收到了原公司的汇款2400元,该笔汇款备注了竞业协议补偿款,在收到该笔汇款后不久&…...
![](/images/no-images.jpg)
网站建设6000元/可以免费发广告的网站
macOS 在macOS上使用Vapor,需要Xcode 9.3或更高版本、Swift 4.1或更高版本。安装还需要Homebrew命令。 检查Swift版本: swift --version Vapor安装命令: brew tap vapor/tap brew install vapor/tap/vapor 检查安装完成 vapor --help Ubuntu …...
![](https://img-blog.csdnimg.cn/img_convert/81788371647d2519653ac751817fb7f4.png)
企业网站管理系统c/浏阳廖主任打人案
WooCommerce将每个产品的总销量作为wp_postmeta表里,可以用get_post_meta获取,方法如下在主题的functions.php中加入如下代码//在shop页面显示总销量add_action( woocommerce_after_shop_loop_item_title, wc_product_sold_count, 5 );//在产品详情页面显…...