描述
请判断一个数是不是水仙花数。 其中水仙花数定义各个位数立方和等于它本身的三位数。
输入有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000) 输入0表示程序输入结束。输出如果n是水仙花数就输出Yes 否则输出No样例输入
153
154
0
样例输出
Yes
No
#include<iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> ivec;
int i,j,k;
int n;
while(cin>>n)
{
if(n>=100 && n<1000)
ivec.push_back(n);
if(n==0)
break;
}
for(size_t ix=0;ix!=ivec.size();ix++)
{
i=ivec[ix]/100;
j=ivec[ix]/10-i*10;
k=ivec[ix]%10;
if(ivec[ix]==i*i*i+j*j*j+k*k*k)
cout<<"Yes"<<endl;
else
cout<<"No"<<endl;
}
return 0;
}