java 用循环判断输入的数是否是水仙花数
时间: 2023-07-12 11:18:16 浏览: 59
好的,我可以为您编写判断一个数是否为水仙花数的 Java 代码,以下是示例代码:
```java
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int sum = 0, temp = n;
while (temp != 0) {
int digit = temp % 10;
sum += digit * digit * digit;
temp /= 10;
}
if (sum == n) {
System.out.println(n + " 是水仙花数");
} else {
System.out.println(n + " 不是水仙花数");
}
}
}
```
以上代码中,我们首先使用 `Scanner` 类获取输入的数字 `n`,然后使用 `while` 循环计算出每一位数字的立方和 `sum`,最后判断 `sum` 是否等于 `n`,如果相等,则输出 `n` 是水仙花数,否则输出 `n` 不是水仙花数。
相关问题
java 用循环判断水仙花数
好的,以下是 Java 代码实现:
```java
public class Main {
public static void main(String[] args) {
for (int i = 100; i <= 999; i++) { // 遍历 100 到 999 每一个数字
int a = i / 100; // 获取百位数字
int b = i / 10 % 10; // 获取十位数字
int c = i % 10; // 获取个位数字
if (i == a * a * a + b * b * b + c * c * c) { // 如果该数字是水仙花数
System.out.println(i); // 输出该数字
}
}
}
}
```
以上代码中,我们使用 `for` 循环从 100 到 999 遍历每一个数字,然后分别获取该数字的百位、十位和个位数字,判断该数字是否是水仙花数,如果是则输出该数字。
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()` 方法。最后,将计算得到的和与原始数字进行比较,如果相等,则说明该数字是水仙花数。
请注意,这段代码假设用户输入的是一个正整数。如果需要对负数或其他非整数进行判断,需要进行额外的处理。