用c语言这一个水仙花数
时间: 2023-04-11 16:00:24 浏览: 96
我可以回答这个问题。水仙花数是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个水仙花数,因为1³+5³+3³=153。以下是用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 是一个水仙花数", num);
else
printf("%d 不是一个水仙花数", num);
return 0;
}
相关问题
用C语言写一个水仙花数
水仙花数是指一个n位数(n>=3),它的每个位上的数字的n次幂之和等于它本身。比如153就是一个三位数的水仙花数,因为1^3+5^3+3^3=153。下面是用C语言编写的一个水仙花数程序:
```c
#include <stdio.h>
int main() {
int num, originalNum, remainder, result = 0, n = 0;
printf("请输入一个三位数:");
scanf("%d", &num);
originalNum = num;
// 计算数字的位数
while (originalNum != 0) {
originalNum /= 10;
++n;
}
originalNum = num;
// 计算每个位上的数字的n次幂之和
while (originalNum != 0) {
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 判断是否为水仙花数
if (result == num)
printf("%d 是一个水仙花数", num);
else
printf("%d 不是一个水仙花数", num);
return 0;
}
```
注意:在上面的代码中,我们使用了 `pow()` 函数来计算一个数字的n次幂。需要包含头文件 `math.h` 才能使用该函数。
用c语言编写一个水仙花数
好的,水仙花数是指一个 n 位数 ( n ≥ 3 ),它的每个位上的数字的 n 次幂之和等于它本身。例如:153 = 1^3 + 5^3 + 3^3。
下面是一个用 C 语言编写的水仙花数判断程序:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int num, sum = 0, count = 0, temp;
printf("请输入一个三位数:");
scanf("%d", &num);
temp = num;
while (temp > 0)
{
count++;
temp /= 10;
}
temp = num;
while (temp > 0)
{
sum += pow(temp % 10, count);
temp /= 10;
}
if (num == sum)
{
printf("%d 是水仙花数\n", num);
}
else
{
printf("%d 不是水仙花数\n", num);
}
return 0;
}
```
这个程序首先让用户输入一个三位数,然后检查这个数是不是水仙花数。程序先用一个变量 `count` 记录这个数的位数,然后用一个循环计算出这个数的每一位的 n 次幂之和,如果和等于这个数本身,则说明这个数是水仙花数,否则不是。
阅读全文