问题 F: 水仙花数
题目描述
请判断一个数是不是水仙花数。
其中水仙花数定义各个位数立方和等于它本身的三位数。
输入
有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000) 输入0表示程序输入结束。
输出
如果n是水仙花数就输出Yes 否则输出No
样例输入
153
154
0
样例输出
Yes
No
#include<stdio.h>
int main()
{
int n,t,q,a,b,c;
while(scanf("%d",&n)!=EOF)
{
if(n==0)
break;
t=n;
q=n; //将n保护起来
a=n%10; //n的个位
n=n/10;
b=n%10; //n的十位
c=t/100; //n的百位
if(q==(a*a*a+b*b*b+c*c*c))
printf("Yes\n");
else
printf("No\n");
}
}