c++编程输出所有的水仙花数
时间: 2024-04-25 20:18:03 浏览: 11
水仙花数是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。在C++编程中,可以使用循环和条件判断来输出所有的水仙花数。以下是一个示例代码:
```cpp
#include <iostream>
#include <cmath>
int main() {
int n; // 位数
std::cout << "请输入位数n:";
std::cin >> n;
int start = pow(10, n - 1); // 起始数
int end = pow(10, n) - 1; // 结束数
for (int num = start; num <= end; num++) {
int sum = 0;
int temp = num;
while (temp != 0) {
int digit = temp % 10;
sum += pow(digit, n);
temp /= 10;
}
if (sum == num) {
std::cout << num << " ";
}
}
return 0;
}
```
运行以上代码,输入位数n后,程序会输出该位数范围内的所有水仙花数。
相关问题
使用c++编程输出所有水仙花数
好的,这是一个技术问题,我可以回答。以下是使用 C++ 编程输出所有水仙花数的代码:
```
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
int num, temp, sum;
for(num = 100; num < 1000; num++)
{
temp = num;
sum = 0;
while(temp > 0)
{
int remainder = temp % 10;
sum += pow(remainder, 3);
temp /= 10;
}
if(sum == num)
{
cout << num << endl;
}
}
return 0;
}
```
执行这个程序,会输出所有 3 位水仙花数。
c++输出所有水仙花数
好的,以下是输出所有水仙花数的C代码:
```
#include <stdio.h>
int main() {
int i, j, k, num;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d ", num);
}
}
}
}
return 0;
}
```
这个程序会输出所有三位数中的水仙花数,即各个位数的立方之和等于这个数本身的数字。如153就是一个水仙花数,因为 $1^3 + 5^3 + 3^3 = 153$。