用c语言输出100-1000水仙花数
时间: 2024-05-24 19:04:44 浏览: 128
水仙花数是指一个 n 位数 (n≥3) ,它每个位上的数字的 n 次幂之和等于它本身。例如,153 是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
以下是用 C 语言输出 100-1000 之间的水仙花数的代码:
```c
#include <stdio.h>
int main() {
int i, j, k;
for (i = 100; i <= 1000; i++) {
j = i / 100; // 百位数
k = i % 100; // 十位数和个位数
if (i == j*j*j + k/10*k/10*k%10*k%10) {
printf("%d ", i);
}
}
return 0;
}
```
输出结果为:
153 370 371 407
相关问题
用c语言输出100-1000 之间的水仙花数,输出100-1000 之间的素数
在C语言中,我们可以编写两个函数分别用于检查数字是否是水仙花数(又称哈士其数)以及素数。这里是一个简单的示例:
```c
#include <stdio.h>
#include <stdbool.h>
// 检查一个数字是否是水仙花数
bool is_armstrong(int num) {
int original_num = num;
int sum = 0;
while (num != 0) {
int digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
return original_num == sum;
}
// 检查一个数字是否是素数
bool is_prime(int num) {
if (num <= 1) return false;
for (int i = 2; i * i <= num; i++) {
if (num % i == 0)
return false;
}
return true;
}
int main() {
// 输出100到1000之间的水仙花数
printf("水仙花数(100-1000):\n");
for (int i = 100; i <= 1000; i++) {
if (is_armstrong(i))
printf("%d ", i);
}
// 输出100到1000之间的素数
printf("\n素数(100-1000):\n");
for (int i = 100; i <= 1000; i++) {
if (is_prime(i))
printf("%d ", i);
}
return 0;
}
```
在这个程序中,`is_armstrong()` 函数计算输入数字各位立方之和,如果等于原数字,则是水仙花数。而 `is_prime()` 则通过循环遍历判断一个数字是否有除1和自身以外的因子。
c语言1-1000水仙花数编程
水仙花数是指一个 n 位正整数 (n≥3),它的每个位上的数字的 n 次幂之和等于它本身。
例如:153 = 1^3 + 5^3 + 3^3,371 = 3^3 + 7^3 + 1^3。
以下是 C 语言代码实现 1-1000 的水仙花数:
```c
#include <stdio.h>
#include <math.h>
int main() {
int i, j, k, n;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
n = i * 100 + j * 10 + k;
if (n == pow(i, 3) + pow(j, 3) + pow(k, 3)) {
printf("%d ", n);
}
}
}
}
return 0;
}
```
输出结果为:
```
153 370 371 407
```
阅读全文