Submission #602576

#TimeUsernameProblemLanguageResultExecution timeMemory
602576snasibov05Palembang Bridges (APIO15_bridge)C++14
22 / 100
130 ms7452 KiB
#include <bits/stdc++.h> using namespace std; #define oo 1000000000000000000ll #define int long long signed main() { int k, n; cin >> k >> n; int ans = 0; vector<int> arr; for (int i = 0; i < n; ++i){ char t1, t2; int x1, x2; cin >> t1 >> x1 >> t2 >> x2; if (t1 == t2) ans += abs(x2 - x1); else arr.push_back(x1), arr.push_back(x2); } if (arr.size() == 0){ cout << ans << "\n"; return 0; } sort(arr.begin(), arr.end()); vector<int> pref(arr.size()); pref[0] = arr[0]; for (int i = 1; i < arr.size(); ++i) pref[i] = pref[i-1] + arr[i]; vector<int> suf(arr.size()); suf.back() = arr.back(); for (int i = arr.size() - 2; i >= 0; --i) suf[i] = suf[i+1] + arr[i]; int mn = oo; for (int i = 0; i < arr.size(); ++i){ mn = min(mn, arr[i] * (i+1) - pref[i] + suf[i] - arr[i] * ((int)arr.size() - i)); } ans += (int)arr.size() / 2ll; ans += mn; cout << ans << "\n"; return 0; }

Compilation message (stderr)

bridge.cpp: In function 'int main()':
bridge.cpp:26:23: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   26 |     for (int i = 1; i < arr.size(); ++i) pref[i] = pref[i-1] + arr[i];
      |                     ~~^~~~~~~~~~~~
bridge.cpp:31:23: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   31 |     for (int i = 0; i < arr.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...