解题思路:
对于一个确定的数,判断其是否为五次方数比较简单,因此解题关键在于确定遍历的上界。
9的五次方为59049(五位数),5*59049 = 285245(六位数),6*59049 = 354294(六位数),7 * 59049 = 413343(六位数)。
那么可以得出,7位数不可能是五次方数,因为7位数的最大五次方和(9999999的五次方和)413343是六位数。
同时,6位数可能是五次方数,因为六位数的最大五次方和(99999的五次方和)354294是六位数。
那么就可以将354294作为最大上界。
(产生上界的原因:增加一位后,数字本身大小和其五次方和增加范围不一致)
注意事项:
应该存在更优算法,但对于此题来说遍历足矣。
0和1不在答案内。
参考代码:
#include#includeint main(){ for(int i = 1000; i < 354294; i++){ int n1,n2,n3,n4,n5,n6,sum; n1 = i % 10; n2 = i / 10 % 10; n3 = i / 100 % 10; n4 = i / 1000 % 10; n5 = i / 10000 % 10; n6 = i / 100000 % 10; sum = pow(n1,5) + pow(n2,5) + pow(n3,5) + pow(n4,5) + pow(n5,5) + pow(n6,5); if(sum == i){ printf("%d\n",i); } } }
0.0分
1 人评分
2006年春浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:912 |
时间转换 (Java代码)浏览:617 |
C语言训练-最大数问题 (C语言代码)浏览:648 |
C语言训练-计算:t=1-1/(2*2)-1/(3*3)-...-1/(m*m) (C语言代码)浏览:799 |
A+B for Input-Output Practice (V) (C++代码)浏览:485 |
兰顿蚂蚁 (C++代码)浏览:1225 |
C语言程序设计教程(第三版)课后习题1.5 (C++代码)浏览:778 |
不会做的浏览:954 |
C语言程序设计教程(第三版)课后习题8.2 (C语言代码)浏览:5275 |
剪刀石头布 (C语言代码)浏览:1792 |