java判断一个数是不是水仙花数
时间: 2023-09-11 10:09:29 浏览: 59
好的,针对您的问题,下面是 Java 判断一个数是不是水仙花数的代码示例:
```java
public static boolean isNarcissisticNumber(int n) {
int sum = 0;
int temp = n;
int len = String.valueOf(n).length();
while (temp > 0) {
int digit = temp % 10;
sum += Math.pow(digit, len);
temp /= 10;
}
return sum == n;
}
```
这段代码的实现原理是:将该数每一位上的数字的 len 次幂相加,如果和等于该数,则该数是水仙花数,否则不是。其中 len 是该数的位数。
相关问题
java用一段代码判断一个数是不是水仙花数
好的,针对您的问题,下面是 Java 判断一个数是不是水仙花数的代码示例:
```java
public class NarcissisticNumber {
public static boolean isNarcissisticNumber(int n) {
// 获取n的位数
int len = String.valueOf(n).length();
int sum = 0;
// 将n的每一位上的数字的len次幂相加
int temp = n;
while (temp > 0) {
int digit = temp % 10;
sum += Math.pow(digit, len);
temp /= 10;
}
// 判断sum是否等于n
return sum == n;
}
public static void main(String[] args) {
int n = 153;
if (isNarcissisticNumber(n)) {
System.out.println(n + "是水仙花数");
} else {
System.out.println(n + "不是水仙花数");
}
}
}
```
这段代码的实现原理是:将该数每一位上的数字的 len 次幂相加,如果和等于该数,则该数是水仙花数,否则不是。其中 len 是该数的位数。
java判断一个数字是否是水仙花数
水仙花数是指一个 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()` 方法。最后,将计算得到的和与原始数字进行比较,如果相等,则说明该数字是水仙花数。
请注意,这段代码假设用户输入的是一个正整数。如果需要对负数或其他非整数进行判断,需要进行额外的处理。