当前位置:网站首页>LeetCode琅琊榜第三层-盛最多水的容器
LeetCode琅琊榜第三层-盛最多水的容器
2022-04-21 21:33:00 【爪哇土著、JOElib】
LeetCode_11.盛最多水的容器
难度:中等
作者原始思路
1.动态规划的代码实现
class Solution {
public int maxArea(int[] height) {
var len = height.length;
var statistical = new int[len][len];
var maxSize = 0;
var size = 0;
for (int i = 1; i < height.length; i++) {
for (int j = i; j < height.length; j++) {
size = Math.min(height[j-i],height[j]) * i;
statistical[i][j] = size;
if (statistical[i][j] > maxSize) {
maxSize = statistical[i][j];
}
}
}
return maxSize;
}
}
存在问题

2. 不填表,直接运算
class Solution {
public int maxArea(int[] height) {
var len = height.length;
var maxSize = 0;
var size = 0;
for (int i = 1; i < height.length; i++) {
for (int j = i; j < height.length; j++) {
size = Math.min(height[j-i],height[j]) * i;
if (size > maxSize) {
maxSize = size;
}
}
}
return maxSize;
}
}
存在问题

3.反省
- 动态规划算法和分治算法并不是万能的,他们需要运用于能把复杂问题分解成一个简单问题,这个简单问题的性质和原来的问题的性质需要保持一致
- 注意的是,动态规划算法的下一个问题往往与上一个问题有联系,在此处,虽然可以把复杂的问题简单化后,问题的性质一样,但是,下一个问题与上一个问题往往产生不了联系,所以,这里强行用动态规划反而使得程序变得冗余,效率变低
官方解法-双指针解法
1.思路分析
- 1首先我们先要确定影响盛水面积的影响因素有哪些
- 1,1.底面积,即两个下标之间的宽度
- 1.2.高,即下标对应的值,由于木桶效应,决定盛水面积的是两条边中较短的边
- 2.其次,我们分析第一个因素,为了我们的面积可以达到最大,我们应该要让其下标间的宽度达到最大,即左索引与右索引分别初始化为最两端
- 3.最后,我们分析第二个因素,为了我们的面积可以达到最大,我们需要移动较短的一边
- 3.1如果移动较长的一边,移动后宽度变小,无论移动后它是否成为较短的一边,面积一定会减少,即如果移动后不是较短的一边,说明另一边仍然是较短的一边,宽度减少,面积减少,如果是,不仅宽度减少,高度还减少了,所以,移动较长的一边是不可取的
- 4,双指针的核心问题即初始化和移动都解决了,代码就完成了
2.代码实现
class Solution {
public int maxArea(int[] height) {
var left = 0;
var right = height.length - 1;
var maxSize = 0;
while (left < right) {
maxSize = Math.max(Math.min(height[left],height[right])*(right - left),maxSize);
if (height[left] < height[right]) {
left++;
}else {
right--;
}
}
return maxSize;
}
}
代码分析:
- 1.注意每一次移动前都要算出当前的面积即可,调用了Math类的两个求较大值和较小值的方法
- 2.注意:题解中讲述到如果移动较短边时,发现边相等直接跳过,减少计算次数,这里并没有体现
- 原因:因为这会让程序多出循环,不仅达不到提高效率的效果,反而降低了程序的效率,所以,直接计算即可
结论
博主刷题有限,不能准确讲出来什么时候用什么算法,但是将来的一天,我会充满信心的告诉大家什么时候用双指针,什么时候用其他的,最后我来总结一下几点
1.双指针为什么这么定义和移动
2.动态规划算法使用的前提
版权声明
本文为[爪哇土著、JOElib]所创,转载请带上原文链接,感谢
https://joelib.blog.csdn.net/article/details/124317585
边栏推荐
- [untitled] the test time is divided equally
- Reflex WMS system has several similarities with SAP system
- 安洵杯2021_Crypto_复现
- Information visualization large screen display board (with download connection)
- Multi tenant points system function list
- Operation instructions of training management system
- On the Oracle client of Linux, enter the SQL statement and Oracle not available process ID: 0 session ID: 0 serial number: 0 appears
- 飞行安全背后,不可或缺的物联网无线通信传感器设备
- How can urea futures be safe? What are the benefits of urea futures hedging?
- Cyclone IV E系列介绍
猜你喜欢

Smart face recognition 1 - keras builds its own facenet face recognition platform

聪明的人脸识别4——Pytorch 利用Retinaface+Facenet搭建人脸识别平台

憨批的语义分割重制版6——Pytorch 搭建自己的Unet语义分割平台

Operation instructions of training management system

CTF Crypto中涉及的AES题目

Neural network learning record 57 -- introduction, advantages and disadvantages of various activation functions

Smart face recognition 4 -- pytoch uses retinaface + facenet to build a face recognition platform

Red sun shooting range -- intranet penetration practice

返璞归真,多方安全计算要回归到“安全”的本源考虑

一加连发两款耳机产品:充电10分钟 听歌20小时
随机推荐
虚拟机关闭之后,重启linux之后,重启里面oracle的监听
Operation instructions of training management system
或许你不知道的12条SQL技巧
聪明的人脸识别3——Pytorch 搭建自己的Facenet人脸识别平台
微服务,中台,RPA和低代码火热背后的一些冷思考
RVB2601之启动流程
3D打印机CR-10S CR10S PRO Ender-3 Ender 3PRO Ender 5更换BMG挤出机,挤出电机的脉冲值或传动值E如何修改
On the Oracle client of Linux, enter the SQL statement and Oracle not available process ID: 0 session ID: 0 serial number: 0 appears
Introduction to qmenqu
Others - use of siege pressure test tool
AI+大健康, 是超能机器人的正确打开方式?
Eeasybi report system data source selection code development manual
Bailian3726 Xiandao seeking medicine [BFS]
Smart face recognition 4 -- pytoch uses retinaface + facenet to build a face recognition platform
【SeMask】Semantically Masked Transformers for Semantic Segmentation
Use fluent to animate a color filter for photos
力扣解法汇总824-山羊拉丁文
Communication between parent and child processes (II) -- four cases of anonymous pipeline communication
135, 137, 138, 139 and 445 port explanation and closing method
#Reflex WMS研习心得#上架原理
