用C语言求出所有三位水仙花数
时间: 2023-11-02 20:05:16 浏览: 113
水仙花数是指一个三位数,它的每个位上的数字的立方和等于它本身。例如153就是一个水仙花数,因为$1^3+5^3+3^3=153$。
下面是用C语言求出所有三位水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
int n = i * 100 + j * 10 + k;
if (n == i * i * i + j * j * j + k * k * k) {
printf("%d\n", n);
}
}
}
}
return 0;
}
```
这段代码中,我们用了三层循环来枚举所有可能的三位数。然后对于每个三位数,我们判断其是否为水仙花数,如果是,则输出它。
相关问题
用C语言求出所有的水仙花数
水仙花数是一个三位数,其各位数字立方之和等于该数本身。例如,153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。在C语言中,你可以通过循环遍历所有三位数并检查条件来找出它们:
```c
#include <stdio.h>
// 检查是否为水仙花数的函数
int is narcissistic(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() {
int start = 100; // 开始查找从100开始的三位数
int end = 999; // 结束于999,包括这个数
printf("水仙花数有:\n");
for (int num = start; num <= end; num++) {
if (is_narcissistic(num)) {
printf("%d ", num);
}
}
printf("\n");
return 0;
}
用c语言求出所有的水仙花数。
在C语言中,水仙花数是指那些每个位上的数字立方之和等于原数本身的三位数。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
下面是一个简单的程序示例,用于找出所有小于1000的水仙花数:
```c
#include <stdio.h>
// 函数定义,检查一个数字是否是水仙花数
int is_armstrong(int num) {
int original_num, remainder, sum = 0;
original_num = num;
// 对每一位进行立方并加总
while (original_num != 0) {
remainder = original_num % 10;
sum += remainder * remainder * remainder; // 取余并立方
original_num /= 10;
}
// 检查是否相等
if (sum == num)
return 1; // 是水仙花数
else
return 0; // 否则不是
}
// 主函数遍历并打印水仙花数
void find_armstrong_numbers() {
for (int i = 100; i < 1000; ++i) { // 遍历三位数范围
if (is_armstrong(i))
printf("%d ", i); // 打印水仙花数
}
}
int main() {
find_armstrong_numbers();
return 0;
}
```
当你运行这个程序,它会输出153, 370, 371, 407 这些水仙花数。
阅读全文