打印并输出所有的水仙花数,所谓水仙花数是指一个三位数,其各位数的立方各等于数本身,如153=13+53+33,所以153是一个水仙花数。
时间: 2023-06-04 12:04:32 浏览: 47
好的,以下是程序代码:
#include <stdio.h>
int main() {
int num, digit1, digit2, digit3;
for(num = 100; num <= 999; num++) {
digit1 = num / 100; // 百位数字
digit2 = (num % 100) / 10; // 十位数字
digit3 = num % 10; // 个位数字
// 判断是否为水仙花数
if(num == digit1 * digit1 * digit1 + digit2 * digit2 * digit2 + digit3 * digit3 * digit3) {
printf("%d ", num);
}
}
return 0;
}
相关问题
输出所有的水仙花数,所谓的水仙花数是指一个 3 位数,其各个数字立方和等于该数本 身,
要编写一个C程序来找出所有的水仙花数,你可以遍历3位数范围内的每个数字,然后检查它们是否满足条件,即各个位上的数字立方之和等于这个三位数本身。以下是一个简单的示例代码:
```c
#include <stdio.h>
int main() {
int start, end, i, j, k, sum;
// 开始和结束的边界,这里定义为100(最小的三位数)到999(最大的三位数)
start = 100;
end = 999;
printf("Water Lily (Narcissistic) Numbers are:\n");
for (i = start; i <= end; ++i) {
// 分解每一位数字
sum = 0;
j = i / 100; // 百位
k = (i % 100) / 10; // 十位
sum += j * j * j + k * k * k + (i % 10) * (i % 10) * (i % 10);
// 检查是否是水仙花数
if (sum == i) {
printf("%d ", i);
}
}
return 0;
}
```
当你运行这段代码时,它将输出所有3位的水仙花数。
C语言中水仙花数是一个三位数,特点是各个位数的立方等于该本身
在C语言中,水仙花数是指一个三位正整数,其各位数字立方之和等于原数本身。例如,153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。判断一个数是否为水仙花数的过程通常会涉及到循环和数学计算。你可以通过遍历从100到999的所有三位数,对每一位取立方然后求和,如果结果等于原始数字,那么这个数就是水仙花数。
以下是简单的C程序片段,用于检查一个三位数是否为水仙花数:
```c
#include <stdio.h>
int is_armstrong(int num) {
int original_num, digit, sum = 0;
// 将数字分解成每位数字
original_num = num;
while (original_num != 0) {
digit = original_num % 10;
sum += pow(digit, 3); // 立方并累加
original_num /= 10;
}
// 检查和是否等于原数
if (sum == num)
return 1; // 返回1表示是水仙花数
else
return 0; // 返回0表示不是水仙花数
}
int main() {
for (int i = 100; i <= 999; i++) {
if (is_armstrong(i))
printf("%d 是水仙花数\n", i);
}
return 0;
}