[双指针] (二) LeetCode 202.快乐数 和 11.盛最多水的容器

news2025/1/13 10:11:42

[双指针] (二) LeetCode 202.快乐数 和 11.盛最多水的容器

快乐数

202. 快乐数

image-20231029102141125

题目解析

(1) 判断一个数是不是快乐数

(2) 快乐数的定义:将整数替换为每个位上的和;如果最终结果为1,就是快乐数

(3) 这个数可能变为1,也可能无限循环

解题思路

示例1:n = 19;示例2: n = 2

image-20231029093817505

我们发现它们都可以抽象为一种类型:一个环中全都是1,另一个是无限重复的数。

image-20231029093912956

这和经典题目判断链表是否有环几乎是一模一样,解决判断链表是否有环时,我们使用的就是双指针解法。

141. 环形链表

解法:双指针(并不是真正意义上的指针)

定义一个快指针和一个慢指针,快指针走两步,慢指针走一步,最终它们会在同一个点相遇。(大家有能力的可以自己画图证明一下)

看到这里,大家可以尝试一下去实现一下代码,再向后面看下去。


代码实现
class Solution {
public:
    int getVal(int n)
    {
        int val = 0;
        while(n)
        {
            int tmp = n % 10;
            val += tmp * tmp;
            n /= 10;
        }
        return val;
    }
    bool isHappy(int n) {
        int fast = getVal(n), slow = n;
        while(fast != slow)
        {
            slow = getVal(slow);
            fast = getVal(getVal(fast));
        }
        return slow == 1;
    }
};

image-20231029094337360

总结

细节1:在循环条件上,我们使用fast != slow,所以一开始我们定义的快慢指针,应该不相同,所以把快指针定义为第二个数(getVal(n)),否则进不去循环。

细节2:返回的是slow == 1,最后相遇的点不一定为1,如示例中,也有可能为4。

细节3:为什么只有这两种情况(无限循环为1,或者无限循环不为1)?为什么没有一直循环下去且不重复这第三种情况?

我们进行一下简单证明:鸽巢原理

100个鸽子巢穴,有101只鸽子,可以得出至少有一个巢穴有两只鸽子。

image-20231029095245589

数据范围是[1, 2 ^ 31 - 1],也就是 [1, 2147483647];(约2 * 10 ^ 9)

我们再扩充数据范围为[1, 9999999999] (大于9 * 10 ^ 9)

9999999999 -> 81 * 10 = 810

所以[1, 2 ^ 31 - 1]循环范围为 [1, 810],即使有一个数经历810次循环后还不重复,但是第811次就会和这范围中的一个数重复。

由此得出,第三种情况不存在。

盛最多水的容器

11. 盛最多水的容器

image-20231029102057569

题目解析

(1) 数组height中存放的是高度

(2) 存水量为长 * 高

(3) 找出最大存水量的容器

解题思路

一开始我们会想到暴力解法:两个循环枚举所有情况,一个一个比大小。

但是有些情况是不需要枚举的,比如一个高是1,其他的情况基本不需要再枚举了(具体情况具体分析),长度确定情况下,肯定是越高越好。

接下来对暴力枚举进行优化:

我们又发现:存水量 = 长 * 高,即选择不同的下标就是选择不同的高度,所以我们尝试使用双指针。

定义一个指针left 和 指针right:

从同一方向开始,我们发现存水量 = 长 * 高,长可以变大或者变小,高可以变大或者变小:相乘之后结果是变大还是变小,这是不可控制的。

所以我们选择left在下标0处,right在下标height.size-1处。这样长是不断在减小的,高必须要变大才能使存水量变大。

所以在height[left]和height[right]之间需要选择一个更大的数,否则就跳过包含这个情况的所有情况,即为:left++或者right - -。

代码实现
class Solution {
public:
    int maxArea(vector<int>& height) {
        int max_area = 0;//h * l = area l:变小 h:变大
        for(int left = 0, right = height.size()-1; right > left; )
        {
                int low = height[left] < height[right] ? height[left] : height[right];
                max_area = max(max_area, (right - left) * low);
                if(height[left] < height[right]) left++;
                else right--;
        }
        return max_area;
    }
};

image-20231029103641872

总结

细节1:容器盛水量是由两个高度中短的那个决定的。

细节2:height[left] 和 height[right]之间,我们需要选择大的那个,来跳过包含小的那个高度的所有情况

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

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

相关文章

ESP-IDF编程指南

ESP-IDF 编程指南 - ESP32-C3 - — ESP-IDF 编程指南 v5.1 文档 (espressif.com) ESP-IDF 入门指南 | 乐鑫科技 (espressif.com) ESP-IDF 物联网开发框架 | 乐鑫科技 (espressif.com.cn)

【Git企业开发】第二节.Git 的分支管理

作者简介&#xff1a;大家好&#xff0c;我是未央&#xff1b; 博客首页&#xff1a;未央.303 系列专栏&#xff1a;Git企业级开发 每日一句&#xff1a;人的一生&#xff0c;可以有所作为的时机只有一次&#xff0c;那就是现在&#xff01;&#xff01;&#xff01;&#xff0…

一款功能强大的iOS设备管理软件Mazing 3中文版免费2024最新下载

Mazing 3中文版是一款功能强大的iOS设备管理软件&#xff0c;它可以帮助用户备份和管理他们的iPhone、iPad或iPod Touch上的数据。除此之外&#xff0c;它还可以将备份数据转移到新的设备中、管理应用程序、导入和导出媒体文件等。本文将详细介绍iMazing的功能和安全性&#xf…

解读deepLabV3+时遇到的问题总结

环境问题 python &#xff1a;3.10.12 ModuleNotFoundError: No module named ‘torchvision.models.utils 起初pip以下这个包&#xff0c;也没有解决问题&#xff1b;后来发现是版本的问题。 #from torchvision.models.utils import load_state_dict_from_url from torch.…

机器人入门(四)—— 创建你的第一个虚拟小车

机器人入门&#xff08;四&#xff09;—— 创建你的第一个虚拟小车 一、小车建立过程1.1 dd_robot.urdf —— 建立身体1.2 dd_robot2.urdf —— 添加轮子1.3 dd_robot3.urdf —— 添加万向轮1.4 dd_robot4.urdf —— 添加颜色1.5 dd_robot5.urdf —— 添加碰撞检测(Collision …

印度财团欲代工iPhone,路虎是前车之鉴,印度制造仍在梦中

随着印度财团塔塔收购纬创即将落寞&#xff0c;印度电子与科技国务部长强德拉谢克&#xff08;Rajeev Chandrasekhar&#xff09;为塔塔站台&#xff0c;表示两年内塔塔将制造iPhone并出口海外市场&#xff0c;印度制造将由此起飞。 一、印度制造在路虎上梦破 塔塔集团收购路虎…

手把手教你:如何用Java多线程模拟银行叫号服务

大家好&#xff0c;我是小米&#xff01;今天&#xff0c;我将和大家一起探讨一个非常有趣的话题——Java多线程模拟银行叫号服务。这不仅是一个有趣的编程练习&#xff0c;还可以帮助我们更好地理解多线程编程和并发控制。在这篇文章中&#xff0c;我将带领大家一步步实现一个…

cmd基本命令

一、cmd黑框是什么 cmd 是 Windows 命令提示符&#xff08;cmd.exe&#xff09;是 Windows NT 及以后的 Windows 系统下的一个用于运行 Windows 控制面板程序或某些 DOS 程序的shell程序&#xff1b;或在 Windows CE 下只用于运行控制面板程序的外壳程序。 二、打开步骤 wind…

Tornado downloadable工程和Tornado bootable工程

目录 Tornado downloadable工程Tornado bootable工程 Tornado downloadable工程和Tornado bootable工程是两个不同类型的Tornado项目。 Tornado downloadable工程 Tornado downloadable工程是指可以通过下载安装程序来安装的Tornado项目,通常用于Web应用程序。这种工程通常包…

相亲APP哪个好用?找对象的相亲软件哪个能脱单?

现在市面上的相亲APP非常多&#xff0c;质量也参差不齐&#xff0c;需要我们自己去辨别才能找到靠谱的&#xff0c;但是这很浪费时间。所以今天就分享几个我用过靠谱的相亲APP给大家参考&#xff0c;也算是提供一点经验。 1、一伴婚恋 这款相亲软件的优势在于&#xff0c;每个…

IOC课程整理-19 Spring Environment 抽象

1. 理解 Spring Environment 抽象 2. Spring Environment 接口使用场景 3. Environment 占位符处理 4. 理解条件配置 Spring Profiles 5. Spring 4 重构 Profile 6. 依赖注入 Environment 7. 依赖查找 Environment 8. 依赖注入 Value 9. Spring 类型转换在 Environment 中的运用…

使用dirhunt无需暴力破解即可扫描Web目录

Dirhunt 是一个针对搜索和分析目录进行优化的网络爬虫。如果服务器启用了“index of”模式&#xff0c;则该工具可以找到有趣的东西。如果未启用目录列表&#xff0c;Dirhunt 也很有用。它可以检测带有虚假 404 错误的目录、创建空索引文件以隐藏内容的目录等等。 Dirhunt 不使…

万字解析设计模式之工厂方法模式与简单工厂模式

一、概述 1.1简介 在java中&#xff0c;万物皆对象&#xff0c;这些对象都需要创建&#xff0c;如果创建的时候直接new该对象&#xff0c;就会对该对象耦合严重&#xff0c;假如我们要更换对象&#xff0c;所有new对象的地方都需要修改一遍&#xff0c;这显然违背了软件设计的…

麒麟KYLINOS2303版本上使用KDE桌面共享软件

原文链接&#xff1a;麒麟KYLINOS2303版本上使用KDE桌面共享软件 hello&#xff0c;大家好啊&#xff0c;今天给大家推荐一个在麒麟KYLINOS桌面操作系统2303版本上使用KDE桌面共享软件的文章&#xff0c;通过安装KDE桌面共享软件&#xff0c;可以让远程vnc客户端连接访问本机桌…

飞鼠异地组网工具基本使用教程

飞飞鼠异地组网工具基本使用教程 一、飞鼠工具介绍1.1 飞鼠工具简介1.2 飞鼠工具特点1.3 飞鼠工具使用场景1.4 飞鼠工具官网1.5 飞鼠工具版本介绍1.6 飞鼠工具节点类型 二、本次实践介绍2.1 本次实践简介2.2 本次环境规划 三、Docker环境安装工作3.1 master节点安装Docker3.2 子…

2023年【湖南省安全员-C证】新版试题及湖南省安全员-C证证考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 湖南省安全员-C证新版试题是安全生产模拟考试一点通总题库中生成的一套湖南省安全员-C证证考试&#xff0c;安全生产模拟考试一点通上湖南省安全员-C证作业手机同步练习。2023年【湖南省安全员-C证】新版试题及湖南省…

简历:了解常见的设计模式

一、请讲一讲设计模式的好处 在Java中应用设计模式有以下好处&#xff1a; 1. 提高代码的可维护性和可读性&#xff1a; 设计模式提供了一种结构化的方式来组织代码&#xff0c;使得代码更易于理解和修改。通过使用设计模式&#xff0c;开发人员可以遵循一致的设计原则和最佳…

BUUCTF rar 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 这个是一个rar文件&#xff0c;里面好像隐藏着什么秘密&#xff0c;但是压缩包被加密了&#xff0c;毫无保留的告诉你&#xff0c;rar的密码是4位纯数字。 密文&#xff1a; 下载附件&#xff0c;解压得到一个rar压…

保护自己免受AI诈骗的方法

前言 在21世纪&#xff0c;人工智能已经成为我们日常生活的一部分。不仅在聊天、写作、绘画和编程领域展现了巨大的潜力&#xff0c;还改变了我们的生活方式&#xff0c;提供了便捷和创新。然而&#xff0c;随着这一技术的迅速发展&#xff0c;我们也不得不面对新的威胁&#…

sql--索引使用

最左前缀法则&#xff08;联合索引&#xff09; 联合索引 位置不影响&#xff0c;但是所有索引必须连续使用&#xff0c;才会走索引 中间跳过则会造成后面索引则会失效 索引失效 规避方法---尽量使用> 或 < Explain需要重点关注的字段 Type key_leng possibl…