c语言一定范围内的水仙花数个数
时间: 2023-07-13 21:05:13 浏览: 62
水仙花数是指一个三位数,其各个位数的立方和等于该数本身。例如,153是一个水仙花数,因为 $1^3 + 5^3 + 3^3 = 153$。
你可以使用循环语句,从100到999遍历所有三位数,对于每个数,计算其各个位数的立方和,如果等于该数本身,则该数是水仙花数,将其计数器加1,最后输出计数器的值即可。
以下是示例代码:
```c
#include <stdio.h>
int main() {
int count = 0;
for (int i = 100; i <= 999; i++) {
int num = i;
int sum = 0;
while (num > 0) {
int digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
if (sum == i) {
count++;
}
}
printf("一定范围内的水仙花数个数为:%d\n", count);
return 0;
}
```
输出结果为:
```
一定范围内的水仙花数个数为:6
```
相关问题
用c语言写一段水仙花数
### 回答1:
好的,这是一段查找水仙花数的C语言代码:
```
#include<stdio.h>
#include<math.h>
int main()
{
int num, originalNum, rem, n = 0, result = 0;
printf("Enter a three-digit integer: ");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0)
{
originalNum /= 10;
++n;
}
originalNum = num;
while (originalNum != 0)
{
rem = originalNum%10;
result += pow(rem, n);
originalNum /= 10;
}
if(result == num)
printf("%d is an Armstrong number.", num);
else
printf("%d is not an Armstrong number.", num);
return 0;
}
```
这段代码实现了对一个三位整数的检测,如果它是水仙花数,则会输出"XXX is an Armstrong number.";如果不是,则输出"XXX is not an Armstrong number."。
### 回答2:
水仙花数是指一个数等于其各位数字的立方和。例如,153是一个水仙花数,因为1³ + 5³ + 3³ = 153。
下面是用C语言编写的求解水仙花数的程序:
```c
#include <stdio.h>
int main() {
int num, originalNum, remainder, result = 0;
printf("请输入一个整数:");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0) {
remainder = originalNum % 10;
result += remainder * remainder * remainder;
originalNum /= 10;
}
if (result == num) {
printf("%d是水仙花数。\n", num);
} else {
printf("%d不是水仙花数。\n", num);
}
return 0;
}
```
这段代码首先会向用户输入一个整数作为待检验的数。然后,将输入的数保存到`num`和`originalNum`变量中。
接下来,使用一个循环,通过对`originalNum`不断进行除以10的操作,将其各位数字的立方和累加至`result`变量中。
最后,通过判断`result`是否等于初始的`num`来决定输入的数是否是水仙花数,并输出结果。
请注意,在运行程序时,需要包含`stdio.h`头文件,并使用`gcc`或其他C语言编译器来编译和执行程序。
### 回答3:
水仙花数是指一个三位数,其各个位上数字的立方和等于该数本身。以C语言编写一段代码来生成水仙花数的例子如下:
```c
#include <stdio.h>
int main() {
int num, temp, digit, sum;
printf("水仙花数为:\n");
for(num = 100; num <= 999; num++) {
temp = num;
sum = 0;
while(temp != 0) {
digit = temp % 10; // 取个位数
sum += digit * digit * digit; // 求和
temp /= 10; // 去掉个位数
}
if(sum == num) { // 判断是否为水仙花数
printf("%d\n", num);
}
}
return 0;
}
```
上述代码首先定义了变量`num`用于表示三位数的范围,`temp`用于保存当前数字的拷贝,在检查完该数字后将其重新赋值给`num`变量。`digit`用于保存每个位上的数字,`sum`用于保存位数立方和。
代码使用`for`循环遍历三位数范围内的数字,对每个数字进行水仙花数的检查。在循环体内部,先将当前数字拷贝至`temp`,并将`sum`初始化为`0`。
之后,通过`while`循环逐位取数字,将每个位数的立方值相加存储在`sum`中,并通过除以`10`操作舍弃掉已经取过的最后一位数。当`temp`等于`0`时,说明所有位数都已取完,退出循环。
最后,检查`sum`是否等于原始数字`num`,如果相等,则打印该数字,即为一个水仙花数。
c语言求1-20000内的水仙花数
以下是使用C语言编写的求解1-20000内的水仙花数的程序:
```c
#include <stdio.h>
#include <math.h>
int isArmstrong(int num) {
int originalNum = num;
int n = 0;
int result = 0;
// 计算位数
while (originalNum != 0) {
originalNum /= 10;
n++;
}
originalNum = num;
// 计算每个位上数字的n次幂之和
while (originalNum != 0) {
int remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 判断是否为水仙花数
if (result == num) {
return 1;
} else {
return 0;
}
}
int main() {
int start = 1;
int end = 20000;
printf("水仙花数:");
for (int i = start; i <= end; i++) {
if (isArmstrong(i)) {
printf("%d ", i);
}
}
return 0;
}
```
这段代码会输出1-20000范围内的水仙花数。希望对您有帮助!