找出1000以内所有完数c++,并使所有因子相加
时间: 2023-08-11 18:42:49 浏览: 115
Java找出1000以内的所有完数
5星 · 资源好评率100%
以下是C++代码实现:
```c++
#include <iostream>
using namespace std;
int main() {
for (int i = 1; i <= 1000; ++i) {
int sum = 0;
for (int j = 1; j < i; ++j) {
if (i % j == 0) {
sum += j;
}
}
if (sum == i) {
cout << i << "的因子有:";
for (int j = 1; j < i; ++j) {
if (i % j == 0) {
cout << j << " ";
}
}
cout << endl;
}
}
return 0;
}
```
输出结果如下:
```
6的因子有:1 2 3
28的因子有:1 2 4 7 14
496的因子有:1 2 4 8 16 31 62 124 248
```
代码中,我们首先遍历1到1000之间的所有整数i,然后对于每个i,我们遍历1到i-1之间的所有整数j,找出i的所有因子并累加它们的和。如果这个和等于i,那么i就是完数,输出它的因子即可。
阅读全文