1802 - 水仙花数
时间限制 : 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"); } } }