Submission #653895

#TimeUsernameProblemLanguageResultExecution timeMemory
653895uroskStranded Far From Home (BOI22_island)C++14
100 / 100
268 ms38440 KiB
#define here cerr<<"===========================================\n" #define dbg(x) cerr<<#x<<": "<<x<<endl; #include <bits/stdc++.h> #include <ext/pb_ds/tree_policy.hpp> #include <ext/pb_ds/assoc_container.hpp> #define ld double #define ll long long #define llinf 100000000000000000LL // 10^17 #define pb push_back #define popb pop_back #define fi first #define sc second #define endl '\n' #define pll pair<ll,ll> #define pld pair<ld,ld> #define sz(a) (ll)(a.size()) #define all(a) a.begin(),a.end() #define ceri(a,l,r) {cerr<<#a<<": ";for(ll i_ = l;i_<=r;i_++) cerr<<a[i_]<< " ";cerr<<endl;} #define cer(a) {cerr<<#a<<": ";for(ll x_ : a) cerr<<x_<< " ";cerr<<endl;} #define daj_mi_malo_vremena ios_base::sync_with_stdio(false);cerr.tie(0);cout.tie(0);cin.tie(0); using namespace std; using namespace __gnu_pbds; /* ll add(ll x,ll y){ x+=y; if(x<0){ x%=mod; x+=mod; }else{ if(x>=mod) x%=mod; } return x; } ll mul(ll a,ll b){ ll ans = (a*b)%mod; if(ans<0) ans+=mod; return ans; } typedef tree<int,null_type,less<ll>,rb_tree_tag,tree_order_statistics_node_update> ordered_set; typedef tree<int,null_type,less_equal<ll>,rb_tree_tag,tree_order_statistics_node_update> ordered_multiset; mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count()); ll rnd(ll l,ll r){ return uniform_int_distribution<ll>(l,r)(rng); } */ #define maxn 200005 ll n,m; pll a[maxn]; vector<ll> g[maxn]; vector<ll> g2[maxn]; ll dsu[maxn],sum[maxn],sizi[maxn]; bool ok[maxn]; bool vis[maxn]; void dfs(ll u){ if(!ok[u]) return; ok[u] = 0; for(ll s : g2[u]) dfs(s); } ll root(ll x){ while(x!=dsu[x]){dsu[x] = dsu[dsu[x]];x = dsu[x];} return x; } void upd(ll x,ll y){ x = root(x); y = root(y); if(x==y) return; dsu[x] = y; g2[y].pb(x); sizi[y]+=sizi[x]; sum[y]+=sum[x]; } void tc(){ cin >> n >> m; for(ll i = 1;i<=n;i++) cin >> a[i].fi; for(ll i = 1;i<=n;i++) a[i].sc = i; for(ll i = 1;i<=n;i++) sum[i] = a[i].fi; for(ll i = 1;i<=m;i++){ ll x,y; cin >> x >> y; g[x].pb(y); g[y].pb(x); } iota(dsu+1,dsu+1+n,1); fill(ok+1,ok+1+n,1); fill(sizi+1,sizi+1+n,1); sort(a+1,a+1+n); for(ll j = 1;j<=n;j++){ ll i = a[j].sc; ll x = a[j].fi; vis[i] = 1; for(ll j : g[i]){ if(!vis[j]) continue; j = root(j); if(sum[j]<x){ dfs(j); } } for(ll j : g[i]){ if(!vis[j]) continue; upd(j,i); } } for(ll i = 1;i<=n;i++){ cout<<(ok[i]&&(sizi[root(i)]==n)); } cout<<endl; } int main(){ daj_mi_malo_vremena int t; t = 1; while(t--){ tc(); } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...