【力扣】盛最多水的容器

目录

题目

题目初步解析

水桶效应

代码实现逻辑

第一步

第二步

第三步

代码具体实现

注意

添加容器元素的函数

计算迭代并且判断面积是否是最大值

总代码

运行结果

总结


题目

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

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

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

说明:你不能倾斜容器。

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

题目初步解析

这一道题就是我们小时候常常说的水桶效应

水桶效应

水桶效应是指一只水桶想盛满水,必须每块木板都一样平齐且无破损,如果这只桶的木板中有一块不齐或者某块木板下面有破洞,这只桶就无法盛满水。是说一只水桶能盛多少水,并不取决于最长的那块木板,而是取决于最短的那块木板。也可称为短板效应。一个水桶无论有多高,它盛水的高度取决于其中最低的那块木板。

这就是我们要利用的思想来解答题目

代码实现逻辑

这是一个运用到双指针思想的问题(不一定用指针)

第一步

可以在数组的两侧(开头以及末尾)标记两个指针(或者记录下标)

然后计算面积

第二步

此时当然不能说这是最大的面积

我们要进行遍历

那怎么遍历呢?

还记得我们刚刚说的木头效应吗?

你装下的水取决于的是你最小的那一块木板

那如果要遍历的话

只能是短的一边进行更新,如果是左边的指针那就往右移动

如果是右边的就往左边进行移动

也就是都向“中间”更新

因为在横坐标两条垂线的距离降低的情况下,如果变化的是长边,盛水的长方形的高依旧不会变,不需要比较,那么面积必然会更小

第三步

那迭代出来的面积个数不止一个,怎么办呢?

分别比大小就可以了

第三步的步骤就是把每次迭代出来的值与之前的最大值比大小

如果更新的值更大,那就更新最大值就行

代码具体实现

注意

这里是展示所有代码可直接运行,但是力扣上的一个类,所以要改一下才可以跑

添加容器元素的函数

void addCounts(vector<int>& sum_1)
{int length;cout << "输入数组的长度" << endl;cin >> length;int i = 1;while (i <= length){int sum_2;cout << "输入第" << i << "个元素" << endl;cin >> sum_2;sum_1.insert(sum_1.end(), sum_2);i++;};
}

 这里就是最基本的赋值就行

可以用链表的形式,当然我图方便用了容器

不过如果用链表的话那下面的函数要进行修改

这些方法都可以

计算迭代并且判断面积是否是最大值

int maxArea(vector<int> height) 
{int maxarea = 0;int maxarea_1 = 0;int i = 0;int j = height.size() - 1;//最左节点int left_str = height[i];//最右节点int right_str = height[j];while (i != j){if (height[i] < height[j]){maxarea_1 = height[i] * (j - i);if (maxarea < maxarea_1)maxarea = maxarea_1;i++;}else{maxarea_1 = height[j] * (j - i);if (maxarea < maxarea_1)maxarea = maxarea_1;j--;}}return maxarea;
}

我这里是用下标进行定位的

计算面积同时判断大小

while语句中判断左边标记的下标等于右边的时候跳出循环

需要注意的是迭代的时候左边是++右边是--

总代码

总代码附上

#include <iostream>
#include <vector>
using namespace std;
//添加数组元素
void addCounts(vector<int>& sum_1)
{int length;cout << "输入数组的长度" << endl;cin >> length;int i = 1;while (i <= length){int sum_2;cout << "输入第" << i << "个元素" << endl;cin >> sum_2;sum_1.insert(sum_1.end(), sum_2);i++;};
}
int maxArea(vector<int> height) 
{int maxarea = 0;int maxarea_1 = 0;int i = 0;int j = height.size() - 1;//最左节点int left_str = height[i];//最右节点int right_str = height[j];while (i != j){if (height[i] < height[j]){maxarea_1 = height[i] * (j - i);if (maxarea < maxarea_1)maxarea = maxarea_1;i++;}else{maxarea_1 = height[j] * (j - i);if (maxarea < maxarea_1)maxarea = maxarea_1;j--;}}return maxarea;
}
int main()
{vector<int> sum_1;addCounts(sum_1);int maxarea = maxArea(sum_1);cout << "*************************************************************************"<< endl;cout <<"面积为" << maxarea << endl;return 0;
}

运行结果

和题目得到示例得到的结果一样

总结

本次博客学习了一种新的思想,并且巧妙的运用了学到的木桶效应来进行解题

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

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

相关文章

QT初始学习中的个人基础认知

整体感觉 安装的时候感觉更像python的库安装和编译器版本的配合安装。进入创建工程时&#xff0c;感觉是c语言的创建工程的感觉&#xff0c;而且可以看到main和h的头文件&#xff0c;整体来看是C来编写的程序。完成整个工程个人感觉是C编写功能&#xff0c;使用VB实现界面设计…

开发新能源的好处

风能无论是总装机容量还是新增装机容量&#xff0c;全球都保持着较快的发展速度&#xff0c;风能将迎来发展高峰。风电上网电价高于火电&#xff0c;期待价格理顺促进发展。生物质能有望在农业资源丰富的热带和亚热带普及&#xff0c;主要问题是降低制造成本&#xff0c;生物乙…

数据结构(Java实现)-二叉树(上)

树型结构 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树&#xff0c;也就是说它是根朝上&#xff0c;而叶朝下的。 有一个特殊的结点&#xff0c;称为根结点&…

SSL/CA 证书及其相关证书文件(pem、crt、cer、key、csr)

数字证书是网络世界中的身份证&#xff0c;数字证书为实现双方安全通信提供了电子认证。数字证书中含有密钥对所有者的识别信息&#xff0c;通过验证识别信息的真伪实现对证书持有者身份的认证。数字证书可以在网络世界中为互不见面的用户建立安全可靠的信任关系&#xff0c;这…

tomcat高可用和nginx高可用

tomcat高可用和nginx高可用 小白教程&#xff0c;一看就会&#xff0c;一做就成。 1.什么是高可用&#xff1f; 高可用HA&#xff08;High Availability&#xff09;是分布式系统架构设计中必须考虑的因素之一&#xff0c;它通常是指&#xff0c;通过设计减少系统不能提供服务…

如何构建多域名HTTPS代理服务器转发

在当今互联网时代&#xff0c;安全可靠的网络访问是至关重要的。本文将介绍如何使用SNI Routing技术来构建多域名HTTPS代理服务器转发&#xff0c;轻松实现多域名的安全访问和数据传输。 SNI代表"Server Name Indication"&#xff0c;是TLS协议的扩展&#xff0c;用于…

C#_GDI+ 绘图编程入门

官网提供相关API GDI 基本图形功能_drawing 高级二维和矢量图形功能_drawing2D GDI 图像处理功能_Imaging GDI 排版功能_text Windows 窗体应用程序提供打印功能_Printing 像素 构成图像的最小单位就是像素&#xff1b;屏幕上显示不管是位图或者矢量图&#xff0c;当描述…

《华为认证》6to4自动隧道

实验需求&#xff1a; 在NE1和NE3之间使用tunnel 口创建6to4自动隧道&#xff0c;实现PC1和PC2互访。 步骤1:配置ipv4地址&#xff0c;如图所示&#xff1a; 步骤2&#xff1a;配置NE1和NE3的ipv4路由&#xff0c;是两端的ipv4网络能够互访 R1: ip route-static 0.0.0.0 0…

机器学习笔记之优化算法(十九)经典牛顿法的收敛性分析

机器学习笔记之优化算法——经典牛顿法的收敛性分析 引言回顾&#xff1a;算法的收敛性分析 Wolfe \text{Wolfe} Wolfe准则的收敛性分析梯度下降法在凸函数的收敛性分析梯度下降法在强凸函数的收敛性分析 经典牛顿法的收敛性分析收敛性定理介绍证明过程关于隐含条件的说明 引言…

跳跃游戏【贪心算法】

跳跃游戏 给你一个非负整数数组 nums &#xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标&#xff0c;如果可以&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。在这里插入图片…

二级MySQL(七)——表格数据修改

1、修改表格中部分数据 将表格某一行的数据修改&#xff0c;这里用的UPDATE语句&#xff1a; UPDATE tb_student SET studentName 黄涛,native湖北,nation汉 WHERE studentNo 2014210103; 结果&#xff1a; 2、修改表格某一列全部数据 比如性别全部设置为‘女’ UPDATE…

langchain ChatGPT AI私有知识库

企业知识库 原理就是把文档变为向量数据库&#xff0c;然后搜索向量数据库&#xff0c;把相似的数据和问题作为prompt&#xff0c; 输入到大模型&#xff0c;再利用GPT强大的自然语言处理、推理和分析等方面的能力将答案返回给用户 什么是langchain? langchain是一个强大的…