用Java代码判断一个数是否为水仙花数
时间: 2024-02-06 14:08:55 浏览: 108
JS判断一个数是否是水仙花数
水仙花数是指一个 n 位数 (n≥3),它的每个位上的数字的 n 次幂之和等于它本身。例如,153 是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
以下是用 Java 代码判断一个数是否为水仙花数的实现:
```java
public class NarcissisticNumber {
public static void main(String[] args) {
int number = 153;
if (isNarcissisticNumber(number)) {
System.out.println(number + " is a narcissistic number.");
} else {
System.out.println(number + " is not a narcissistic number.");
}
}
public static boolean isNarcissisticNumber(int number) {
int sum = 0;
int temp = number;
int digitCount = String.valueOf(number).length();
while (temp > 0) {
int digit = temp % 10;
sum += Math.pow(digit, digitCount);
temp /= 10;
}
return sum == number;
}
}
```
在这个例子中,我们将要检查的数定义为 `number`,然后调用 `isNarcissisticNumber` 方法来判断是否为水仙花数。方法首先计算数字的位数 `digitCount`,然后使用循环来计算每个位上的数字的 n 次幂之和。最后,它将比较这个和与原始数字是否相等。如果相等,则返回 `true`,否则返回 `false`。
阅读全文