写一个用c语言的水仙花数代码
时间: 2023-09-03 15:27:58 浏览: 227
### 回答1:
可以的,以下是用 C 语言编写的水仙花数代码:
#include <stdio.h>
#include <math.h>
int main()
{
int num, originalNum, remainder, n = ;
float result = .;
printf("请输入一个三位数: ");
scanf("%d", &num);
originalNum = num;
// 计算位数
while (originalNum != ) {
originalNum /= 10;
++n;
}
originalNum = num;
// 计算立方和
while (originalNum != ) {
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 判断是否为水仙花数
if ((int)result == num)
printf("%d 是水仙花数。", num);
else
printf("%d 不是水仙花数。", num);
return ;
}
### 回答2:
水仙花数指的是一个n位数,其各个位数上的数字的n次方之和等于它本身。以下是一个用C语言编写的水仙花数代码:
```
#include <stdio.h>
#include <math.h>
int main() {
int n, num, sum, digit, temp;
printf("请输入水仙花数的位数:");
scanf("%d", &n);
printf("水仙花数为:");
for (int i = pow(10, n-1); i < pow(10, n); i++) {
num = i;
sum = 0;
while (num != 0) {
digit = num % 10;
temp = pow(digit, n);
sum += temp;
num /= 10;
}
if (sum == i) {
printf("%d ", i);
}
}
return 0;
}
```
这段代码首先会要求用户输入水仙花数的位数n,然后通过循环从10^(n-1)开始遍历到10^n-1,对每个数的每一位进行幂运算,并将结果累加到sum变量中。最后,判断是否满足sum等于原始数值i,如果满足,则输出该数值。通过这样的循环遍历和条件判断,就可以找到所有的n位水仙花数。
### 回答3:
下面是用C语言编写的水仙花数代码:
```c
#include <stdio.h>
int main() {
int num, originalNum, remainder, result = 0;
printf("请输入一个数字:");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0) {
remainder = originalNum % 10;
result += remainder * remainder * remainder;
originalNum /= 10;
}
if (result == num) {
printf("%d是一个水仙花数。\n", num);
} else {
printf("%d不是一个水仙花数。\n", num);
}
return 0;
}
```
程序会要求用户输入一个数字,并逐位计算各个位数的立方和。如果计算结果与输入的数字相等,则说明该数字是水仙花数,否则不是。水仙花数是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1³ + 5³ + 3³ = 153。
阅读全文