#include <bits/stdc++.h>
using namespace std;
#define F first
#define S second
const int N = 2e5 + 100;
int dp[N], par[N], a[N];
string used[N];
vector<pair<int, int>> vec;
map<pair<int, int>, bool> store;
map<int, string> output;
bool check(int p, int i){
    if (i == vec.size()) return 1;
    if (store.find({p, i}) != store.end()) return store[{p, i}];
    if (vec[i].S == 0){
        int nxt = i + 1;
        while (nxt < vec.size() and vec[nxt].F <= vec[i].F + p and vec[nxt].S == 1)
            nxt++;
        output[p] += 'R';
        return store[{p, nxt}] = check(p, nxt);
    }
    int last = i;
    while (last < vec.size() and vec[last].S == 1)
        last++;
    if (last == vec.size()) return store[{p, i}] = 0;
    if (vec[last].F - p <= vec[i].F){
        output[p] += 'L';
        if (check(p, last + 1))
            return 1;
        output[p].pop_back();
    }
    int last2 = last;
    while (last2 < vec.size() and vec[last2].S == 1)
        last2++;
    if (last2 == vec.size()) return store[{p, i}] = 0;
    if (vec[last2].F - p > vec[i].F) return store[{p, i}] = 0;
    int nxt = last2 + 1;
    while (nxt < vec.size() and vec[nxt].F <= vec[last].F + p and vec[nxt].S == 1)
        nxt++;
    output[p] += "RL";
    return store[{p, i}] = check(p, nxt);
}
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;
        a[i] = 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, 0)) r = mid;
        else l = mid;
    }
    cout << r << endl;
    cout << output[r] << 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... |