/* Zadanie: Wersja dla profesjonalistów Autor: Tomasz Kwiatkowski */ #include <bits/stdc++.h> #define fi first #define se second #define pb push_back using namespace std; typedef long long ll; const int MAXN = 1e6 + 7; const int INF = 1e9 + 7; string rep(string s, long long k, int st = 2) { if (k == 0) return ""; if (k == 1) return s; if (k <= 9) return string{k + '0'} + '[' + s + ']'; string res = ""; for (int i = 9; i >= st; --i) { if (k % i == 0) { string tmp = rep(s, k / i, i); if ((res.empty() && tmp.size()) || (tmp.size() && (3 + tmp.size() < res.size()))) { res = string{i + '0'} + '[' + tmp + ']'; } } //if (res.size()) break; } if (res.size()) return res; return string{9 + '0'} + '[' + rep(s, k / 9) + ']' + rep(s, k % 9); } string rot(string s, int r) { string res = ""; for (auto c : s) { if ('A' <= c && c <= 'F') res += (char)('A' + (c - 'A' + r) % 6); else res += c; } return res; } string solve(long long n, int r) { if (n == 1) return rot("A", r); if (n % 2) { string res; res = rep(rot("AE", r), n - 1) + rot("A", r) + rep(rot("C", r), n - 1); return res + solve(n - 1, r); } string res; res = rep(rep(rot("A", r), n / 2) + rot("E", r) + rep(rot("CE", r), n / 2 - 1), n / 2); string tmp = solve(n / 2, r); res += tmp; res += rot(tmp, 2); res += rep(rot("A", r), n / 2); return res; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); long long n; cin >> n; string res = rep("C", n) + solve(n, 0) + rep("E", n); cout << res << '\n'; return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 | /* Zadanie: Wersja dla profesjonalistów Autor: Tomasz Kwiatkowski */ #include <bits/stdc++.h> #define fi first #define se second #define pb push_back using namespace std; typedef long long ll; const int MAXN = 1e6 + 7; const int INF = 1e9 + 7; string rep(string s, long long k, int st = 2) { if (k == 0) return ""; if (k == 1) return s; if (k <= 9) return string{k + '0'} + '[' + s + ']'; string res = ""; for (int i = 9; i >= st; --i) { if (k % i == 0) { string tmp = rep(s, k / i, i); if ((res.empty() && tmp.size()) || (tmp.size() && (3 + tmp.size() < res.size()))) { res = string{i + '0'} + '[' + tmp + ']'; } } //if (res.size()) break; } if (res.size()) return res; return string{9 + '0'} + '[' + rep(s, k / 9) + ']' + rep(s, k % 9); } string rot(string s, int r) { string res = ""; for (auto c : s) { if ('A' <= c && c <= 'F') res += (char)('A' + (c - 'A' + r) % 6); else res += c; } return res; } string solve(long long n, int r) { if (n == 1) return rot("A", r); if (n % 2) { string res; res = rep(rot("AE", r), n - 1) + rot("A", r) + rep(rot("C", r), n - 1); return res + solve(n - 1, r); } string res; res = rep(rep(rot("A", r), n / 2) + rot("E", r) + rep(rot("CE", r), n / 2 - 1), n / 2); string tmp = solve(n / 2, r); res += tmp; res += rot(tmp, 2); res += rep(rot("A", r), n / 2); return res; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); long long n; cin >> n; string res = rep("C", n) + solve(n, 0) + rep("E", n); cout << res << '\n'; return 0; } |