c语言输入3位数判断水仙花
时间: 2023-07-27 14:12:37 浏览: 58
判断一个三位数是否为水仙花数,需要将这个三位数拆分成个位、十位和百位,然后判断其是否满足以下条件:各个位上的数字的立方和等于该数本身。
下面是一个简单的C语言程序实现:
```c
#include <stdio.h>
int main()
{
int num, digit, sum = 0;
printf("请输入一个三位数:");
scanf("%d", &num);
digit = num % 10; // 取个位数
sum += digit * digit * digit;
num /= 10;
digit = num % 10; // 取十位数
sum += digit * digit * digit;
num /= 10;
digit = num % 10; // 取百位数
sum += digit * digit * digit;
if (sum == num) // 判断是否为水仙花数
{
printf("%d 是水仙花数。\n", num);
}
else
{
printf("%d 不是水仙花数。\n", num);
}
return 0;
}
```
在程序中,首先从用户输入中获取一个三位数,然后分别取出个位、十位和百位上的数字,计算它们的立方和,最后判断是否等于原来的三位数。如果等于,则输出“是水仙花数”,否则输出“不是水仙花数”。
相关问题
用C语言打印四位数的水仙花数
好的,下面是用C语言打印四位数的水仙花数的代码:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int i, n, m;
for (i = 1000; i < 10000; i++)
{
n = i / 100;
m = i % 100;
if (i == pow(n, 3) + pow(m, 3))
printf("%d\n", i);
}
return 0;
}
```
这个程序可以打印出所有的四位数水仙花数。具体方法是,遍历所有四位数,将其分成两部分,分别计算每一部分的立方和,如果两部分的立方和加起来等于这个数本身,则说明这个数是水仙花数,打印出来即可。
n位数水仙花数判断c语言
水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身,例如:153 = 1³ + 5³ + 3³。
以下是一个判断n位数是否为水仙花数的C语言代码:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int num, originalNum, remainder, n = 0, result = 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 是水仙花数。\n", num);
else
printf("%d 不是水仙花数。\n", num);
return 0;
}
```
该程序首先输入一个整数,然后计算出该整数的位数n,然后计算n次幂之和。最后判断n次幂之和是否等于该整数,如果相等则输出该整数是水仙花数,否则输出不是水仙花数。