打印1000以内的所有水仙花数 C语言
时间: 2023-03-12 11:44:44 浏览: 81
我们可以使用以下C语言程序来打印1000以内的所有水仙花数:
#include <stdio.h>
int main()
{
int num, temp, digit, sum = 0;
printf("打印1000以内的所有水仙花数:\n");
for(num = 100; num <= 1000; num++)
{
temp = num;
while(temp != 0)
{
digit = temp % 10;
sum = sum + digit * digit * digit;
temp = temp / 10;
}
if(sum == num)
{
printf("%d ", num);
}
sum = 0;
}
return 0;
}
相关问题
水仙花数c语言程序用自定义函数
水仙花数是指一个三位数,其各位数字的立方和等于该数本身。
要用C语言编写一个水仙花数的程序,可以使用自定义函数来判断一个三位数是否为水仙花数。
首先,定义一个自定义函数,命名为isNarcissusNumber,函数接收一个整数参数num,表示要判断的三位数。
在函数内部,我们可以使用取余和整除操作来获取该三位数的各位数字。
具体步骤如下:
1. 首先,声明一个变量sum并初始化为0,用来存储各位数字的立方和。
2. 使用取余操作获取num的个位数字,将其立方后加到sum中。
3. 使用整除操作将num除以10,以便获取十位数字。
4. 重复步骤2和3,获取百位数字,并将其立方后加到sum中。
5. 判断sum是否等于num,如果相等,则说明该三位数为水仙花数,返回1;否则,返回0。
以下是水仙花数的C语言程序示例:
```c
#include <stdio.h>
int isNarcissusNumber(int num) {
int sum = 0;
int digit;
int originalNum = num;
while (num > 0) {
digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
if (sum == originalNum) {
return 1;
} else {
return 0;
}
}
int main() {
for (int i = 100; i < 1000; i++) {
if (isNarcissusNumber(i)) {
printf("%d是水仙花数\n", i);
}
}
return 0;
}
```
上述程序中的main函数通过循环遍历100到999之间的所有三位数,将每个数传入isNarcissusNumber函数进行判断,如果是水仙花数,则在终端上打印出来。
用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以内的水仙花数。