java判断一个数字是否是水仙花数
时间: 2024-04-14 10:26:29 浏览: 131
水仙花数是指一个 n 位数(n ≥ 3),它的每个位上的数字的 n 次幂之和等于它本身。例如,153 是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
下面是一个判断一个数字是否是水仙花数的 Java 代码示例:
```java
import java.util.Scanner;
public class NarcissisticNumberChecker {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入一个数字:");
int number = scanner.nextInt();
int originalNumber = number;
int sum = 0;
int digits = String.valueOf(number).length();
while (number != 0) {
int digit = number % 10;
sum += Math.pow(digit, digits);
number /= 10;
}
if (sum == originalNumber) {
System.out.println(originalNumber + " 是水仙花数");
} else {
System.out.println(originalNumber + " 不是水仙花数");
}
}
}
```
在这段代码中,首先通过 `Scanner` 类获取用户输入的数字。然后,使用一个循环将数字的每一位拆解出来,并计算每个位上数字的 n 次幂之和。为了确定数字的位数,我们使用了 `String.valueOf(number).length()` 方法。最后,将计算得到的和与原始数字进行比较,如果相等,则说明该数字是水仙花数。
请注意,这段代码假设用户输入的是一个正整数。如果需要对负数或其他非整数进行判断,需要进行额外的处理。
阅读全文