用C++写出一段代码,计算输出所有三位数中的水仙花数。水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。(例如:13 + 53 + 33 = 153)。
时间: 2023-11-15 12:06:36 浏览: 79
以下是用C++语言编写的计算输出所有三位数中的水仙花数的代码:
```c++
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
for(int i = 100; i < 1000; i++)
{
int sum = pow(i / 100, 3) + pow(i / 10 % 10, 3) + pow(i % 10, 3);
if(sum == i)
{
cout << i << " ";
}
}
return 0;
}
```
代码中,我们使用了 `for` 循环遍历所有三位数。在循环内部,我们使用 `pow()` 函数计算出每个位上的数字的三次幂之和,并将其存储在 `sum` 变量中。如果 `sum` 等于这个三位数本身,就说明这个数是水仙花数,将其输出即可。
相关问题
水仙花数c++ 一个n位数
水仙花数是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。在C++中,可以通过循环和取余运算来判断一个数是否为水仙花数。具体实现可以参考以下代码:
```
#include <iostream>
#include <cmath>
using namespace std;
int main() {
int n, num, sum, digit;
cout << "请输入一个n位数:";
cin >> n;
num = pow(10, n-1); // 计算n位数的最小值
while (num < pow(10, n)) {
sum = 0;
int temp = num;
while (temp != 0) {
digit = temp % 10;
sum += pow(digit, n);
temp /= 10;
}
if (sum == num) {
cout << num << "是水仙花数" << endl;
}
num++;
}
return 0;
}
```
这段代码可以判断一个n位数是否为水仙花数,并输出所有的水仙花数。其中,使用了pow函数来计算幂次方,使用了循环和取余运算来计算每个位上的数字,并使用了if语句来判断是否为水仙花数。
写一个C++程序:输出所有的“水仙花数”,所谓“水仙花数”是指一个3 位数,其各位数字立方和等于该数本身。例如,153 是一水仙花数
。这是一个简单的 C 语言程序,用于打印所有的“水仙花数”:
```
#include <stdio.h>
int main() {
int i, j, k, n;
for (n = 100; n < 1000; n++) {
i = n / 100; // 计算百位
j = (n / 10) % 10; // 计算十位
k = n % 10; // 计算个位
if (i * i * i + j * j * j + k * k * k == n) {
printf("%d\n", n); // 打印该数
}
}
return 0;
}
```
该程序使用 for 循环遍历所有的三位数,分别计算其百位、十位和个位数字。然后,它检查该数是否是“水仙花数”,即它的立方和是否等于该数本身。如果是,则打印该数。
阅读全文