제출 #317894

#제출 시각아이디문제언어결과실행 시간메모리
317894ali_tavakoliPalembang Bridges (APIO15_bridge)C++17
0 / 100
1 ms512 KiB
//In the name of Allah #include<bits/stdc++.h> using namespace std; typedef long long ll; #define endl '\n' #define F first #define S second #define pb push_back #define all(x) x.begin(), x.end() const ll N = 1e5 + 5; ll n, k, med[N][2], base, med2[N][2]; vector<pair<ll, pair<ll, ll> > > ve; int main() { priority_queue<ll> q1; priority_queue<ll, vector<ll>, greater<ll> > q2; cin >> k >> n; for(ll i = 0; i < n; i++) { char ch1, ch2; ll p, q; cin >> ch1 >> p >> ch2 >> q; if(ch1 != ch2) { ve.pb({p + q, {min(p, q), max(p, q)}}); base ++; } else base += abs(p - q); } sort(all(ve)); n = ve.size(); for(ll i = 0; i < (ll)ve.size(); i++) { auto x = ve[i]; q1.push(x.S.F); q2.push(x.S.S); while(q1.top() > q2.top()) { ll to1 = q1.top(), to2 = q2.top(); q1.pop();q2.pop(); q1.push(to2); q2.push(to1); } med[i][0] = q1.top(); med[i][1] = q2.top(); } //cout << med[ve.size() - 1][0] << " " << med[ve.size() - 1][1] << endl; if(!n) cout << base << endl; if(k == 1|| n == 1) { ll ans1, ans2; ans1 = ans2 = 0; for(ll i = 0; i < ve.size(); i++) { ans1 += abs(ve[i].S.F - med[ve.size() - 1][0]); ans1 += abs(ve[i].S.S - med[ve.size() - 1][0]); ans2 += abs(ve[i].S.F - med[ve.size() - 1][1]); ans2 += abs(ve[i].S.S - med[ve.size() - 1][1]); } cout << min(ans1, ans2) + base << endl; } else { ll ans = 1e18 + 5; while(q1.size())q1.pop(); while(q2.size())q2.pop(); for(ll i = 0; i < (ll)ve.size(); i++) { auto x = ve[ve.size() - i - 1]; q1.push(x.S.F); q2.push(x.S.S); while(q1.top() > q2.top()) { ll to1 = q1.top(), to2 = q2.top(); q1.pop();q2.pop(); q1.push(to2); q2.push(to1); } med2[i][0] = q1.top(); med2[i][1] = q2.top(); } for(int i = 0; i < n - 1; i++) { ll ans1, ans2, ans3, ans4; ans1 = ans2 = ans3 = ans4 = 0; for(int j = 0; j <= i; j++) { ans1 += abs(ve[j].S.F - med[i][0]); ans1 += abs(ve[j].S.S - med[i][0]); ans2 += abs(ve[j].S.F - med[i][1]); ans2 += abs(ve[j].S.S - med[i][1]); } for(int j = i + 1; j < n; j++) { ans3 += abs(ve[j].S.F - med2[i + 1][0]); ans3 += abs(ve[j].S.S - med2[i + 1][0]); ans4 += abs(ve[j].S.F - med2[i + 1][1]); ans4 += abs(ve[j].S.S - med2[i + 1][1]); } ans = min(ans, min(ans1, ans2) + min(ans3, ans4)); } cout << ans + base << endl; } } /* 1 5 B 0 A 4 B 1 B 3 A 5 B 7 B 2 A 6 B 1 A 7 2 5 B 0 A 4 B 1 B 3 A 5 B 7 B 2 A 6 B 1 A 7 */

컴파일 시 표준 에러 (stderr) 메시지

bridge.cpp: In function 'int main()':
bridge.cpp:64:25: warning: comparison of integer expressions of different signedness: 'll' {aka 'long long int'} and 'std::vector<std::pair<long long int, std::pair<long long int, long long int> > >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   64 |         for(ll i = 0; i < ve.size(); i++)
      |                       ~~^~~~~~~~~~~
#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...