This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define ll long long
using namespace std;
#include <ext/pb_ds/tree_policy.hpp>
#include <ext/pb_ds/assoc_container.hpp>
using namespace __gnu_pbds;
template<class T> using Tree= tree<T, null_type, less<T>,rb_tree_tag, tree_order_statistics_node_update>;
int main() {
	int k,n;
	cin >> k >> n;
	if (k==1) {
		ll ans = 0; 
		vector<int> nums;
		Tree<pair<int,int>> ms;
		int c=0;
		for (int i=0; i<n; i++) {
			char p,q; int s,t;
			cin >> p >> s >> q >> t;
			if (p == q) {
				ans += abs(t-s);
			}
			else {
				nums.push_back(s);
				nums.push_back(t);
				ms.insert({s,i}); ms.insert({t,i+n});
				c+=2;
			}
		}
		int median = ms.find_by_order(c/2)->first;
		for (int z : nums) {ans += abs(z-median);}
		ans += (c/2);
		cout << ans << "\n";
	}
	
	
	
	
	return 0;
}
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... |