1802 - 水仙花数

通过次数

0

提交次数

0

时间限制 : 1 秒 内存限制 : 128 MB

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

题目输入

有多组测试数据,每组测试数据以包含一个整数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;
} 

Java解答

import java.util.Scanner;
public class Main
{
	public static void main(String[] args)
	{
		Scanner sc=new Scanner(System.in);
		while(sc.hasNext())
		{
			int n=sc.nextInt();
			if(n==0)
				break;
			String str=Integer.toString(n);
			int a=(int)Math.pow((str.charAt(0)-'0'),3);
			int b=(int)Math.pow((str.charAt(1)-'0'),3);
			int c=(int)Math.pow((str.charAt(2)-'0'),3);
			if(a+b+c==n)
				System.out.println("Yes");
			else
				System.out.println("No");
		}
	}
}