c++实现所有的水仙花数
时间: 2024-10-25 22:14:10 浏览: 0
水仙花数是指一个三位数,其各位数字立方之和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。在 C++ 中实现所有水仙花数的一种简单方法是遍历从100到999之间的整数,然后检查每个数是否满足条件。
以下是用 C++ 实现的代码示例:
```cpp
#include <iostream>
#include <vector>
bool is_armstrong_number(int num) {
int original_num, remainder, sum = 0;
original_num = num;
// 将数字转换成字符串以便逐位处理
std::string str_num = std::to_string(num);
// 获取数字的位数,因为是三位数
int digits_count = str_num.length();
// 计算每一位的立方和
for (int i = 0; i < digits_count; ++i) {
remainder = str_num[i] - '0'; // 转换字符到数值
sum += remainder * remainder * remainder;
}
return num == sum;
}
// 打印所有水仙花数
void print_armstrong_numbers() {
for (int i = 100; i <= 999; ++i) {
if (is_armstrong_number(i)) {
std::cout << i << " ";
}
}
std::cout << std::endl;
}
int main() {
print_armstrong_numbers();
return 0;
}
```
当你运行这个程序时,它会打印出所有的水仙花数:153, 370, 371, 407.
阅读全文