找出所有水仙花数c++
时间: 2024-11-05 12:33:58 浏览: 6
水仙花数是一种特殊的整数,其各位数字立方之和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。在C++中,你可以编写一个程序来找出所有的3位数水仙花数。下面是一个简单的示例:
```cpp
#include <iostream>
#include <vector>
bool is narcissistic(int num) {
int sum = 0;
while (num > 0) {
int digit = num % 10;
sum += std::pow(digit, 3);
num /= 10;
}
return sum == num;
}
int main() {
std::vector<int> narcissistic_numbers;
for (int i = 100; i <= 999; ++i) {
if (is_narcissistic(i)) {
narcissistic_numbers.push_back(i);
}
}
std::cout << "3位数的水仙花数有:" << std::endl;
for (const auto &number : narcissistic_numbers) {
std::cout << number << std::endl;
}
相关问题
输出所有水仙花数c++代码
以下是输出所有水仙花数的 C++ 代码:
```c++
#include <iostream>
using namespace std;
int main() {
int num, sum, temp;
for (int i = 100; i <= 999; i++) {
num = i;
sum = 0;
while (num > 0) {
temp = num % 10;
sum += temp * temp * temp;
num /= 10;
}
if (sum == i) {
cout << i << " ";
}
}
return 0;
}
```
这段代码可以输出所有三位数的水仙花数。
c++输出所有水仙花数
水仙花数是指一个 n 位正整数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。
例如:1³ + 5³ + 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 (n == i * i * i + j * j * j + k * k * k) {
printf("%d\n", n);
}
}
return 0;
}
阅读全文