双指针算法: 快乐数 与 盛水最多的容器

2023-12-04 14:52

本文主要是介绍双指针算法: 快乐数 与 盛水最多的容器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨
🐻推荐专栏1: 🍔🍟🌯C语言初阶
🐻推荐专栏2: 🍔🍟🌯C语言进阶
🔑个人信条: 🌵知行合一

前言

声明:题目来源于: 力扣

一、快乐数

题目链接: 传送门

(1) 题目描述

编写一个算法来判断一个数 n 是不是快乐数

「快乐数」 定义:

对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
如果这个过程 结果为 1,那么这个数就是快乐数。

返回值:
如果 n快乐数 就返回 true
不是,则返回 false

示例:

示例 1:

输入:

n = 19

输出:true

解释:

12 + 92 = 82
82 + 22 = 68
62 + 82 = 100
12 + 02 + 02 = 1

示例 2:

输入:n = 2
输出:false

(2)解题思路

刚开始见到这道题的时候,毫无思路,知道会循环又如何?什么时候结束循环才麻烦。
我总不能每次循环都判断结果是否为1吧?计算是这样,那要是一直不为1咋办,死循环,也就死翘翘了。

快乐数,有点也不快乐!
在这里插入图片描述

总不能不做吧,我们不妨画图分析一下。
在这里插入图片描述
是不是有点眼熟,画完图以后,我们惊奇的发现,这好像与带环链表问题极其相似。

环形链表博客(第二题)

在环形链表II 中,我们向后一步是next指针往后遍历,本题是每一次将该数替换为它每个位置上的数字的平方和。

  1. 我们可以将 “求每个位数的平方和”封装成一个函数(func)。
  2. 定义快慢指针:
    快指针每次调用两次func函数。
    慢指针每次调用一次func函数。
  3. 快慢指针相遇时,即为环的入口点。
  4. 入口点是1,则为快乐数,返回ture
    入口点非1,则不是快乐数,返回false

(3)代码展示:

class Solution {
public:bool isHappy(int n) {int slow=n;int fast=n;do{slow=func(slow);fast=func(func(fast));}while(slow!=fast);//跳出循环,此时快慢指针相遇if(slow!=1)return false;return true;}int func(int n){	//求每个位数的平方和int ret=0;while(n){int mod=n%10;ret+=(mod*mod);n/=10;}return ret;}
};

二、盛水最多的容器

(1) 题目描述

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

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

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

示例:

在这里插入图片描述

(2)解题思路

其实题目意思很简单,看图就很容易理解,就是寻找两个下标位置,将其最短的作为容器的高,两个坐标的距离作为容器的底,求出容积最大情况时,两个下标的位置。

  1. 定义两个指针:
    (1)left最初位置
    (2)right最后一个位置
  2. 先计算这边界状态时,容器的容量。
  3. 如果左边界比右边界高,则移动右边界。

如果我们移动左边界:
  取到比右边界的值大: 则容器的高度依旧是右边界,低长度下降,总容量下降
  取到比右边界的值小,则容器的高度是左边界,这样的左边界只会让高度更低,而低的长度下降,总容量下降

如果我们移动右边界:
  取到比左边界的值大: 则容器的高度是左边界,高度会增加,虽然底的长度下降,但是容量可能上升
  取到比左边界的值小,则容器的高度是右边界,高度更低,低的长度下降,总容量下降

  1. 如果右边界比左边界高,则移动左边界。
    同理,这里就不再分析了。

  2. 计算移动后的容量,并判断是否需要更新容量。

(3)代码展示:

class Solution {
public:int maxArea(vector<int>& height) {int left=0,right=height.size()-1;//边界时的面积int maxv=(right-left)* min(height[left], height[right]);while(left<right){//如果左边界比右边界高,则移动右边界if(height[left]>height[right]) --right;else ++left;//计算移动边界以后的面积int v=(right-left)*min(height[left],height[right]);//取最大面积maxv=max(maxv,v);}return maxv;}
};

这篇关于双指针算法: 快乐数 与 盛水最多的容器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/453869

相关文章

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

SpringIOC容器Bean初始化和销毁回调方式

《SpringIOC容器Bean初始化和销毁回调方式》:本文主要介绍SpringIOC容器Bean初始化和销毁回调方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录前言1.@Bean指定初始化和销毁方法2.实现接口3.使用jsR250总结前言Spring Bea

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.