【问题描述】
输入两个正整数m和n(m≥1,n≤1000),输出m到n之间的所有水仙花数。水仙花数是指各位数字的立方和等于其自身的数。例如,153的各位数字的立方和是13+53+33 =153。
【输入形式】
从键盘输入两个正整数m和n。
【输入输出样例1】(下划线部分表示输入)
Input m: 100
Input n: 400
153
370
371
【样例说明】
输入提示符后要加一个空格。其中“:”后要加一个且只能一个空格。
每行输出一个水仙花数。
英文字母区分大小写。必须严格按样例输入输出。
#include
#include
int main(void)
{
int m,n,a,b,c,k;
printf("Input m: ");
scanf("%d",&m);
printf("Input n: ");
scanf("%d",&n);
for(k=m;k<=n;k++){
a=k/100;
b=(k/10)%10;
c=k%10;
if(a*a*a+b*b*b+c*c*c==k){
printf("%d\n",k);
}
}
return 0;
}
我们可以把判断一个数是不是水仙花数做成一个函数,然后再调用,具体如下#include
#include
int Narcissistic(int k);
int main(void)
{
int m,n,k;
printf("Input m: ");
scanf("%d",&m);
printf("Input n: ");
scanf("%d",&n);
for(k=m;k<=n;k++){
if(Narcissistic(k) != -1){
printf("%d\n",k);
}
}
return 0;
}
int Narcissistic(int k){
int a,b,c;
a=k/100;
b=(k/10)%10;
c=k%10;
if(a*a*a+b*b*b+c*c*c==k){
return k;
}
return -1;
}
推荐您阅读更多有关于“c语言,”的文章