“水仙花数”是指一个三位数,其各个位的数字立方和等于该数字本身。例如:153是一个“水仙花数”,因为153=13 + 53 + 33。JAVA
时间: 2023-05-14 19:04:36 浏览: 157
可以使用以下代码来判断一个三位数是否为水仙花数:
for(int i=100; i<1000; i++){
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 + "是水仙花数");
}
}
这段代码会从100开始遍历到999,判断每个数是否为水仙花数,如果是则输出该数。
相关问题
用Java“水仙花数”是指一个三位数,其各个位的数字立方和等于该数字本身。例如:153是一个“水仙花数”,因为153=13 + 53 + 33。
一个简单的Java程序可以用来找出所有的水仙花数:
public class NarcissisticNumber {
public static void main(String[] args) {
for (int i = 100; i < 1000; i++) {
int a = i / 100;
int b = i / 10 % 10;
int c = i % 10;
if (a * a * a + b * b * b + c * c * c == i) {
System.out.println(i);
}
}
}
}
这个程序会输出所有的三位数水仙花数。
编写一个C语言程序,输出所有的“水仙花数”,所谓水仙花数是指一个三位数,其各位数字立方和等于该数本身。例如153是水仙花数,因为153=13+53+33。
下面是一个简单的C语言程序,它会遍历100到999之间的所有三位数,并检查它们是否是水仙花数:
```c
#include <stdio.h>
#include <stdbool.h>
bool is_aquileonum(int num) {
int digits[3]; // 存储每一位数字
int sum = 0;
// 分割出百位、十位和个位
digits[0] = num / 100;
digits[1] = (num % 100) / 10;
digits[2] = num % 10;
// 检查每位数字立方和是否等于原数
for (int i = 0; i < 3; i++) {
sum += pow(digits[i], 3);
}
return (sum == num);
}
int main() {
for (int num = 100; num <= 999; num++) {
if (is_aquileonum(num)) {
printf("%d 是水仙花数。\n", num);
}
}
return 0;
}
```
上述代码定义了一个辅助函数`is_aquileonum`,它将三位数分解成它的各个数字,并计算它们的立方和。如果和等于原始数字,那么返回`true`,表明这是一个水仙花数。
阅读全文