Submission
Status:
[PPPPP][PPPPP][PPPPPPPPPP]
Score: 100
User: AungS8430
Problemset: ห้องสมุดเมือง 3M
Language: cpp
Time: 0.002 second
Submitted On: 2025-03-16 06:57:03
#include <bits/stdc++.h>
using namespace std;
int main(void) {
int n;
cin >> n;
long start[n], end[n], range[2] = {LONG_MAX, LONG_MIN}, total = 0, med_pos;
for (int i = 0; i < n; i++) {
cin >> start[i] >> end[i];
range[0] = min(range[0], start[i]);
range[1] = max(range[1], end[i]);
total += end[i] - start[i];
}
med_pos = total / 2;
while (range[0] < range[1]) {
long mid = range[0] + (range[1] - range[0]) / 2;
long pos = 0;
for (int i = 0; i < n; i++) {
if (start[i] <= mid) {
pos += min(mid, end[i] - 1) - start[i] + 1;
}
}
if (pos < med_pos) range[0] = mid + 1;
else range[1] = mid;
}
cout << range[0] << endl;
return 0;
}