【问题描述】
编写一个程序,输入一个正整数N(N大于等于100小于等于999),求出100~N之间的所有水仙花数。所谓的水仙花数是:如果一个三位数的个位数、十位数、百位数的立方和等于该数自身,就称这个数为水仙花数。
【输入形式】
输入一个正整数N。
【输出形式】
输出从100到N之间的所有水仙花数,数之前用空格隔开。
【样例输入】
400
【样例输出】
153 370 371
【样例说明】
输入一个的正整数400,输出为100~400之间的水仙花数153、370、371
解析:
考察循环结构
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int n,t;
float a,b,c;
cin>>n;
for(int i=100;i<=n;i++)
{
t=i;
a=t%10;
t/=10;
b=t%10;
t/=10;
c=t%10;
t/=10;
if(pow(a,3)+pow(b,3)+pow(c,3)==i) cout<<i<<" ";
}
}
就目前学过的知识而言,以上代码是可行的。但是其实还可以简化代码,只不过要用到后面数组的知识来进行循环嵌套,让程序更加简洁可读。
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int n,t;
float a[3];
cin>>n;
for(int i=100;i<=n;i++)
{
t=i;
for(int j=0;j<3;j++)
{
a[j]=t%10;
t/=10;
}
if(pow(a[0],3)+pow(a[1],3)+pow(a[2],3)==i) cout<<i<<" ";
}
}
注意pow第一个参数要是小数。