F. 实验4-2-9 水仙花数
题目描述
水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=1^3+5^3+3^3。 本题要求编写程序,计算所有N位水仙花数。
输入
输入在一行中给出一个正整数N(3≤N≤7)。
输出
按递增顺序输出所有N位水仙花数,每个数字占一行。
样例查看模式
正常显示
查看格式
输入样例1
3
输出样例1
153
370
371
407
#include<stdio.h>
#include<math.h>
int main()
{
int i,n,min,max,a,b,c,d,e,f,g;
scanf("%d",&n);
min=pow(10,n-1);
max=pow(10,n);
for(i=min;i<max;i++)
{
a=i%10;
b=i/10%10;
c=i/100%10;
d=i/1000%10;
e=i/10000%10;
f=i/100000%10;
g=i/1000000%10;
if(pow(a,n)+pow(b,n)+pow(c,n)+pow(d,n)+pow(e,n)+pow(f,n)+pow(g,n)==i)
{
printf("%d\n",i);
}
}
return 0;
}
上面是我第一次通过的代码
后来觉得有点复杂,就想尝试着优化
下面给出我第二次写的代码
#include<stdio.h>
#include<math.h>
int main()
{
int n,i,min,max,j,a,sum=0;
scanf("%d",&n);
min=pow(10,n-1);
max=pow(10,n);
for(j=min;j<max;j++)
{
sum=0;
for(i=0;i<n;i++)
{
a=j%10;
sum+=pow(a,n);
j/=10;
}
if(sum==j)
printf("%d\n",j);
}
return 0;
}
咋一看,思路完全正确,但是当你运行的时候一个案例都无法通过,为什么??
因为都超时了!!!!
再优化!!!
当使用pow导致超时时我们常常想到用循环代替它!!!
#include<stdio.h>
//#include<math.h>
int main()
{
int i, j, k, n, a, b = 1, sum = 0;
int min = 1, max;
scanf("%d",&n);
//min = pow(10,n-1);
for(i = 1; i < n; i++)//替代pow函数
{
min *= 10;
}
max = 10 * min;
for(i = min; i < max; i++)
{
a = i;
for(j = 1; j <= n; j++)
{
//sum += pow(a % 10, n);
for(k = 1; k <= n; k++)//替代pow函数
{b *= a % 10;}
sum += b;
a /= 10;
b = 1;
}
if(sum == i)
{printf("%d\n",i);}
sum = 0;
}
return 0;
}