#include <bits/stdc++.h>
using namespace std;
#define F first
#define S second
const int N = 2e5 + 100;
int dp[N], par[N];
string used[N], output;
vector<pair<int, int>> vec;
int check(int p){
memset(dp, 0, sizeof dp);
memset(par, -1, sizeof par);
for (int i = 0; i < N; i ++) used[i] = "";
int n = vec.size();
dp[n] = 1;
vector<int> inds;
for (int i = n - 1; i >= 0; i --){
if (vec[i].S == 0){
if (inds.size() and vec[inds.back()].F <= vec[i].F + p and dp[inds.back()]){
dp[i] = 1;
par[i] = inds.back();
used[i] = "R";
}
else{
int nxt = lower_bound(vec.begin(), vec.end(), pair<int, int> {vec[i].F + p + 1, -1}) - vec.begin();
if (dp[nxt]){
dp[i] = 1;
par[i] = nxt;
used[i] = "R";
}
}
inds.push_back(i);
continue;
}
if (inds.empty()){
dp[i] = 0;
continue;
}
int last = inds.back();
if (dp[last + 1] and vec[last].F - p <= vec[i].F){
dp[i] = 1;
par[i] = last + 1;
used[i] = "L";
continue;
}
if (inds.size() == 1){
dp[i] = 0;
continue;
}
int last2 = inds[inds.size() - 2];
int last3 = -1;
if (inds.size() > 2) last3 = inds[inds.size() - 3];
if (vec[last2].F - p > vec[i].F) continue;
int nxt = lower_bound(vec.begin(), vec.end(), pair<int, int> {vec[last].F + p + 1, -1}) - vec.begin();
if (last3 != -1 and nxt >= last3) nxt = last3;
if (dp[nxt]){
dp[i] = 1;
par[i] = nxt;
used[i] = "RL";
continue;
}
}
return dp[0];
}
int main(){
int n, m;
cin >> n >> m;
int X, mn = 1e9, mx = 0;
for (int i = 0; i < n; i ++){
int x;
cin >> x;
X = x;
vec.push_back({x, 0});
}
for (int i = 0; i < m; i ++){
int x;
cin >> x;
mn = min(mn, x);
mx = max(mx, x);
vec.push_back({x, 1});
}
sort(vec.begin(), vec.end());
if (n == 1){
if (mn < X and X < mx){
cout << -1 << endl;
}
else if (mn < X){
cout << X - mn << endl;
cout << "L" << endl;
}
else{
cout << mx - X << endl;
cout << "R" << endl;
}
return 0;
}
int l = 0;
int r = 1e9 + 100;
while (r - l > 1){
int mid = (l + r) / 2;
if (check(mid)) r = mid;
else l = mid;
}
check(r);
cout << r << endl;
int cur = 0;
while (cur < vec.size()){
output += used[cur];
cur = par[cur];
}
cout << output << endl;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |