Submission #493256

#TimeUsernameProblemLanguageResultExecution timeMemory
493256blueToys (CEOI18_toy)C++17
79 / 100
5032 ms93232 KiB
#include <iostream>
#include <vector>
#include <set>
#include <algorithm>
#include <map>
#include <cassert>
#include <unordered_set>
using namespace std;
 
#define sz(x) (int(x.size()))
using vi = vector<int>;
using ll = long long;
 
// map< int, vector<int> > res;
 
vi sf;
 
long long n;
 
unordered_set<int> res[40'000]; //i*i <= n
unordered_set<int> res2[40'000]; //i*i >= n, access n/i.
 
vi solved(1+40'000, 0);
vi solved2(1+40'000, 0);
 
vector<int> factors[40'000];
vector<int> factors2[40'000];
 
unordered_set<int>& get_res(long long u)
{
    if(u*u <= n) return res[u];
    else return res2[n/u];
}
 
vector<int>& get_factors(long long u)
{
    if(u*u <= n) return factors[u];
    else return factors2[n/u];
}
 
int& get_solved(long long u)
{
    if(u*u <= n) return solved[u];
    else return solved2[n/u];
}
 
 
 
void solve(long long i)
{
    get_res(i).insert(i-1);
 
    for(ll j: get_factors(i))
    {
        // cerr << "j = " << j << '\n';
        if(j >= i || j*j > i) break;
            // cerr << i << " -> " << j << '\n';
        long long u = j;
        long long v = i/j;
        for(int a: get_res(u))
        {
            for(int b: get_res(v))
            {
                // if(b > a) break;
                get_res(i).insert(a+b);
            }
        }
 
    }
}
 
int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
 
    cin >> n;
 
    if(n == 1)
    {
        cout << "1\n 0\n";
        return 0;
    }
 
 
 
    for(int i = 2; i < n; i++)
    {
        // cerr << i << " " << n%i << ' ' << int(n%i == 0) << '\n';
        if(i*i > n) break;
        if(n % i == 0)
        {
            sf.push_back(i);
            sf.push_back(n/i);
        }
    }
 
    // for(int i = 2; i <= n; i++)
    // {
    //     // cerr << i << " " << n%i << ' ' << int(n%i == 0) << '\n';
    //     if(n % i == 0)
    //         sf.push_back(i);
    // }
 
    sf.push_back(n);
 
    sort(sf.begin(), sf.end());
    sf.erase(unique(sf.begin(), sf.end()), sf.end());
 
    // for(int q: sf) cerr << q << ' ';
    // cerr << '\n';
 
    for(int a: sf)
        for(int b: sf)
            if(a < b && b%a==0)
                get_factors(b).push_back(a);
 
 
    for(int a: sf) solve(a);
    unordered_set<int> ans = get_res(n);
    set<int> A;
  for(int a: ans) A.insert(a);
 
    // cerr << "sf init = " ;
    // for(int q: sf) cerr << q << " ";
    // cerr << "\n";
 
 
    cout << sz(A) << '\n';
    for(int r: A) cout << r << ' ';
    cout << '\n';
}
#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...