设计C++程序:输出100到1000以内是“水仙花数”的所有三位数。水仙花数是指三位数的各位数字的立方和等于这个三位数本身。例如:153=111+555+333
时间: 2024-05-04 20:15:36 浏览: 14
以下是C程序的实现:
```c
#include <stdio.h>
int main()
{
int i, j, k, n;
for(n=100; n<=999; n++)
{
i = n / 100; // 获取百位数
j = n / 10 % 10; // 获取十位数
k = n % 10; // 获取个位数
if(n == i*i*i + j*j*j + k*k*k) // 判断是否为水仙花数
{
printf("%d\n", n); // 输出水仙花数
}
}
return 0;
}
```
希望对您有所帮助。
相关问题
用c++程序写判断一个三位数是否是水仙花数
### 回答1:
好的,以下是用C语言写判断一个三位数是否是水仙花数的示例代码:
```c
#include <stdio.h>
#include <math.h>
int main()
{
int num, originalNum, remainder, n = 0;
double result = 0.0;
printf("请输入一个三位数:");
scanf("%d", &num);
originalNum = num;
// 求出位数
while (originalNum != 0)
{
originalNum /= 10;
++n;
}
originalNum = num;
// 计算立方和
while (originalNum != 0)
{
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 检查是否为水仙花数
if ((int)result == num)
printf("%d 是水仙花数", num);
else
printf("%d 不是水仙花数", num);
return 0;
}
```
注意,这只是一个示例代码,实际上,判断一个三位数是否是水仙花数还有其他的方法,可以通过数学计算得到更简单的算法。
### 回答2:
水仙花数是指一个三位数,其各个位上数字的立方和等于该数本身。例如153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。下面是用C语言编写的程序来判断一个三位数是否是水仙花数:
```c
#include <stdio.h>
int main() {
int number, originalNumber, remainder, result = 0;
printf("请输入一个三位数: ");
scanf("%d", &number);
originalNumber = number;
while (originalNumber != 0) {
remainder = originalNumber % 10;
result += remainder * remainder * remainder;
originalNumber /= 10;
}
if (result == number) {
printf("%d是水仙花数。\n", number);
} else {
printf("%d不是水仙花数。\n", number);
}
return 0;
}
```
这个程序首先会要求用户输入一个三位数,然后通过一个while循环将输入的数字分解为各个位上的数字,并将其立方和保存在result变量中。最后,通过判断result是否等于原始的三位数number来确定该数字是否是水仙花数。如果是,程序会输出该数字是水仙花数;如果不是,程序会输出该数字不是水仙花数。
### 回答3:
水仙花数是指一个三位数,它的各位数字的立方和等于该数本身。例如,153是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
在C程序中,可以使用以下代码来判断一个三位数是否是水仙花数:
```c
#include <stdio.h>
#include <math.h>
int main() {
int num, originalNum, remainder, result = 0;
printf("请输入一个三位数:");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0) {
remainder = originalNum % 10;
result += pow(remainder, 3);
originalNum /= 10;
}
if (result == num) {
printf("%d 是一个水仙花数。\n", num);
} else {
printf("%d 不是一个水仙花数。\n", num);
}
return 0;
}
```
这段代码中,我们首先从用户输入中获取一个三位数。然后,我们将原始数存储在变量 `originalNum` 中,以防止在计算过程中失去对原始数的引用。通过 while 循环,我们将原始数按位拆解,并将每位数字的立方加到 `result` 中。最后,我们将 `result` 与原始数 `num` 进行比较,如果相等,则输出该数是水仙花数,否则输出该数不是水仙花数。
用c++完成:输出所有的“水仙花数”,水仙花数是指一个三位数,其各位数字立方和等于其本身。
Sure, 我可以很轻松地给您展示如何用C语言输出所有水仙花数:
#include <stdio.h>
#include <math.h>
// 定义函数,用于判断一个数是否是水仙花数
int isArmstrong(int num) {
int temp = num;
int sum = 0;
int n = 0;
while (temp > 0) {
temp /= 10;
n++;
}
temp = num;
while (temp > 0) {
int remainder = temp % 10;
sum += pow(remainder, n);
temp /= 10;
}
return sum == num;
}
int main() {
for (int i = 100; i < 1000; i++) {
if (isArmstrong(i)) {
printf("%d ", i);
}
}
return 0;
}
希望这可以帮到您!
相关推荐
![cpp](https://img-home.csdnimg.cn/images/20210720083646.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)