解题思路:判断边界,上边界是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语言程序设计教程(第三版)课后习题1.5 (C++代码)浏览:1078 |
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:1195 |
WU-小九九 (C++代码)浏览:1683 |
【绝对值排序】 (C语言代码)浏览:820 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:668 |
求圆的面积 (C语言代码)浏览:1667 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:632 |
A+B for Input-Output Practice (VI) (C语言代码)浏览:552 |
1054题解浏览:460 |
快速排序算法1浏览:884 |