c语言计算出所有的水仙花数并打印
时间: 2024-05-15 07:18:17 浏览: 171
好的,我可以帮您实现这个功能。以下是 C 语言实现水仙花数的代码:
```c
#include <stdio.h>
int main() {
int num, sum, digit;
for (int i = 100; i <= 999; i++) {
num = i;
sum = 0;
while (num > 0) {
digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
if (i == sum) {
printf("%d ", i);
}
}
return 0;
}
```
运行此程序,您可以得到所有的水仙花数。请注意,水仙花数是指一个 3 位数,它的每个位上的数字的立方和等于它本身(例如:153 = 1^3 + 5^3 + 3^3)。
相关问题
用C语言打印出所有水仙花数
水仙花数是指一个n位数(n≥3),其各位数字的n次方之和等于该数本身。例如153=1^3+5^3+3^3,所以153是一个水仙花数。
以下是用C语言打印出所有水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k, num;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}
```
该程序的思路是通过三层循环依次枚举所有的三位数,计算出该数的各位数字的立方和,判断是否等于该数本身,如果是则输出该数。
c语言 定义函数计算水仙花数,打印出100到1000之间所有“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个水仙花数,因为153 = 1 + 5°+ 3。输入说明:无输出说明:每行输出一个水仙花数,有多少个水仙花数,就输出多少行
在C语言中,你可以定义一个函数来检查一个数是否是水仙花数,并遍历给定范围内的所有三位数来查找它们。下面是一个简单的实现示例:
```c
#include <stdio.h>
#include <stdbool.h>
// 函数声明
bool isArmstrong(int num);
int main() {
int start = 100;
int end = 1000;
printf("水仙花数:\n");
for (int i = start; i <= end; ++i) {
if (isArmstrong(i)) {
printf("%d\n", i);
}
}
return 0;
}
// 检查是否为水仙花数的辅助函数
bool isArmstrong(int num) {
int original_num, remainder, sum = 0;
original_num = num;
// 把数字分解成每一位并计算立方和
while (original_num != 0) {
remainder = original_num % 10;
sum += pow(remainder, 3); // 使用pow函数计算立方
original_num /= 10;
}
// 如果原始数等于它的立方和,则是水仙花数
return (num == sum);
}
```
这个程序会循环100到1000之间的每个整数,通过`isArmstrong()`函数检查它是否是水仙花数,如果是则打印出来。
阅读全文