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

news/2024/5/20 0:27:03 标签: 算法, 数据结构, leetcode, 推荐算法

在这里插入图片描述

🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨
🐻推荐专栏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.niftyadmin.cn/n/5237130.html

相关文章

linux resin的安装

1. 下载安装包 1.1 下载地址&#xff1a;https://caucho.com/products/resin/download 这里我下载的是普通版本的resin&#xff0c;没有选resin pro 版本。 科普一下&#xff0c;从性能上来说 resin和resin pro 版本的性能没区别。 resin pro 版本的 和resin 普通版本的文件是…

Python基础快速过一遍

文章目录 一、变量及基本概念1、变量2、变量类型3、变量格式化输出4、type()函数5、input()函数6、类型转换函数7、注释 二、Python运算/字符1、算数运算2、比较运算3、逻辑运算4、赋值运算符5、转义字符6、成员运算符 三、判断/循环语句1、if判断语句2、while循环语句3、for循…

热门文章采集器【2023】

自媒体成为了许多人追逐的梦想&#xff0c;而爆文则是迈向成功的关键一步。随着越来越多的内容涌现&#xff0c;如何找到独特而引人注目的素材成为了自媒体创作者们面临的难题。本文将深入讲解当下热门的文章采集器&#xff0c;分享使用过的工具经验。 1.文章采集器的作用&…

珠宝模具3d仿真沉浸式交互展示更易分享传播

3D云展会经过近几年的蓬勃发展&#xff0c;迅速受到参展企业和客户的多方认可和支持&#xff0c;那么随着市场再度恢复&#xff0c;各种展会络绎不绝&#xff0c;想要快速打造一个逼真的线上3D云展会成为企业刚需。3D云展会线上搭建平台是web3d开发公司深圳华锐视点根据领先的三…

springboot 整合 Spring Security 中篇(RBAC权限控制)

1.先了解RBAC 是什么 RBAC(Role-Based Access control) &#xff0c;也就是基于角色的权限分配解决方案 2.数据库读取用户信息和授权信息 1.上篇用户名好授权等信息都是从内存读取实际情况都是从数据库获取&#xff1b; 主要设计两个类 UserDetails和UserDetailsService 看下…

【大连民族大学C语言CG题库练习题】——输入10个实数入数组,然后依次输出前1个实数和、前2个实数和、…、前10个实数和

【问题描述】输入10个实数入数组&#xff0c;然后依次输出前1个实数和、前2个实数和、…、前10个实数和 【输入形式】输入10个实数 【输出形式】依次输出前1个实数和、前2个实数和、…、前10个实数和 【样例输入】 1.2 3.4 4.4 3.8 5.1 6.2 7.3 4.3 9.4 2.5 【样例输出】 …

1.nacos注册与发现及源码注册流程

目录 概述nacos工程案例nacos服务注册案例版本说明本地启动 nacos-server搭建 spring cloud alibaba 最佳实践服务注册案例服务订阅案例 nacos注册源码流程源码关键点技巧 结束 概述 通过本文&#xff0c;学会如何确定项目组件版本(减少可能出现的jar包冲突)&#xff0c;nacos…

机器学习决策树ID3算法

1、先去计算总的信息量 2、根据不同指标分别计算对应的信息增益 3、根据算出的信息增益来选择信息增益最大的作为根结点 4、天气中选择一个继续上述过程 5、决策树划分结束