#4335. 序列合并——CSP 2024 提高级第一轮
序列合并——CSP 2024 提高级第一轮
有两个长度为 的非负整数序列 和 ,所有数均为非负整数,且小于 。它们都是单调不降排列。在 A 和 B 中各取一个数相加可以得到个和,求其中第 K 小的和。 数据范围满足:,
#include <iostream>
using namespace std;
const int maxn = 100005;
int n;
long long k;
int a[maxn], b[maxn];
int* upper_bound(int *a, int *an, int ai) {
int l = 0, r = ___①___;
while (l < r) {
int mid = (l+r)>>1;
if (___②___) {
r = mid;
} else {
l = mid + 1;
}
}
return ___③___;
}
long long get_rank(int sum) {
long long rank = 0;
for (int i = 0; i < n; ++i) {
rank += upper_bound(b, b+n, sum - a[i]) - b;
}
return rank;
}
int solve() {
int l = 0, r = ___④___;
while (l < r) {
int mid = ((long long)l+r)>>1;
if (___⑤___) {
l = mid + 1;
} else {
r = mid;
}
}
return l;
}
int main() {
cin >> n >> k;
for (int i = 0; i < n; ++i) cin >> a[i];
for (int i = 0; i < n; ++i) cin >> b[i];
cout << solve() << endl;
}
① 处应填( )
{{ select(1) }}
- A.
an - a - B.
an - a - 1 - C.
ai - D.
ai + 1
② 处应填( )
{{ select(2) }}
a[mid] > aia[mid] >= aia[mid] < aia[mid] <= ai
③ 处应填( )
{{ select(3) }}
a + la + l + 1a + l - 1an - l
④ 处应填( )
{{ select(4) }}
a[n - 1] + b[n - 1]a[n] + b[n]2 * maxnmaxn
⑤ 处应填( )
{{ select(5) }}
get_rank(mid) < kget_rank(mid) <= kget_rank(mid) > kget_rank(mid) >= k