快乐数

本文介绍了一种用于判断正整数是否为快乐数的算法。快乐数是指通过不断将其各位数字的平方和相加直至得到1的过程,若最终能到达1,则该数即为快乐数。文章提供了具体的实现代码,包括如何分解数字、计算平方和以及循环判断的过程。

快乐数
一个数是不是快乐是这么定义的:对于一个正整数,每一次将该数替换为他每个位置上的数字的平方和,然后重复这个过程直到这个数变为1,或是无限循环但始终变不到1。如果可以变为1,那么这个数就是快乐数。
1^2 + 9^2 = 82
8^2 + 2^2 = 68
6^2 + 8^2 = 100
1^2 + 0^2 + 0^2 = 1
要求输入一个数,判断它是否为快乐数
算法的思路很简单,第一步将数分解,第二部进行计算判断,也没有需要注意的细节。

vector<int> extraNum(int n)
{

    int tmp = 0;
    vector<int> result;
    int div_num = int(pow(10, 7));
    for (int i = 0; i < 8; i++)
    {
        tmp = n / div_num;
        n = n - tmp * div_num;
        result.push_back(tmp);
        div_num = div_num / 10;
    }
    return result;
}

int calPower(vector<int> result)
{
    int sum = 0;
    for (size_t i = 0; i < result.size(); i++)
    {
        sum = sum + (result[i] * result[i]);
    }
    return sum;
}
bool isHappy(int n)
{
    vector<int> each_num;
    int power = 0;
    int count = 0;
    each_num = extraNum(n);
    power = calPower(each_num);
    if (power == 1)
    {
        return true;
    }

    while (power != 1 && count < 20)
    {
        each_num = extraNum(power);
        power = calPower(each_num);
        count++;
    }
    if (power == 1)
        return true;
    return false;
    //each_num = extraNum(n);
}
### 关于快乐的 Java 实现 快乐是一种通过特定计算过程最终能够收敛至 1 的正整。其核心思想在于不断迭代计算当前字各位平方和,直到结果为 1 或进入循环为止。 以下是基于已有引用中的代码实现[^1]以及进一步优化后的版本: #### 完整的 Java 实现代码 ```java import java.util.HashSet; public class HappyNumbers { // 判断单个字是否为快乐的方法 public static boolean isHappy(int n) { HashSet<Integer> seenValues = new HashSet<>(); while (n != 1 && !seenValues.contains(n)) { seenValues.add(n); n = calculateNextNumber(n); } return n == 1; } // 计算下一个值(即各位字平方和) private static int calculateNextNumber(int number) { int totalSum = 0; while (number > 0) { int digit = number % 10; totalSum += digit * digit; number /= 10; } return totalSum; } // 打印指定量的快乐 public static void printHappyNumbers(int count) { int candidate = 1; // 候选起始值 int foundCount = 0; // 已找到的快乐 while (foundCount < count) { if (isHappy(candidate)) { System.out.print(candidate + " "); foundCount++; } candidate++; } } public static void main(String[] args) { int numberOfHappyNumbersToPrint = 10; // 需要打印的快乐量 System.out.println("前 " + numberOfHappyNumbersToPrint + " 个快乐是:"); printHappyNumbers(numberOfHappyNumbersToPrint); } } ``` #### 代码解析 1. **`isHappy` 方法** 此方法用于判断给定字 `n` 是否为快乐。它利用了一个集合 (`HashSet`) 来记录已经出现过的中间结果,防止无限循环的发生[^1]。 2. **`calculateNextNumber` 辅助函** 这是一个辅助函,负责计算输入字每位上的平方和,并返回新的值作为下一步处理的基础[^2]。 3. **`printHappyNumbers` 方法** 提供了一种简单的方式去连续寻找并打印一定量的快乐。此部分逻辑较为直观,只需逐一测试自然即可[^1]。 4. **主程序入口** 主函定义了需要查找多少个快乐并通过调用相应功能完成任务展示。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值