AC

许诺  •  14天前


#include <iostream>
#include <vector>
#include <algorithm>

using namespace std; vector get_divisors(int m) {

vector<int> divisors;
for (int i = 2; i * i <= m; ++i) {
    if (m % i == 0) {
        divisors.push_back(i);
        if (i != m / i) {
            divisors.push_back(m / i);
        }
    }
}
sort(divisors.begin(), divisors.end());
if (m > 1) {
    divisors.push_back(m);
}
divisors.erase(unique(divisors.begin(), divisors.end()), divisors.end());
return divisors;

}

int main() {

int n;
cin >> n;
int m = n - 1;
vector<int> divisors = get_divisors(m);
for (size_t i = 0; i < divisors.size(); ++i) {
    if (i != 0) cout << " ";
    cout << divisors[i];
}
cout << endl;
return 0;

}


评论:

请先登录,才能进行评论