解题思路:判断边界,上边界是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语言训练-求s=a+aa+aaa+aaaa+aa...a的值 (C语言代码)浏览:1031 |
ASCII帮了大忙浏览:749 |
字符串比较 (C语言代码)答案错误????浏览:597 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:770 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:672 |
C语言程序设计教程(第三版)课后习题6.9 (C语言代码)浏览:641 |
【矩阵】 (C++代码)浏览:950 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:462 |
1012题解浏览:870 |
简单的a+b (C语言代码)浏览:546 |