请判断一个数是不是水仙花数。
其中水仙花数定义各个位数立方和等于它本身的三位数。         
水仙花数时间限制:1000 ms  |  内存限制:65535 KB难度:1
描述 
请判断一个数是不是水仙花数。
其中水仙花数定义各个位数立方和等于它本身的三位数。
输入
有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000)
输入0表示程序输入结束。
输出
如果n是水仙花数就输出Yes
否则输出No
样例输入
样例输出
我用的编译器是CodeBlocks
我的代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
   | #include<iostream>   using namespace std;   int main()   {       int i,n,a,b,c;       while(cin>>n)   {       if(n!=0&&n>=100&&n<1000)       {       a=n/100;       b=(n-a*100)/10;       c=n-a*100-b*10;       if(a*a*a+b*b*b+c*c*c==a*100+b*10+c)           cout<<"YES"<<endl;       else           cout<<"NO"<<endl;       }       else           break;   }   return 0;   }
   | 
 
最优代码:
1 2 3 4 5 6 7 8 9 10 11 12
   | #include<iostream>   using namespace std;   int main()   {       int a;       while(1)       {           cin>>a;           if(a==0) break;           cout<<((a==153||a==370||a==371||a==407)?"Yes":"No")<<endl;       }   }
   | 
 
共
同
进
步
O(∩_∩)O