描述
春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:
“水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。
现在要求输出所有在m和n范围内的水仙花数。
输入
两个整数m和n(100<=m<=n<=999)。
输出
要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开;
如果给定的范围内不存在水仙花数,则输出no。
输入样例 1
300 380
输出样例 1
370 371
题目要求输入范围然后再范围内判断水仙花数,这个需要分解每一个数的每一位然后判断每一位的三次方加起来是否等于原数,等于就输出不等于就继续知道到达数据范围之外。分解和判断可以写在main函数中,也可以写一个函数,我使用的是inline函数。
//1124
#include <iostream>
using namespace std;
inline void judeg(int a,int &x,int &y,int &z)
{
x=a%10;
y=(a%100-x)/10;
z=(a%1000-x-y)/100;
}
int main()
{
int m,n,x,y,z;
while(cin>>m>>n)
{
int jug=0;
for(int i=m;i<=n;i++)
{
judeg(i,x,y,z);
if(i==x*x*x+y*y*y+z*z*z)
{cout<<i<<" "<<endl;jug=1;}
}
if(!jug)
cout<<"no"<<endl;
}
return 0;
}