n位水仙花数c语言程序
时间: 2024-01-07 11:20:14 浏览: 23
以下是一个求解n位水仙花数的C语言程序:
```
#include <stdio.h>
#include <math.h>
int main() {
int n;
scanf("%d", &n);
int start = pow(10, n-1);
int end = pow(10, n) - 1;
for (int i = start; i <= end; i++) {
int sum = 0;
int temp = i;
while (temp > 0) {
int digit = temp % 10;
sum += pow(digit, n);
temp /= 10;
}
if (sum == i) {
printf("%d\n", i);
}
}
return 0;
}
```
程序首先读入n,然后计算出n位数的取值范围。接着,程序遍历这个范围内的所有数,对于每个数,程序计算出它各个位数上的数字的n次幂之和,如果这个和等于这个数本身,那么这个数就是一个n位水仙花数,程序就输出它。
相关问题
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次幂之和是否等于该整数,如果相等则输出该整数是水仙花数,否则输出不是水仙花数。
水仙花数c语言程序
以下是求解水仙花数的C语言程序:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int n, num, sum, i;
printf("请输入一个三位数:");
scanf("%d", &n);
printf("该数的水仙花数有:\n");
for (i = 100; i <= n; i++)
{
num = i;
sum = 0;
while (num != 0)
{
sum += pow(num % 10, 3);
num /= 10;
}
if (sum == i)
{
printf("%d\n", i);
}
}
return 0;
}
```
该程序先让用户输入一个三位数,然后从100到该数之间进行遍历,对于每个数,求出它各个数位的立方和,若等于该数本身,则输出。