一个N位的十进制正整数,如果它的每个位上的数字的N次方的和等于这个数本身,则称其为花朵数。

例如:

当N=3时,153就满足条件,因为 1^3 + 5^3 + 3^3 = 153,这样的数字也被称为水仙花数(其中,“”表示乘方,53表示5的3次方,也就是立方)。

当N=4时,1634满足条件,因为 1^4 + 6^4 + 3^4 + 4^4 = 1634。

当N=5时,92727满足条件。

实际上,对N的每个取值,可能有多个数字满足条件。

程序的任务是:求N=21时,所有满足条件的花朵数。注意:这个整数有21位,它的各个位数字的21次方之和正好等于这个数本身。

如果满足条件的数字不只有一个,请从小到大输出所有符合条件的数字,每个数字占一行。因为这个数字很大,请注意解法时间上的可行性。

这些代码因为BigInteger要大约三分钟才会有结果

import java.math.BigInteger;
import java.util.ArrayList;
import java.util.Collections; public class Main {
public static ArrayList<BigInteger> set = new ArrayList<BigInteger>();
public static BigInteger[] value = new BigInteger[10];
public static int count = 0; public BigInteger getPow(BigInteger n) {
BigInteger result = BigInteger.ONE;
for(int i = 1;i <= 21;i++)
result = result.multiply(n);
return result;
} public boolean check(int[] A) {
BigInteger temp = BigInteger.ZERO;
for(int i = 0;i < 10;i++) {
BigInteger k = new BigInteger(""+A[i]);
temp = temp.add(value[i].multiply(k));
}
String s = "" + temp;
if(s.length() != 21)
return false;
int[] B = new int[10];
for(int i = 0;i < 21;i++) {
int k = s.charAt(i) - '0';
B[k]++;
}
for(int i = 0;i < 10;i++)
if(A[i] != B[i])
return false;
return true;
} public void dfs(int step, int sum, int[] A) {
if(step == 10) {
if(sum == 21 && check(A)) {
BigInteger temp = BigInteger.ZERO;
for(int i = 0;i < 10;i++) {
BigInteger k = new BigInteger(""+A[i]);
temp = temp.add(value[i].multiply(k));
}
if(!set.contains(temp))
set.add(temp);
count++;
}
return;
} else {
for(int i = 0;i <= 21 - sum;i++) {
A[step] = i;
dfs(step + 1, sum + i, A);
}
}
} public static void main(String[] args) {
Main test = new Main();
for(int i = 0;i <= 9;i++) {
BigInteger a = new BigInteger(""+i);
value[i] = test.getPow(a);
}
int[] A = new int[10];
test.dfs(0, 0, A);
Collections.sort(set);
for(int i = 0;i < set.size();i++)
System.out.println(set.get(i));
}
}

最新文章

  1. iOS: 在iPhone和Apple Watch之间共享数据: App Groups
  2. shell随机输出一人的学号与姓名
  3. 会话状态已创建一个会话 ID,但由于响应已被应用程序刷新而无法保存它
  4. Android多线程分析之一:使用Thread异步下载图像
  5. Servlet获取request的变量方法.
  6. [编]IoT The Internet of Things (IoT) 物联网
  7. Unity4.5版本DLL库名字问题
  8. 什么是编解码器codec
  9. hdu 5091(线段树+扫描线)
  10. 智传播客hadoop视频学习笔记(共2天)
  11. hadoop2集群中的datanode启动以后自动关闭的问题
  12. Java-枚举介绍
  13. UI 基本控件使用
  14. Scrapy中使用cookie免于验证登录和模拟登录
  15. RH2288V3服务器 硬件安装以及更换硬件
  16. (PAT)L2-012 关于堆的判断 (最小堆)
  17. Servlet 会话技术cookie和session
  18. Codeforces 180C - Letter - [简单DP]
  19. 如何使用命令行备份SAP HANA数据库
  20. linux网卡桥接问题与docker网卡桥接问题

热门文章

  1. xml rpc SimpleXMLRPCServer [python]
  2. 「雕爷学编程」Arduino动手做(13)——触摸开关模块
  3. dockerfile文档的相关参数
  4. 使用phoenix踩的坑与设计思考
  5. react中控制元素的显示与隐藏
  6. Linux下分析bin文件的10种方法
  7. Flex打印功能 (2011-05-21 17:16:14)
  8. jquery 根据 option 的 text 定位选中 option
  9. Spring全家桶——SpringBoot之AOP详解
  10. CukeTest+Puppeteer的Web自动化测试(二)