제출 #352405

#제출 시각아이디문제언어결과실행 시간메모리
352405SeDunionJust Long Neckties (JOI20_ho_t1)C++17
100 / 100
342 ms18796 KiB
#include<bits/stdc++.h> using namespace std; using ll = long long; const int N = 1e6 + 66; pair<int,int> a[N]; int ans[N], b[N]; int main() { ios_base::sync_with_stdio(0); cin.tie(0), cout.tie(0); int n; cin >> n; for (int i = 1 ; i <= n + 1 ; ++ i) { cin >> a[i].first; a[i].second = i; } for (int i = 1 ; i <= n ; ++ i) cin >> b[i]; sort(a + 1, a + 2 + n); sort(b + 1, b + 1 + n); multiset<int> s = {0}; for (int i = 1 ; i <= n ; ++ i) { s.insert(a[i + 1].first - b[i]); } for (int i = 1 ; i - 1 <= n ; ++ i) { ans[a[i].second] =*s.rbegin(); if (i <= n) { s.erase(s.find(a[i + 1].first - b[i])); s.insert(a[i].first - b[i]); } } for (int i = 1 ; i <= n + 1 ; ++ i) cout << ans[i] << " "; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...