1802 - 水仙花数

请判断一个数是不是水仙花数。
其中水仙花数定义各个位数立方和等于它本身的三位数。

题目输入

有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000)
输入0表示程序输入结束。

题目输出

如果n是水仙花数就输出Yes
否则输出No

输入/输出样例

题目输入

153
154
0

题目输出

Yes
No

C语言解答

#include <stdio.h>
int main(){
    int n, a, b, c, f;
    while(scanf("%d", &n) && n != 0){
        a = n%10;
        b = n/10%10;
        c = n/100;
        if(a*a*a + b*b*b + c*c*c == n)
            puts("Yes");
        else
            puts("No");
    }

    return 0;
}

C++解答

#include <iostream>

using namespace std;

int main()
{
    int n,a,b,c;
    while(cin>>n&&n){
        a=n%10;
        b=n/10%10;
        c=n/100%10;
		if(n!=0)
          if(a*a*a+b*b*b+c*c*c==n){
            cout<<"Yes"<<endl;
        }else{
            cout<<"No"<<endl;
        }
		else break;
    }
    return 0;
} 
时间限制 1 秒
内存限制 128 MB
讨论 统计
上一题 下一题