日期:2014-05-20 浏览次数:20884 次
package com.pyh.demo1;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Demo5 {
/**
* 获取阶乘的方法
*/
public static int factorial(int i) {
if (i == 1) {
return 1;
}
return factorial(i - 1) * i;
}
/**
* 获取阶乘和
*
* @return 返回包含阶乘和的集合
*/
public static List<String> factorialSum() {
List<String> info = new ArrayList<String>();// 准备一个集合
for (int i = 1; i <= 100000000; i++) {
String temp = i + "";// 将整形转换为字符串
int len = temp.length();// 获取长度
int sum1 = 0;
int sum2 = 0;
for (int j = 0; j < len; j++) {// 对数据进行拆分求阶乘和,如:123=1!+2!+3!
sum1 = Integer.parseInt(temp.substring(j, j + 1));
if (sum1 != 0) {
sum2 += factorial(sum1);
}
}
if (i == sum2) {// 对阶乘和与当前的数字进行比较
info.add(i + "");// 如果符合条件就加入到集合中
}
}
Collections.sort(info);// 对集合进行字典排序
return info;
}
public static void main(String[] args) {
System.out.println(factorialSum());
}
}