답안 #660991

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
660991 2022-11-23T19:05:12 Z urosk 장난감 기차 (IOI17_train) C++14
22 / 100
1674 ms 1404 KB
#include "train.h"
#define dbg(x) cerr<<#x<<": "<<x<<endl
#define here cerr<<"===================================\n"
#include <bits/stdc++.h>
#define ll int
#define sz(a) (ll)(a.size())
#define pb push_back
#define popb pop_back
#define all(a) a.begin(),a.end()
#define llinf 1000000000LL
#define fi first
#define sc second
#define pll pair<ll,ll>
#define endl '\n'
#define ceri(a,l,r) {cerr<<#a<<": ";for(ll i_ = l;i_<=r;i_++) cerr<<a[i_]<< " ";cerr<<endl;}
using namespace std;
#define maxn 5005
ll n,m,it;
vector<ll> ans;
vector<ll> g[maxn];
vector<ll> cur;
ll b[maxn];
bool c[maxn];
bool vis[maxn];
bool naso = 0;
bool ok[maxn];
ll cnt = 0;
ll in[maxn],out[maxn];
void dfs(ll u,ll poc){
    vis[u] = 1;
    for(ll s : g[u]){
        if(c[s]) continue;
        if(s==poc){
            naso = 1;
            return;
        }
        if(vis[s]) continue;
        dfs(s,poc);
        if(naso) return;
    }
}
void dfs2(ll u,ll poc){
    if(c[u]) cnt++;
    vis[u] = 1;
    for(ll s : g[u]){
        if((s==poc)&&(cnt>0)){
            naso = 1;
            return;
        }
        if(vis[s]) continue;
        dfs2(s,poc);
        if(naso) return;
    }
    if(c[u]) cnt--;
}
void dfs3(ll u){
    vis[u] = 1;
    for(ll s : g[u]){
        if(vis[s]) continue;
        dfs3(s);
        ok[u]|=ok[s];
    }
}
bool dfs4(ll u){
    bool tu = 0;
    for(ll s : g[u]) if(s==u) tu = 1;
    if(!tu){
        if(sz(g[u])==0){
            cout<<u<<endl;
            return 1;
        }
        return dfs4(g[u][0]);
    }
    if(!b[u]&&!c[u]) return 0;
    if(b[u]&&c[u]) return 1;
    for(ll s : g[u]){
        if(s!=u) return dfs4(s);
    }
}
vector<int> who_wins(vector<int> a,vector<int> r,vector<int> u,vector<int> v) {
    reverse(all(u)); u.pb(-1); reverse(all(u));
    reverse(all(v)); v.pb(-1); reverse(all(v));
    reverse(all(r)); r.pb(-1); reverse(all(r));
    ll sum = 0; for(ll x : a) sum+=x;
    n = sz(a);
    reverse(all(a)); a.pb(-1); reverse(all(a));
    for(ll i = 1;i<=n;i++) b[i] = a[i];
    m = sz(u)-1;
    bool sub1 = 1;
    for(ll i = 1;i<=n;i++) c[i] = r[i];
    for(ll i = 1;i<=m;i++){
        u[i]++; v[i]++;
        ll x = u[i]; ll y = v[i];
        g[x].pb(y);
        sub1&=((x==y)||(y-x==1));
    }
    if(sum==0){
        for(ll i = 1;i<=n;i++){
            if(c[i]) continue;
            for(ll j = 1;j<=n;j++) vis[j] = 0;
            naso = 0;
            dfs(i,i);
            if(naso) ok[i] = 1;
        }
        for(ll i = 1;i<=n;i++){
            for(ll j = 1;j<=n;j++) vis[j] = 0;
            dfs3(i);
        }
        for(ll i = 1;i<=n;i++) ans.pb(1^ok[i]);
        return ans;
    }
    if(sum==n){
        for(ll i = 1;i<=n;i++){
            for(ll j = 1;j<=n;j++) vis[j] = 0;
            naso = 0;
            cnt = 0;
            dfs2(i,i);
            if(naso) ok[i] = 1;
        }
        for(ll i = 1;i<=n;i++){
            for(ll j = 1;j<=n;j++) vis[j] = 0;
            dfs3(i);
        }
        for(ll i = 1;i<=n;i++) ans.pb(ok[i]);
        return ans;
    }
    if(sub1){
        for(ll i = 1;i<=n;i++){
            for(ll j = 1;j<=n;j++) vis[j] = 0;
            ok[i] = dfs4(i);
        }
        for(ll i = 1;i<=n;i++) ans.pb(ok[i]);
        return ans;
    }
	return {};
}

/*
4 6
0 0 0 0
0 1 0 0
0 1
0 2
0 3
1 2
1 3
2 3
*/

Compilation message

train.cpp: In function 'bool dfs4(int)':
train.cpp:79:1: warning: control reaches end of non-void function [-Wreturn-type]
   79 | }
      | ^
# 결과 실행 시간 메모리 Grader output
1 Incorrect 4 ms 852 KB secret mismatch
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 340 KB WA in grader: Wrong returned array size
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 296 ms 1404 KB Output is correct
2 Correct 266 ms 1364 KB Output is correct
3 Correct 257 ms 1324 KB Output is correct
4 Correct 1130 ms 1356 KB Output is correct
5 Correct 981 ms 1236 KB Output is correct
6 Correct 865 ms 1128 KB Output is correct
7 Correct 707 ms 1108 KB Output is correct
8 Correct 455 ms 1236 KB Output is correct
9 Correct 430 ms 1112 KB Output is correct
10 Correct 550 ms 1076 KB Output is correct
11 Correct 487 ms 1064 KB Output is correct
12 Correct 38 ms 1036 KB Output is correct
13 Correct 1585 ms 1300 KB Output is correct
14 Correct 1674 ms 1296 KB Output is correct
15 Correct 1605 ms 1324 KB Output is correct
16 Correct 1150 ms 1300 KB Output is correct
17 Correct 1161 ms 1356 KB Output is correct
18 Correct 462 ms 1112 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 629 ms 1108 KB Output is correct
2 Correct 197 ms 1100 KB Output is correct
3 Correct 377 ms 1108 KB Output is correct
4 Correct 375 ms 1236 KB Output is correct
5 Correct 505 ms 1108 KB Output is correct
6 Correct 442 ms 1108 KB Output is correct
7 Correct 468 ms 1100 KB Output is correct
8 Correct 344 ms 1064 KB Output is correct
9 Correct 23 ms 1048 KB Output is correct
10 Correct 867 ms 1300 KB Output is correct
11 Correct 990 ms 1312 KB Output is correct
12 Correct 924 ms 1300 KB Output is correct
13 Correct 695 ms 1176 KB Output is correct
14 Correct 408 ms 1080 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 8 ms 1008 KB WA in grader: Wrong returned array size
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 4 ms 852 KB secret mismatch
2 Halted 0 ms 0 KB -