用C语言找出1000以内的水仙花数
时间: 2023-07-04 07:22:42 浏览: 59
水仙花数是指一个n位正整数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153就是一个水仙花数,因为1的3次方+5的3次方+3的3次方=153。
可以使用以下代码来找出1000以内的水仙花数:
```c
#include <stdio.h>
int main()
{
int i, j, k, num;
for(i = 1; i < 10; i++)
{
for(j = 0; j < 10; j++)
{
for(k = 0; k < 10; k++)
{
num = i * 100 + j * 10 + k;
if(num == i*i*i + j*j*j + k*k*k)
{
printf("%d ", num);
}
}
}
}
return 0;
}
```
这段代码使用三层循环,枚举所有的三位数。对于每个三位数,判断它是否是水仙花数,如果是就输出。最终输出的结果为153、370、371和407。
相关问题
用C语言写出1000以内的水仙花数的代码
### 回答1:
以下是一段简单的 C 语言代码,可以输出 1000 以内的水仙花数: #include <stdio.h>int main()
{
int i, j, k;
printf("1000以内的水仙花数有: \n");
for (i = 1; i < 10; i++)
{
for (j = 0; j < 10; j++)
{
for (k = 0; k < 10; k++)
{
int n = i * 100 + j * 10 + k;
if (i * i * i + j * j * j + k * k * k == n)
{
printf("%d\n", n);
}
}
}
}
return 0;
}
### 回答2:
#include <stdio.h>
int main()
{
int num, remainder, sum;
printf("1000以内的水仙花数有:\n");
for(num = 100; num <= 999; num++)
{
sum = 0;
int temp = num;
while(temp != 0)
{
remainder = temp % 10;
sum += remainder * remainder * remainder;
temp /= 10;
}
if(num == sum)
{
printf("%d ", num);
}
}
return 0;
}
这段代码使用C语言编写以找到1000以内的水仙花数。所谓水仙花数,指的是一个三位数,它的各个位上的数字的立方和等于它本身。
代码中的for循环从100循环到999,即遍历所有三位数。然后,使用while循环将当前数的每位进行拆分计算,并将求和的结果保存在变量sum中。在while循环中,使用取模运算获得每位的数字,并将结果累加到sum中,同时使用整除运算将temp除以10的整数部分等于将temp的末位去掉,以便于下一次循环。
最后,判断如果当前数num等于sum,则输出num,即找到了一个水仙花数。循环结束后,程序会输出1000以内的所有水仙花数。
### 回答3:
水仙花数是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。换句话说,如果一个n位数等于其每个数字的n次幂之和,则称该数为水仙花数。
以下是用C语言编写的打印出1000以内的水仙花数的代码:
#include<stdio.h>
#include<math.h>
int main()
{
int number, originalNumber, remainder, result = 0, n = 0;
printf("1000以内的水仙花数有:\n");
for(number = 1; number <= 1000; number++)
{
originalNumber = number;
while (originalNumber != 0)
{
originalNumber /= 10;
n++;
}
originalNumber = number;
while(originalNumber != 0)
{
remainder = originalNumber % 10;
result += pow(remainder, n);
originalNumber /= 10;
}
if(result == number)
{
printf("%d\n", number);
}
result = 0; // 重置变量
n = 0; // 重置变量
}
return 0;
}
编译并运行上述代码,就可以输出1000以内的水仙花数。在屏幕上显示的水仙花数如下所示:
153
370
371
407
这些数字正好是1000以内的水仙花数。
用C语言找出三位水仙花数
#include <stdio.h>
int main() {
int i, j, k;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
int num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}