c语言水仙花数的编程
时间: 2023-11-20 15:50:38 浏览: 60
好的,C语言实现水仙花数的代码如下:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int num, sum, temp;
for (int i = 100; i <= 999; i++)
{
num = i;
sum = 0;
while (num > 0)
{
temp = num % 10;
sum += pow(temp, 3);
num /= 10;
}
if (sum == i)
{
printf("%d ", i);
}
}
return 0;
}
```
这段代码的思路是:从100到999遍历每个数,将每个数的每一位的立方和计算出来,如果等于这个数本身,则输出这个数。
相关问题
用c语言编程水仙花数
水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
下面是用C语言编程实现水仙花数的示例代码:
```c
#include <stdio.h>
#include <math.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 是一个水仙花数。\n", num);
else
printf("%d 不是一个水仙花数。\n", num);
return 0;
}
```
这段代码首先要求用户输入一个整数,然后计算该整数的位数。接下来,通过取余和除法运算,计算每个位上的数字的n次幂之和。最后,判断计算结果是否等于原始输入的整数,如果相等,则输出该整数是水仙花数,否则输出不水仙花数。
水仙花数代码编程c语言
以下是C语言实现水仙花数的代码:
```c
#include <stdio.h>
int main() {
int a, b, c, i;
printf("水仙花数有:\n");
for (i = 100; i <= 999; i++) {
a = i % 10; // 个位数
b = (i / 10) % 10; // 十位数
c = i / 100; // 百位数
if (i == a * a * a + b * b * b + c * c * c) {
printf("%d\t", i);
continue;
}
}
return 0;
}
```
该程序通过循环遍历100到999之间的所有整数,将每个整数的个位、十位、百位分别拆分,并求其立方和,判断是否等于该数本身,如果是则输出该数,否则继续循环。最终输出所有的水仙花数。