博客
关于我
算法笔记_218:花朵数(Java)
阅读量:437 次
发布时间:2019-03-06

本文共 2491 字,大约阅读时间需要 8 分钟。

为了找到N=21时所有满足条件的花朵数,我们需要找到所有21位正整数,使得该数等于其每个位数字的21次方之和。以下是解决方案:

方法思路

  • 问题分析:花朵数是指一个N位正整数,使得其各个位数字的N次方之和等于该数本身。对于N=21,我们需要找到所有这样的21位数。

  • 数字范围:21位数的范围是10^20到10^21 - 1。最高位必须是1,否则总和可能超过该数。

  • 回溯算法:使用回溯算法生成所有可能的21位数,逐步填充每一位数字。每一步计算当前的总和,并检查是否有可能满足条件。

  • 剪枝搜索:在每一步根据当前总和和剩余位数,剪枝搜索,避免不必要的计算。例如,如果当前总和加上剩余位的最大可能贡献小于当前数的下限,或者当前总和加上剩余位的最小可能贡献大于当前数的上限,则停止搜索。

  • 大整数处理:使用Java中的BigInteger来处理大数运算,避免溢出问题。

  • 解决代码

    import java.math.BigInteger;import java.util.ArrayList;import java.util.Collections;public class FlowerNumber {    private static final BigInteger[] powers = new BigInteger[10];    private static final ArrayList
    result = new ArrayList<>(); private static int count = 0; static { for (int i = 0; i < 10; i++) { powers[i] = new BigInteger("1").pow(21); } } public static void main(String[] args) { dfs(0, 0, new int[10]); Collections.sort(result); for (BigInteger num : result) { System.out.println(num.toString()); } } private static void dfs(int step, int sum, int[] digits) { if (step == 10) { if (sum == 21 && check(digits)) { BigInteger temp = BigInteger.ZERO; for (int i = 0; i < 10; i++) { temp = temp.add(powers[digits[i]]); } if (!result.contains(temp)) { result.add(temp); } count++; } return; } else { for (int i = 0; i <= 21 - sum; i++) { digits[step] = i; dfs(step + 1, sum + i, digits); } } } private static boolean check(int[] digits) { BigInteger total = BigInteger.ZERO; for (int i = 0; i < 10; i++) { total = total.add(powers[digits[i]]); } String s = total.toString(); if (s.length() != 21) { return false; } int[] countDigit = new int[10]; for (int i = 0; i < 21; i++) { int d = s.charAt(i) - '0'; countDigit[d]++; } for (int i = 0; i < 10; i++) { if (digits[i] != countDigit[i]) { return false; } } return true; }}

    代码解释

  • 初始化:预先计算每个数字(0-9)的21次方,并存储在数组powers中。

  • 主函数:调用递归函数dfs,从最高位开始填充数字,并在递归结束时检查是否满足条件。

  • 递归函数dfs:逐步填充每一位数字,计算当前总和,并调用check函数验证是否满足条件。

  • 验证函数check:计算各位数字的21次方之和,并检查是否等于该数本身,同时确保位数正确。

  • 剪枝搜索:在递归过程中根据当前总和和剩余位数进行剪枝,避免不必要的计算。

  • 结果处理:将满足条件的数字存储在result列表中,排序后输出。

  • 通过这种方法,我们可以高效地找到所有满足条件的花朵数。

    转载地址:http://oztyz.baihongyu.com/

    你可能感兴趣的文章
    PandoraFMS 监控软件 SQL注入漏洞复现
    查看>>
    PandoraFMS 监控软件 任意文件上传漏洞复现
    查看>>
    Parallel.ForEach的基础使用
    查看>>
    parallels desktop for mac安装虚拟机 之parallelsdesktop密钥 以及 parallels desktop安装win10的办公推荐可以提高办公效率...
    查看>>
    paramiko模块
    查看>>
    param[:]=param-lr*param.grad/batch_size的理解
    查看>>
    Spring Cloud 之注册中心 EurekaServerAutoConfiguration源码分析
    查看>>
    ParseChat应用源码ios版
    查看>>
    Part 2异常和错误
    查看>>
    Spring @Async执行异步方法的简单使用
    查看>>
    PAT 1027 Colors in Mars
    查看>>
    PAT 1127 ZigZagging on a Tree[难]
    查看>>
    PAT 2-07. 素因子分解(20)
    查看>>
    PAT-1044. Shopping in Mars (25)
    查看>>
    PAT-乙级-1040 有几个PAT
    查看>>
    PAT1093 Count PAT's (25)(逻辑题)
    查看>>
    PATA1038题解(需复习)
    查看>>
    Patching Array
    查看>>
    Path does not chain with any of the trust anchors
    查看>>
    Path形状获取字符串型变量数据
    查看>>