Submission #1149139

#TimeUsernameProblemLanguageResultExecution timeMemory
1149139SSSMOne-Way Streets (CEOI17_oneway)C++20
0 / 100
2 ms4928 KiB
#include <bits/stdc++.h>

/*
#pragma GCC optimize("O3")
#pragma GCC optimize("Ofast")
#pragma GCC target ("avx2")
*/

using namespace std;

/*
#include <ext/pb_ds/assoc_container.hpp> 
#include <ext/pb_ds/tree_policy.hpp> 
using namespace __gnu_pbds;
template<class T> using Tree = tree<T, null_type, less<T>, rb_tree_tag, tree_order_statistics_node_update>;
*/

#define F first
#define S second
#define pb push_back
#define md(a) (a%mod)
#define all(a) a.begin(), a.end()
#define MP make_pair
#define lc (id<<1)
#define rc (lc|1)
#define mid (l+r)/2
#define kill(a) cout << a << "\n", exit(0)
#define SZ(a) (ll)a.size()

typedef pair<int,int> pii;
typedef pair<long long ,long long> pll;
typedef long long ll;
typedef long double ld;
typedef vector<vector<ll>> matrix;
mt19937_64  rng(chrono::steady_clock::now().time_since_epoch().count());

ll const maxn=2e5+10, mod=1e9+7, INF=1e18, LOG=31, sq=65;

ll poww(ll a, ll b, ll mod) {
 if (b == 0) return 1;
 return 1 * poww(1 * a * a % mod, b / 2, mod) * ((b % 2 == 1) ? a : 1) % mod;
}

ll n, m, dp[maxn], dp2[maxn];
vector<pll> g[maxn];
char ans[maxn];
bool vis[maxn], Vvis[maxn];

void DFS(ll v)
{
    Vvis[v]=1;
    for(auto [u, i]:g[v])
    {
        if(vis[abs(i)]) continue;
        vis[abs(i)]=1;
        if(!Vvis[u])
        {
            DFS(u);
            if(dp2[u]>0||dp[u]==0) ans[abs(i)]='B';
            else ans[abs(i)]=((dp[u]<0)^(i>0))?'L':'R';
            dp[v]+=dp[u];
            dp2[v]+=dp2[u];
        }
        else{
            ans[abs(i)]='B';
            dp2[v]++;
            dp2[u]--;
        }
    }
}

int main()
{
    ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);

    cin>>n>>m;
    for(ll i=1;i<=m;i++)
    {
        ll v, u;
        cin>>v>>u;
        g[v].pb({u, i});
        g[u].pb({v, -i});
    }

    ll q;
    cin>>q;
    while(q--)
    {
        ll v, u;
        cin>>v>>u;
        dp[v]++;
        dp[u]--;
    }
    DFS(1);
    for(ll i=1;i<=m;i++) cout<<ans[i];
    cout<<"\n";


    return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...