解题思路:判断边界,上边界是999999,999999的五次方数是354294,比原数小;下边界是参考了大神的解题方法发现这题中 0和1 不在正解范围内,所以从10开始进行循环即可
注意事项: 解法比较暴力,是钻了字符串和整型数据转换的空子,所以内存会特别特别大,第一次是在10~999999的范围,然后超限了!!!,之后就改成了自己先前跑出来的正确答案的范围,即4150~194979,然后内存就小了许多,但还是超级大!!!
参考代码:
public class Main {
public static void main(String[] args) {
for (int i = 4150; i <= 194979; i++) {
int sum = 0;
String [] str = String.valueOf(i).split("");
for (int j = 0; j < str.length; j++) {
sum += Math.pow(Integer.valueOf(str[j]), 5); //表示计算Integer.valueOf(str[j])的5次方
}
if (sum == i){
System.out.println(i);
}
}
}
}
0.0分
1 人评分
买不到的数目 (C++代码)浏览:862 |
打水问题 (C语言代码)浏览:1063 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:661 |
WU-小九九 (C++代码)浏览:1680 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:2090 |
sizeof的大作用 (C语言代码)浏览:1447 |
C语言程序设计教程(第三版)课后习题10.2 (C语言代码)浏览:678 |
2003年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:575 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:505 |
上车人数 (C语言代码)浏览:709 |