This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#pragma GCC optimize ("O3")
#pragma GCC optimize ("unroll-loops")
#pragma GCC optimize("-Ofast")
#include <bits/stdc++.h>
#include <algorithm>
#include <iostream>
#include <vector>
#include <limits>
#include <cmath>
#include <stack>
#include <queue>
#include <map>
#include <math.h>
using namespace std;
using ll = long long;
void solve(){
ll n;
cin >> n;
vector<ll> list_a(n + 1, 0);
vector<ll> list_b(n, 0);
vector<ll> proper_min(n + 1, 0);
vector<ll> improper_min(n + 1, 0);
for(ll i = 0; i <= n; i++){
cin >> list_a[i];
}
for(ll i = 0; i < n; i++){
cin >> list_b[i];
}
sort(list_a.begin(), list_a.end());
sort(list_b.begin(), list_b.end());
for(ll i = 0; i < n; i++){
proper_min[i + 1] = max(proper_min[i], max((ll)0, list_a[i] - list_b[i]));
}
for(ll i = n - 1; i >= 0; i--){
improper_min[n - i] = max(proper_min[n - i + 1], max((ll)0, list_a[i + 1] - list_b[i]));
}
vector<ll> ans(n + 1, 0);
for(ll i = 0; i <= n; i++){
ans[i] = max(proper_min[i], improper_min[n - i]);
cout << ans[i] << " ";
}
}
int main(){
ios_base::sync_with_stdio(false);
cout.tie(0);
cin.tie(0);
ll t = 1;
while(t--){
solve();
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |