请用C++回答,题目描述 打印出所有"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该本身。 例如:153是一个水仙花数,因为153=1^3+5^3+3^3。 Output: 153 ??? ??? ??? 输入 无 输出 所有的水仙花数,从小的开始。 每行一个
时间: 2023-05-19 16:02:01 浏览: 78
以下是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;
}
输出结果为:
153
370
371
407
每行一个水仙花数,从小到大输出。
相关问题
用c++写一个判断一个三位数是否为“水仙花数”。所谓“水仙花数”是指一个三位数,其各位数字的立方各等于该数本身的程序
### 回答1:
#include<stdio.h>
#include<math.h>
int main(){
int num, sum = 0, temp;
printf("请输入一个三位数:");
scanf("%d", &num);
temp = num;
while(temp){
int digit = temp % 10;
sum += pow(digit, 3);
temp /= 10;
}
if(sum == num){
printf("%d是水仙花数。\n", num);
}else{
printf("%d不是水仙花数。\n", num);
}
return 0;
}
### 回答2:
要判断一个三位数是否为“水仙花数”,可以使用C语言来编写一个简单的程序。
首先,我们需要获取用户输入的三位数。可以使用scanf函数来实现,将用户输入的数保存在一个变量中。
接下来,我们需要对用户输入的三位数进行拆分,获取其中的个位、十位和百位数字。可以通过将十进制数除以10得到个位数,再将结果除以10得到十位数,再将结果除以10得到百位数。
然后,我们需要判断三位数是否为“水仙花数”。根据题目要求,各位数字的立方和应等于该数本身。可以使用if语句来进行判断。使用pow函数来计算各位数字的立方和,并将结果与用户输入的数进行比较。
最后,根据判断结果输出相应的提示信息。如果判断为真,则输出“是水仙花数”,否则输出“不是水仙花数”。
以下是一个简单的C语言程序示例:
```c
#include <stdio.h>
#include <math.h>
int main() {
int num, originalNum, remainder, result = 0, n = 3;
printf("请输入一个三位数:");
scanf("%d", &num);
originalNum = num;
while (originalNum != 0) {
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
if (result == num) {
printf("%d是水仙花数", num);
} else {
printf("%d不是水仙花数", num);
}
return 0;
}
```
这个程序会根据用户输入的三位数判断是否为“水仙花数”,并输出相应的提示信息。例如,用户输入153,则程序会输出“153是水仙花数”。
### 回答3:
#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;
}
以上是用C语言编写的一个判断一个三位数是否是水仙花数的程序。首先,用户输入一个三位数。然后,程序将输入的数值存储在变量num中,并将其赋值给变量originalNum备份。接下来,程序通过while循环对originalNum进行迭代,每次取出一个数位,并计算其立方值。最后,将所有数位的立方值相加,得到的结果存储在变量result中。
最后,程序通过比较result和num的值,判断该三位数是否是水仙花数。如果相等,则输出该数为水仙花数;否则,输出该数不是水仙花数。
水仙花数是指一个三位数,其个位、十位和百位数字的立方和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。
输出 按从小到大输出所有水仙花数,每个数占6个字符宽度c++
以下是C++代码实现:
```cpp
#include <iostream>
#include <iomanip> // 用于设置输出格式
using namespace std;
int main() {
for (int i = 100; i <= 999; i++) {
int a = i / 100;
int b = (i / 10) % 10;
int c = i % 10;
if (a * a * a + b * b * b + c * c * c == i) {
cout << setw(6) << i;
}
}
return 0;
}
```
解释一下代码:
首先,我们从 100 到 999 遍历所有的三位数。对于每个三位数,我们把它拆分成百位数、十位数和个位数。这里用到了整除和取余运算符。
接下来,我们判断这个三位数是否是水仙花数。如果是,我们就按照题目要求输出这个数,用 setw 函数来设置输出格式,确保每个数占6个字符宽度。
最后,我们返回 0,结束程序的执行。
阅读全文