用c语言写一个计算水仙花数的代码
时间: 2024-06-06 13:06:58 浏览: 93
#include <stdio.h>
#include <math.h>
int main()
{
int n, i, sum, num;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("n以内的水仙花数有:");
for(i = 1; i <= n; i++)
{
sum = 0;
num = i;
while(num > 0)
{
sum += pow(num % 10, 3);
num /= 10;
}
if(sum == i)
{
printf("%d ", i);
}
}
printf("\n");
return 0;
}
相关问题
用c语言写出1000以内水仙花数第一个整数
水仙花数是指一个三位数,其各位数字的立方和等于该数本身。例如,153就是水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。在C语言中,我们可以编写一个简单的循环来找出1000以内的第一个水仙花数。下面是一个简单的示例:
```c
#include <stdio.h>
#include <math.h>
int main() {
for (int num = 100; num <= 999; ++num) { // 遍历100到999
int digits[3];
int sum = 0;
// 分离数字并计算立方和
digits[0] = num / 100;
digits[1] = (num % 100) / 10;
digits[2] = num % 10;
sum = pow(digits[0], 3) + pow(digits[1], 3) + pow(digits[2], 3);
// 如果和等于原数,找到了水仙花数
if (sum == num)
break;
}
if (num != 0) {
printf("1000以内的第一个水仙花数是:%d\n", num);
} else {
printf("1000以内没有水仙花数。\n");
}
return 0;
}
```
运行这段代码后,你会得到1000以内的第一个水仙花数。
用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` 才能使用该函数。
阅读全文