题目信息:题目链接
水仙花数
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
0
-
描述
-
请判断一个数是不是水仙花数。
其中水仙花数定义各个位数立方和等于它本身的三位数。-
输入
-
有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000)
输入0表示程序输入结束。
输出
-
如果n是水仙花数就输出Yes
否则输出No
样例输入
-
153 154 0
样例输出
-
Yes No
-
有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000)
运行代码:
package 语言入门;
import java.util.Scanner;
/*
* 水仙花数:水仙花数定义各个位数立方和等于它本身的三位数。
* 输入:有多组测试数据,每组测试数据以包含一个整数n(100<=n<1000),
输入0表示程序输入结束。
输出:如果n是水仙花数就输出Yes
否则输出No
AC!
吐槽:被自己坑死了,直接复制过去,虽然改了主类名,但是你忘记了删去包名,晕
幸好看了网友的代码,发现和自己差不多,菜直到是哪里错了
运行时的错误:运行超时
温馨小贴士:if_else语句可以用三目运算符替代,这样的代码更为简练
*/
public class Num_39
{
public static void main(String[] args) throws Exception
{
Scanner in=new Scanner(System.in);
//输入数据,直到输入0的时候结束
int inputNum=in.nextInt();
while(inputNum !=0)
{
//判断输入的数是否是水仙花数
if(isDaf(inputNum))
System.out.println("Yes");
else
System.out.println("No");
//重新输入数据
inputNum=in.nextInt();
}
}
//判断数字n是都是水仙花数
private static boolean isDaf(int n)
{
//将n的三个数字分离出来,保存
int ge=n%10;
int bai=n/100;
int shi=n%100/10; //shi=(n-bai*100-ge)/10
long panduan=ge*ge*ge+shi*shi*shi+bai*bai*bai;
//long panduan=Math.pow(ge, 3)+Math.pow(shi, 3)+Math.pow(bai, 3);
if(n==panduan)
return true;
else
return false;
}
}