Submission #303198

#TimeUsernameProblemLanguageResultExecution timeMemory
303198fishy15Vrtić (COCI18_vrtic)C++14
0 / 160
5 ms4512 KiB
#include <iostream> #include <iomanip> #include <fstream> #include <vector> #include <array> #include <algorithm> #include <utility> #include <map> #include <queue> #include <set> #include <cmath> #include <cstdio> #include <cstring> #define ll long long #define ld long double #define eps 1e-8 #define MOD 1000000007 #define INF 0x3f3f3f3f #define INFLL 0x3f3f3f3f3f3f3f3f // change if necessary #define MAXN 160 using namespace std; int n; int nxt[MAXN]; bool vis[MAXN]; vector<int> start[MAXN]; int cnt[MAXN]; pair<int, int> nums[MAXN]; int diff[MAXN][MAXN]; ll dp[500000]; int rem[500000]; ll sum; int ans[MAXN]; // how to make and get state int sz; int vals[MAXN]; int d[MAXN]; int m[MAXN]; int conv(const vector<int> &nums) { int res = 0; for (int i = 0; i < sz; i++) { res += nums[i] * d[i]; } return res; } void dfs(int pos, int &len, int set) { if (!vis[pos]) { vis[pos] = true; if (set >= 0) ans[pos] = nums[set].first; len++; dfs(nxt[pos], len, set - 1); } } int solve(vector<int> &cur, int len) { if (len == 0) return 0; int c = conv(cur); if (dp[c] < INFLL) return dp[c]; for (int i = 0; i < sz; i++) { if (cur[i]) { cur[i]--; ll res = max(solve(cur, len - vals[i]), diff[len - vals[i]][len - 1]); if (res < dp[c]) { dp[c] = res; rem[c] = i; } } } return dp[c]; } void calc(vector<int> &cur, int len) { if (len > 0) { int c = conv(cur); int taken = rem[c]; int x = 0; dfs(start[vals[taken]].back(), x, len - 1); start[vals[taken]].pop_back(); cur[taken]--; calc(cur, len - vals[taken]); } } int main() { cin.tie(0)->sync_with_stdio(0); cin >> n; for (int i = 0; i < n; i++) { cin >> nxt[i]; nxt[i]--; } for (int i = 0; i < n; i++) { ll x; cin >> x; nums[i] = {x, i}; } sort(nums, nums + n); for (int i = 0; i < n; i++) { for (int j = i + 1; j < n; j++) { diff[i][j] = max(diff[i][j], nums[i + 1].first - nums[i].first); diff[i][j] = max(diff[i][j], nums[j].first - nums[j - 1].first); for (int k = i; k <= j - 2; k++) { diff[i][j] = max(diff[i][j], nums[k + 2].first - nums[k].first); } } } for (int i = 0; i < n; i++) { if (!vis[i]) { int len = 0; dfs(i, len, -1); start[len].push_back(i); cnt[len]++; } } ll p = 1; for (int i = 0; i <= 150; i++) { if (cnt[i]) { vals[sz] = i; d[sz] = p; p *= cnt[i] + 1; m[sz] = p; sz++; } } vector<int> cur; for (int i = 0; i < sz; i++) { cur.push_back(cnt[vals[i]]); } vector<int> cur2(cur); memset(dp, 0x3f, sizeof dp); memset(vis, 0, sizeof vis); cout << solve(cur, n) << '\n'; calc(cur2, n); for (int i = 0; i < n; i++) { cout << ans[i] << ' '; } cout << '\n'; 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...
#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...