用c语言输出100-1000 之间的水仙花数,输出100-1000 之间的素数
时间: 2024-09-13 10:08:59 浏览: 74
在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和自身以外的因子。
阅读全文