제출 #1353684

#제출 시각아이디문제언어결과실행 시간메모리
1353684cnam9Toys (CEOI18_toy)C++20
100 / 100
182 ms16984 KiB
#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

vector<int> divisors;
vector<int> answer;

void recur(int n, int it, int s) {
    answer.push_back(s + n - 1);
    for (; it < divisors.size(); it++) {
        int d = divisors[it];
        if (d * d > n) break;
        if (n % d) continue;
        recur(n / d, it, s + d - 1);
    }
}

signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);

    // freopen("input.txt", "r", stdin);

    int n;
    cin >> n;

    for (int d = 1; d * d <= n; d++) {
        if (n % d == 0) {
            divisors.push_back(d);
            if (d * d < n) {
                divisors.push_back(n / d);
            }
        }
    }
    sort(divisors.begin(), divisors.end());
    recur(n, 1, 0);

    sort(answer.begin(), answer.end());
    auto end = unique(answer.begin(), answer.end());

    cout << end - answer.begin() << '\n';
    for (auto it = answer.begin(); it != end; ++it) {
        cout << *it << ' ';
    }

    return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...