This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
/*
DavitMarg
In a honky-tonk,
Down in Mexico
*/
#include <iostream>
#include <algorithm>
#include <cmath>
#include <vector>
#include <string>
#include <cstring>
#include <map>
#include <unordered_map>
#include <set>
#include <unordered_set>
#include <queue>
#include <random>
#include <bitset>
#include <stack>
#include <cassert>
#include <iterator>
#define mod 1000000007ll
#define LL long long
#define LD long double
#define MP make_pair
#define PB push_back
#define all(v) v.begin(), v.end()
#define fastIO ios::sync_with_stdio(false); cin.tie(0)
using namespace std;
const int N = 1005;
int n;
set<int> ans;
map<int, set<int>> dp[N];
map<int, int> used[N];
set<int> add(set<int> a,int d)
{
set<int> s;
for (auto it = a.begin(); it != a.end(); ++it)
s.insert(*it + d);
return s;
}
void add(set<int> &a, set<int> b)
{
a.insert(all(b));
}
int sq(int x)
{
return sqrt(x);
}
void dfs(int num, int mx)
{
if (mx > num)
{
used[mx][num] = used[num][num];
dp[mx][num] = dp[num][num];
}
if (used[mx][num])
return;
used[mx][num] = 1;
for (int i = 1; i * i <= num; i++)
{
if (num % i)
continue;
if (i <= mx && i != 1)
{
dfs(num / i, min(i,num/i));
add(dp[mx][num], add(dp[min(i, num / i)][num / i], i - 1));
}
if (num / i <= mx && i != num / i)
{
dfs(i, min(i, num / i));
add(dp[mx][num], add(dp[min(i, num / i)][i], num/i - 1));
}
}
}
int main()
{
fastIO;
cin >> n;
used[1][1] = 1;
dp[1][1].insert(0);
for (int i = 1; i * i <= n; i++)
{
if (n % i)
continue;
int P = i;
for (int j = 1; j * j <= n / P; j++)
{
if ((n / P) % j)
continue;
int p = j;
if (p != 1 && p <= P)
{
dfs(n / P / p, min(p, n / P / p));
add(ans, add(dp[min(p, n / P / p)][n / P / p], P + p - 2));
}
p = n / P / p;
if (p != 1 && p <= P)
{
dfs(n / P / p, min(p, n / P / p));
add(ans, add(dp[min(p, n / P / p)][n / P / p], P + p - 2));
}
}
P = n / P;
if (P * P == n)
continue;
for (int j = 1; j * j <= n / P; j++)
{
if ((n / P) % j)
continue;
int p = j;
if (p != 1 && p <= P)
{
dfs(n / P / p, min(p, n / P / p));
add(ans, add(dp[min(p, n / P / p)][n / P / p], P + p - 2));
}
p = n / P / p;
if (p != 1 && p <= P)
{
dfs(n / P / p, min(p, n / P / p));
add(ans, add(dp[min(p, n / P / p)][n / P / p], P + p - 2));
}
}
}
ans.insert(n - 1);
cout << ans.size() << endl;
for (auto it = ans.begin(); it != ans.end(); ++it)
cout << (*it) << " ";
cout << endl;
return 0;
}
/*
100000000
67108864
3
1 2
1 3
*/
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |