結果
問題 | No.3016 ハチマキおじさん |
ユーザー |
|
提出日時 | 2025-02-22 02:19:34 |
言語 | C++23 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 949 bytes |
コンパイル時間 | 3,709 ms |
コンパイル使用メモリ | 293,168 KB |
実行使用メモリ | 29,312 KB |
最終ジャッジ日時 | 2025-02-22 02:19:47 |
合計ジャッジ時間 | 12,283 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 2 WA * 29 |
ソースコード
#include<bits/stdc++.h>using namespace std;using ll = long long;#define all(a) begin(a), end(a)#define rep(i,a,b) for(ll i = a; i < (b); i++)#define per(i,a,b) for(ll i = (b)-1; i >= (a); i--)int main(){int n;cin >> n;vector<ll> a(n);vector<ll> b(n-1);rep(i,0,n) cin >> a[i];rep(i,0,n-1) cin >> b[i];map<int, vector<int>> mp;rep(i,0,n){mp[a[i]].push_back(i+1);}sort(all(a));sort(all(b));vector<ll> l(n,0);vector<ll> r(n,0);rep(i,0,n-1){l[i+1] = l[i] + abs(a[i] - b[i]);}per(i,1,n){r[i-1] = r[i] + abs(a[i] - b[i-1]);}ll ans =1e18;set<int> st;rep(i,0,n){if(ans > l[i] + r[i]){ans = l[i] + r[i];st = {};}if(ans == l[i] + r[i]) st.insert(a[i]);}vector<int> ind;cout << ans << endl;for(auto v: st){cout << v << " ";}cout << endl;}