首页 > 编程语言 >(算法)双指针——快乐数 <数据分块>

(算法)双指针——快乐数 <数据分块>

时间:2024-05-28 23:59:20浏览次数:23  
标签:10 slow return 分块 int fast 算法 指针

1. 题⽬链接:快乐数

2. 题⽬描述:

3. 题⽬分析: 

为了⽅便叙述,将「对于⼀个正整数,每⼀次将该数替换为它每个位置上的数字的平⽅和」这⼀个 操作记为x 操作; 题⽬告诉我们,当我们不断重复x 操作的时候,计算⼀定会「死循环」,死的⽅式有两种: 

        ▪ 情况⼀:⼀直在1 中死循环,即1 -> 1 -> 1 -> 1......  

        ▪ 情况⼆:在历史的数据中死循环,但始终变不到1  

由于上述两种情况只会出现⼀种,因此,只要我们能确定循环是在「情况⼀」中进⾏,还是在「情 况⼆」中进⾏,就能得到结果。

简单证明:  

a. 经过⼀次变化之后的最⼤值9^2 * 10 = 810 ( 2^31-1=2147483647 。选⼀个更⼤的最 ⼤9999999999 ),也就是变化的区间在[1, 810] 之间; 

b. 根据「鸽巢原理」,⼀个数变化811 次之后,必然会形成⼀个循环;

c. 因此,变化的过程最终会⾛到⼀个圈⾥⾯,因此可以⽤「快慢指针」来解决。

4. 解法(快慢指针):  

算法思路:  

根据上述的题⽬分析,我们可以知道,当重复执⾏x 的时候,数据会陷⼊到⼀个「循环」之中。 ⽽「快慢指针」有⼀个特性,就是在⼀个圆圈中,快指针总是会追上慢指针的,也就是说他们总会 相遇在⼀个位置上。如果相遇位置的值是1 ,那么这个数⼀定是快乐数;如果相遇位置不是1 的话,那么就不是快乐数。  

补充知识:如何求⼀个数n每个位置上的数字的平⽅和. 

a. 把数n 每⼀位的数提取出来: 循环迭代下⾯步骤:

        i. int t = n % 10 提取个位; 

        ii. n /= 10 ⼲掉个位; 直到n 的值变为0 ; 

b. 提取每⼀位的时候,⽤⼀个变量tmp 记录这⼀位的平⽅与之前提取位数的平⽅和 

        ▪ tmp = tmp + t * t

C++算法代码: 

class Solution {
public:
     //求各位的平方和
    int Getsum(int x)
    {
        int count=0;
        while(x)
        {
            int t=x%10;
            count+=t*t;
            x/=10;
        }
            return count;
    }
    bool isHappy(int n) 
    {
        //快慢双指针,慢指针一次走一步,快指针一次走两步
        //根据数学推导,快慢指针必定会相遇
        //可能性1:进入1的循环
        //可能性2:进入不等于1的循环
        int low=n,fast=Getsum(n);
        while(low!=fast)
        {
            low=Getsum(low);    //慢指针一次走一步
            fast=Getsum(fast);  //快指针一次走两步
            fast=Getsum(fast);
        }
        //相遇后判断是哪一种循环
        if(low==1)
        {
            return true;
        }
        else
        {
            return false;
        }
    }
};

 Java算法代码:

class Solution
{
	public int bitSum(int n) // 返回 n 这个数每⼀位上的平⽅和 
	{
		int sum = 0;
		while (n != 0)
		{
			int t = n % 10;
			sum += t * t;
			n /= 10;
		}
		return sum;
	}
	public boolean isHappy(int n)
	{
		int slow = n, fast = bitSum(n);
		while (slow != fast)
		{
			slow = bitSum(slow);
			fast = bitSum(bitSum(fast));
		}
		return slow == 1;
	}
}

标签:10,slow,return,分块,int,fast,算法,指针
From: https://blog.csdn.net/2301_79580018/article/details/139280903

相关文章

  • (算法)双指针——复写零 <原地复写>
    1.题⽬链接:1089.复写零2.题⽬描述:3.解法(原地复写-双指针): 算法思路: 如果「从前向后」进⾏原地复写操作的话,由于0的出现会复写两次,导致没有复写的数「被覆盖掉」。因此我们选择「从后往前」的复写策略。但是「从后向前」复写的时候,我们需要找到「最后⼀个复写的数......
  • 二分查找算法详讲(三种版本写法)原创
    介绍:二分查找算法(BinarySearch)是一种在有序数组中查找目标元素的算法。它的基本思想是通过将目标元素与数组的中间元素进行比较,从而将搜索范围缩小一半。如果目标元素等于中间元素,则搜索结束;如果目标元素小于中间元素,则继续在左半部分查找;如果目标元素大于中间元素,则在右......
  • 基于BP神经网络的32QAM解调算法matlab性能仿真
    1.算法运行效果图预览   2.算法运行软件版本matlab2022a 3.算法理论概述       32QAM(QuadratureAmplitudeModulation,四相幅度调制)是一种高效的数字调制技术,能够在一个信道内同时传输多比特信息。基于BP(Backpropagation)神经网络的32QAM解调算法,利用神经网......
  • 数据结构与算法学习——二叉树
    题目PS:下列题目均来自leetcode中灵神题单938.二叉搜索树的范围和classSolution:defrangeSumBST(self,root:TreeNode,low:int,high:int)->int:ifnotroot:return0ifroot.val>high:returnself.rangeSumBST(r......
  • 想要初步了解指针?看这篇就够啦!
    初级指针    一:指针的解释        什么是指针?本质上指针是内存地址,平时说的指针是指针变量,用来存放地址,指针变量里面存放的是地址而通过这个地址,就可以找到一个内存单元            上示例,定义了int类型的a变量,声明了一个整型......
  • 数据结构与算法
    数据结构与算法导航目录数据结构与算法导航一、数据结构与算法概念数据结构的定义算法伪代码二、线性表线性表三、队列与栈栈队循环队列四、窜广义表窜五、数组六、树与二叉树树二叉树七、图图的存储八、查找五大查找顺序查找二分查找二叉查找树(排序)二叉平衡树哈夫曼树B-树B+......
  • 031 指针学习—引用数组
    目录1数组元素的指针(1)定义(2)举例(3)注意事项2指针的算术运算(1)前提(2)运算规则(3)举例[1]p+i[2]p-i[3]++p与p++[4]--p与p--[5]p1-p2(4)注意事项3通过指针引用数组元素(1)引用数组元素方法(2)举例例1:输出a[10]数组中的全部元素例2:通过指针变量输出整型数组a的10个......
  • 旅行第三天【算法】双指针-----盛最多水的容器
    文章目录一、题目二、算法原理三、编写代码一、题目链接:盛最多水的容器二、算法原理首先,这种题可以用暴力解法(枚举每一种容器的大小情况),但是显然会超时(不用尝试啦,我已经试过啦!)其次还是咱们的主题----->利用双指针来求解下面先附上草稿图容器面积=高度(左......
  • 【LeetCode算法】第88题:合并两个有序数组
    目录一、题目描述二、初次解答三、官方解法四、总结一、题目描述二、初次解答1.思路:首次想到的解法:定义一个m+n长度的辅助数组,从头遍历这两个数组,谁小就放进辅助数组中并且对应往后走,最后使用memcpy函数将辅助数组内容拷贝到nums1中。这种解法容易想到,但是空间复杂......
  • 【LeetCode算法】第83题:删除排序链表中的重复元素
    目录一、题目描述二、初次解答三、官方解法四、总结一、题目描述二、初次解答1.思路:双指针法,只需遍历一遍。使用low指向前面的元素,high用于查找low后面与low不同内容的节点。将具有不同内容的节点链接在low后面,实现重复元素的删除。2.代码:/***Definitionfor......