题解 | #奶牛快乐数#

奶牛快乐数

https://www.nowcoder.com/practice/d91cec70c7724a7dbcea02ed25bdeaee

知识点:快慢指针

思路:

给定的代码实现了一个函数isHappy,用于判断一个数是否是快乐数。函数接收一个整数n作为参数。

代码中使用了快慢指针的概念来进行判断。首先,初始化两个指针ab,将其都指向初始的整数n。然后,进入一个无限循环:

  • 在每次迭代中,通过调用辅助函数get,将a进行两次转换得到新的值,同时将b进行一次转换得到新的值。
  • 如果a的值最终等于1,则返回true,表示该数是快乐数。
  • 如果a的值等于b的值,表示出现了循环,即不可能得到1,返回false
  • 如果循环结束仍未返回结果,则继续下一次迭代。

辅助函数get用于对数字进行转换。它将整数x按位拆解,并将每位数字的平方累加到结果res中。

最后,代码在main函数中调用isHappy进行测试,并输出结果。

编程语言:java

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param n int整型
     * @return bool布尔型
     */
    public  boolean isHappy(int n) {
        int a = n, b = n;
        while (true) {
            a = get(get(a));
            b = get(b);
            if (a == 1) return true;
            if (a == b) return false;
        }
    }

    public static int get(int x) {
        int res = 0;
        while (x != 0) {
            int t = x % 10;
            res += t * t;
            x /= 10;
        }
        return res;
    }

}

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务