Leecode热题100---11:盛最多水的容器

题目:
给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。
找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。
返回容器可以储存的最大水量。
说明:你不能倾斜容器。
在这里插入图片描述
C++:双指针解法
要点:指针每一次移动,都意味着排除掉了一个柱子,每次移动有可能会增大面积的那条边
详细解释请参照:

https://leetcode.cn/problems/container-with-most-water/solutions/94102/on-shuang-zhi-zhen-jie-fa-li-jie-zheng-que-xing-tu/?envType=study-plan-v2&envId=top-100-liked
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;class Solution{
public:int maxArea(vector<int>& height) {//l是左端,r端开始,tmp每次计算出的容积,maxarea每次计算后的最大容积 int l = 0, r = height.size() - 1, tmp= 0, maxarea= 0;while (l < r){tmp= (r - l) *  min(height[l], height[r]);//一格指针移动后,取这次计算的area和上次计算的容积哪个大 maxarea= max(tmp, maxarea);if (height[l] < height[r]){l++;}else{r--;}}return maxarea;}
};int main(){Solution solution;int res;vector<int > arr = { 1, 8, 6, 2, 5, 4, 8, 3, 7 };res = solution.maxArea(arr);cout << res << endl;return 0;
}

python:双指针
思路同上;

# 双指针思路:左右两边标记i, j, 两边往中间移(左右夹逼)
class Solution(object):def maxArea(self, height):""":type height: List[int]:rtype: int"""maxArea = 0l = 0r = len(height) - 1while l < r:minHeight = 0if height[l] < height[r]:minHeight = height[l]l = l + 1else:minHeight = height[r]r = r - 1area = (r - l + 1) * minHeightmaxArea = max(maxArea, area)return maxArea

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

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

相关文章

数据结构学习/复习14--归并排序的递归与循环实现/计数排序

一、归并排序 1.递归实现 注意事项&#xff1a;即使排序的数字个数不为2的倍数也可正常分解&#xff0c;其思想没有规定一定要左右数目对称才可合并 注意事项&#xff1a;归并的思想还适用于外排序 2.递归改循环 注意事项&#xff1a;边界处理与非2的n次方倍的处理 版本1&…

基于HTTP GET方式获取网络时间的实现

上一节&#xff0c;我们介绍了基于NTP服务器获取网络时间的例子&#xff0c;但在有些情况下&#xff0c;比如我最近在使用RNDIS协议通过4G模块上网&#xff0c;这个协议不支持UDP协议&#xff0c;所以就用不了NTP服务器。或者有时候我们需要有更多的网络时间获取方式&#xff0…

RK3568平台开发系列讲解(SPI篇)spi_dev 驱动分析

🚀返回专栏总目录 文章目录 一、结构体二、API三、spidev驱动分析3.1、init3.2、probe3.3、spidev_write3.4、spidev_read3.5、spidev_open四、spi_register_driver分析五、spi_dev缺点沉淀、分享、成长

SpringBoot解决CORS跨域——@CrossOrigin

前端请求后端报错了。 状态码&#xff1a;403 返回错误&#xff1a;Invalid coRs request 一个注解就搞定了。 在类上加 CrossOrigin

数据库的函数、存储过程、触发器详解

一.变量 1.系统变量 global session 2.用户自定义变量 1.不用提前声明&#xff0c;使用时直接 变量名 2.set namelisi; set 字段名 into name from 表名 3.局部变量 1.需要用declare声明 2.declare 变量名 类型 3.set 变量名值 二.触发器 .1函数 DELIMITE…

点云算法源代码及解析专栏目录

1、轮廓线提取及简化 1.1 道格拉斯普克算法(DP)的点云轮廓线简化-CSDN博客 1.2 alpha shapes提取边缘点函数调用&#xff08;API&#xff09; 1.3 基于KNN-凸包提取轮廓点&#xff08;matlab&#xff09; 1.4 基于公共转点的Alpha shapes有序边缘点提取 1.5 一元线性回…

kylin 使用心得

Kylin操作系统是一种基于Linux的操作系统&#xff0c;主要在中国使用&#xff0c;由中国国内的开发团队维护。它的目标是为了提供一个稳定、安全、易于使用的操作环境。以下是一些用户可能基于Kylin操作系统的使用心得&#xff1a; 1. **界面友好**&#xff1a;Kylin操作系统通…

查看Linux系统是Ubuntu还是CentOS

要查看Linux系统是Ubuntu还是CentOS&#xff0c;可以通过多种方式进行确认&#xff1a; 查看/etc/os-release文件&#xff1a; 在终端中执行以下命令&#xff1a; cat /etc/os-release 如果输出中包含"IDubuntu"&#xff0c;则表示系统是Ubuntu&#xff1b;如果输出中…

windows驱动开发-PCI和中断(二)

谈到中断使用PCI总线来作为例子是最合适的&#xff0c;在Windows发展过程中&#xff0c;PCI作为最成功的底层总线&#xff0c;集成了大量的外设&#xff0c;不夸张的说&#xff0c;目前PCI几乎是唯一的总线选择&#xff0c;故大部分情况下&#xff0c;只有PCI设备驱动程序会遇到…

java项目之企业资产管理系统(springboot+vue+mysql)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的企业资产管理系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 管理员功能有个人中心&…

SQL Server (MSSQLSERVER) 服务无法启动

解决方法&#xff1a; 打开服务&#xff0c;右键SQL Server (MSSQLSERVER) ->属性->登录&#xff0c;改为本地系统用户

小果网页---套利系统添加了可以套利模块,提供数据api

最近在小果套利系统里面添加了一下可以套利模块&#xff0c;同时实现了盘中自动更新&#xff0c;30分钟更新一次。给大家提交交易参考&#xff0c;可以套利模块的选择 dfdf[df[申购状态] !暂停申购]dfdf[df[申购限额] !无限额]df[溢价率]df[溢价率].astype(float)df[成交量]df…

echarts getZr 点击区分柱状图和图例

mCharts.getZr().on(click, function (params) { var pointInPixel [params.offsetX, params.offsetY]; if (mCharts.containPixel(grid, pointInPixel)) { console.log(柱子) } else { console.log(图例) } })

Oracle镇压重复行的sql

在Oracle数据库中&#xff0c;如果你想要查询时不返回重复的行&#xff0c;你可以使用DISTINCT关键字。但是&#xff0c;如果你想要“镇压”或删除表中的重复行&#xff0c;你需要进行一些不同的操作。 以下是一些常见的方法来处理重复的行&#xff1a; 使用DISTINCT查询不重复…

Nginx的正向代理与反向代理

你好呀&#xff0c;我是赵兴晨&#xff0c;文科程序员。 今天&#xff0c;我们将一起了解什么是Nginx的正向代理&#xff1f;什么是Nginx的反向代理&#xff1f;并实际动手实践。 以下内容都是满满的干货&#xff0c;绝对不容错过。我建议先收藏这篇文章&#xff0c;然后找一…

无锁消息队列的设计实现

无锁队列的需求分析&#xff1a; 多线程访问共享队列的数据时&#xff0c;必须确保对共享队列操作的原子性&#xff0c;有以下情况&#xff1a; 1.生产者&#xff0c;例如tcp服务器接收到请求信息&#xff0c;需要将请求信息push进共享队列 2.消费者&#xff0c;例如线程池的…

项目管理-案例重点知识(整合管理)

项目管理&#xff1a;每天进步一点点~ 活到老&#xff0c;学到老 ヾ(◍∇◍)&#xff89;&#xff9e; 何时学习都不晚&#xff0c;加油 一、整合管理 案例重点 重点内容&#xff1a; &#xff08;1&#xff09;项目章程内容和作用 &#xff08;2&#xff09;项目管理计划…

linux系统介绍和安装教程(含安装链接放在最下面了)

一、linux系统简介 在Linux和C语言的发展历程中&#xff0c;有几位关键人物为它们的诞生和推广做出了重要贡献。 首先&#xff0c;肯汤姆森&#xff08;Ken Thompson&#xff09;是一位在AT&T公司工作的员工&#xff0c;他不仅发明了B语言&#xff0c;还创造了Unix系统。…

python怎么读取xml

引入XML组件&#xff1a;import xml.dom.minidom。 创建一个xml文件&#xff0c;<?xml version"1.0" encoding"utf-8"?>。 加载读取XML文件&#xff0c;xml.dom.minidom.parse(abc.xml)&#xff0c;这是xml文件的对象。 获取XML文档对象&#xff0…

c++ vector容器

在C中&#xff0c;vector 是一个动态数组&#xff0c;它可以根据需要自动增长和缩小。以下是对vector的基本概念和常用操作的详细解释&#xff1a; vector基本概念 vector 是一个模板类&#xff0c;它提供了对动态数组的封装。你可以用它来存储任何类型的对象&#xff0c;并自…