水仙花数c语言
时间: 2023-07-02 19:13:12 浏览: 105
水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
以下是一个用C语言编写的水仙花数程序:
```c
#include <stdio.h>
#include <math.h>
int main() {
int n, num, sum, i;
printf("请输入一个三位数:");
scanf("%d", &num);
n = 3; // 水仙花数是三位数
sum = 0;
for (i = 1; i <= n; i++) {
int digit = num % 10;
sum += pow(digit, n);
num /= 10;
}
if (sum == num) {
printf("%d 是一个水仙花数\n", num);
} else {
printf("%d 不是一个水仙花数\n", num);
}
return 0;
}
```
运行时,程序会要求输入一个三位数,然后判断它是否是一个水仙花数并输出结果。
相关问题
水仙花数c语言并行
可以使用OpenMP库来实现水仙花数的并行计算,具体实现代码如下:
```c
#include <stdio.h>
#include <omp.h>
int main() {
int n, i, j, k;
#pragma omp parallel for private(i,j,k)
for (n = 100; n < 1000; n++) {
i = n / 100; // 百位数
j = (n / 10) % 10; // 十位数
k = n % 10; // 个位数
if (n == i * i * i + j * j * j + k * k * k) {
printf("%d ", n);
}
}
return 0;
}
```
在上面的代码中,我们使用了OpenMP库的并行for循环指令`#pragma omp parallel for`,将循环体内的变量`i`、`j`、`k`定义为私有变量,以避免并行计算时的数据竞争问题。这样,不同线程就可以独立计算不同的数,提高了程序的运行效率。
寻找水仙花数 C语言
寻找水仙花数是一个经典的编程题目,涉及到了数学的概念。水仙花数是指那些每一位数字的立方和等于其本身的三位数。例如,153就是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。
在C语言中,你可以编写一个函数来检查给定的整数是否是水仙花数。以下是一个简单的示例代码:
```c
#include <stdio.h>
// 函数定义
int is_armstrong(int num) {
int original_num, remainder, sum = 0;
original_num = num;
// 把数字分解并计算每个位的立方和
while (num != 0) {
remainder = num % 10; // 取余数得到最后一位
sum += pow(remainder, 3); // 立方并累加
num /= 10; // 移除最后一位
}
// 检查原数是否等于立方和
return (original_num == sum);
}
int main() {
int number, i;
printf("Enter a three-digit number to check for Armstrong number: ");
scanf("%d", &number);
if (is_armstrong(number)) {
printf("%d is an Armstrong number.\n", number);
} else {
printf("%d is not an Armstrong number.\n", number);
}
// 询问用户是否继续查找更多
printf("Do you want to check more numbers? (yes/no): ");
char response[10];
scanf("%s", response);
if(strcmp(response, "yes") == 0) {
for(i = number + 1; ; i++) { // 使用循环无限查找更大的水仙花数
if(is_armstrong(i)) {
printf("%d is also an Armstrong number.\n", i);
} else {
break;
}
}
}
return 0;
}
```
阅读全文