Submission #308573

#TimeUsernameProblemLanguageResultExecution timeMemory
308573shivensinha4Lightning Conductor (POI11_pio)C++17
27 / 100
20 ms20344 KiB
#include <bits/stdc++.h> using namespace std; #define for_(i, s, e) for (int i = s; i < (int) e; i++) #define for__(i, s, e) for (ll i = s; i < e; i++) typedef long long ll; typedef vector<int> vi; typedef pair<int, int> ii; #define endl '\n' const int MXV = 1e6, INF = 1e9; //int rt[MXV+1]; int pos[MXV+1][2]; int grt(int p) { for_(i, 0, p+1) { if (i*i >= p) { //cout << p << " -> " << i << endl; return i; } } assert(false); return -1; } int main() { #ifdef shiven freopen("test.in", "r", stdin); #endif ios_base::sync_with_stdio(false); cin.tie(0); int n; cin >> n; for_(i, 0, MXV+1) { pos[i][0] = INF; pos[i][1] = -1; } vi h(n); int mx = 0; for_(i, 0, n) { cin >> h[i]; mx = max(mx, h[i]); //if (!pos[h[i]].size()) pos[h[i]] = {i, i}; pos[h[i]][0] = min(pos[h[i]][0], i); pos[h[i]][1] = max(pos[h[i]][1], i); } //int r = 0, sq = 0; //for_(i, 0, mx+1) { //rt[i] = r; //if (i == sq) { //r += 1; //sq = r*r; //} //} //vi poss; //for (int i = mx; i >= max(mx-710, 0); i--) if (pos[i].size()) { //poss.push_back(i); //} for_(i, 0, n) { int ans = h[i]; //for (int v = mx; v >= max(mx-710, 0); v--) if (pos[v][0] != INF) ans = max({ans, v + rt[abs(pos[v][0] - i)], v + rt[abs(pos[v][1] - i)]}); for (int v = mx; v >= max(mx-710, 0); v--) if (pos[v][0] != INF) ans = max({ans, v + grt(abs(pos[v][0] - i)), v + grt(abs(pos[v][1] - i))}); cout << ans-h[i] << endl; } 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...
#Verdict Execution timeMemoryGrader output
Fetching results...