답안 #162616

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
162616 2019-11-09T03:46:39 Z samzhang Planinarenje (COCI18_planinarenje) C++17
160 / 160
12 ms 2296 KB
#include "bits/stdc++.h"
//#include "ext/pb_ds/tree_policy.hpp"
//#include "ext/pb_ds/assoc_container.hpp"
#define PB push_back
#define PF push_front
#define LB lower_bound
#define UB upper_bound
#define fr(x) freopen(x,"r",stdin)
#define fw(x) freopen(x,"w",stdout)
#define iout(x) printf("%d\n",x)
#define lout(x) printf("%lld\n",x)
#define REP(x,l,u) for(ll x = l;x<u;x++)
#define RREP(x,l,u) for(ll x = l;x>=u;x--)
#define complete_unique(a) a.erase(unique(a.begin(),a.end()),a.end())
#define mst(x,a) memset(x,a,sizeof(x))
#define all(a) a.begin(),a.end()
#define PII pair<int,int>
#define PLL pair<ll,ll>
#define MP make_pair
#define sqr(x) ((x)*(x))
#define lowbit(x) (x&(-x))
#define lson (ind<<1)
#define rson (ind<<1|1)
#define se second
#define fi first
#define dbg(x) cerr<<#x<<" = "<<(x)<<endl;
#define sz(x) ((int)x.size())
#define EX0 exit(0);

typedef  long long ll;
typedef unsigned long long ull;
typedef double db;
typedef long double ld;
using namespace std;
const int block_size = 320;
typedef complex<ll> point;
const ll mod = 1e9+7;
const ll inf = 1e9+7;
const ld eps = 1e-9;
const db PI = atan(1)*4;
template<typename T>
inline int sign(const T&a) {
    if(a<0)return -1;
    if(a>0)return 1;
    return 0;
}


template<typename T> inline void in(T &x) {
    x = 0;
    T f = 1;
    char ch = getchar();
    while (!isdigit(ch)) {
        if (ch == '-') f = -1;
        ch = getchar();
    }
    while (isdigit(ch))  {
        x = x * 10 + ch - '0';
        ch = getchar();
    }
    x *= f;
}

ll twop(int x) {
    return 1LL<<x;
}

template<typename A,typename B > inline void in(A&x,B&y) {
    in(x);
    in(y);
}
template<typename A,typename B,typename C>inline void in(A&x,B&y,C&z) {
    in(x);
    in(y);
    in(z);
}
template<typename A,typename B,typename C,typename D> inline void in(A&x,B&y,C&z,D&d) {
    in(x);
    in(y);
    in(z);
    in(d);
}




template <class T>
void upd(T&a,T b) {
    a = max(a,b);
}
int n,m;

namespace maxFlow {
    const int maxn = 10010, maxe = 100010,source = 10010-1,sink = 10010-2;
    int cnt = 0;
    struct edge {
        int from,to,cap;
        edge(int a,int b,int c):from(a),to(b),cap(c) {}
        edge() {
            from = to = cap = 0;
        }
    };
    vector<int>g[maxn];
    edge e[maxe];
    void clear() {
        cnt = 0;
        REP(i,0,maxn)g[i].clear();
        REP(i,0,maxe)e[i] = edge();
    }
    
    void addEdge(int u,int v,int cap) {
        int cur = cnt;
        e[cur] = edge(u,v,cap);
        g[u].PB(cur);
        e[cur^1] = edge(v,u,0);
        g[v].PB(cur^1);
        cnt+=2;
    }
    void init(){
        clear();
        REP(i,0,m){
            int u,v;in(u,v);
            addEdge(u, n+v,1);
        }
        REP(i,1,n+1){
            addEdge(source, i, 1);
        }
        REP(i,1,n+1){
            addEdge(n+ i,sink, 1);
        }
    }

    int lvl[maxn],cur[maxn];
    bool bfs(int start = source) {
        mst(lvl, -1);
        mst(cur,0);
        lvl[start] = 0;
        queue<int>q;
        q.push(start);
        
        while(sz(q)) {
            int f = q.front();
            q.pop();
            for(auto curEdge:g[f]) {
                auto &E = e[curEdge];
                if(E.cap) {
                    if(lvl[E.to] == -1) {
                        lvl[E.to] = lvl[f]+1;
                        q.push(E.to);
                    }
                }
            }
        }
        
        return lvl[sink]!=-1;
    }
    
    
    int dfs(int curNode,int curCap) {
        if(!curCap || curNode == sink)return curCap;
        int ans = 0;
        for(int& i = cur[curNode]; i<sz(g[curNode]); i++) {
            int curEdge = g[curNode][i];
            if(lvl[e[curEdge].to]>lvl[curNode]) {
                int delta = dfs(e[curEdge].to,min(e[curEdge].cap,curCap));
                ans+=delta;
                curCap-=delta;
                e[curEdge].cap-=delta;
                e[curEdge^1].cap+=delta;
                if(!curCap)break;
            }
        }
        return ans;
    }
    
    ll dinic() {
        ll ans = 0;
        while (bfs()) {
            ans+=(dfs(source, inf));
        }
        return ans;
    }
    
    void work(){
        dinic();
        bfs();
        int ans = n;
        REP(i,1,n+1){
            if(lvl[i]==-1){
                printf("Slavko\n");
            }else{
                printf("Mirko\n");
            }
        }
        
        
        
    }
}


int main(){
//    fr("/Users/zhangqingchuan/Desktop/cp/cp/input.txt");
    in(n,m);
    maxFlow::init();
    maxFlow::work();
    return 0;
}

Compilation message

planinarenje.cpp: In function 'void maxFlow::work()':
planinarenje.cpp:187:13: warning: unused variable 'ans' [-Wunused-variable]
         int ans = n;
             ^~~
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1760 KB Output is correct
2 Correct 3 ms 1784 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1784 KB Output is correct
2 Correct 3 ms 1784 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1784 KB Output is correct
2 Correct 3 ms 1784 KB Output is correct
3 Correct 4 ms 1784 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4 ms 1784 KB Output is correct
2 Correct 4 ms 1912 KB Output is correct
3 Correct 4 ms 1784 KB Output is correct
4 Correct 4 ms 1788 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 8 ms 2168 KB Output is correct
2 Correct 8 ms 2296 KB Output is correct
3 Correct 8 ms 2296 KB Output is correct
4 Correct 8 ms 2296 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 6 ms 1916 KB Output is correct
2 Correct 5 ms 1912 KB Output is correct
3 Correct 6 ms 1912 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 6 ms 1912 KB Output is correct
2 Correct 6 ms 1832 KB Output is correct
3 Correct 6 ms 1912 KB Output is correct
4 Correct 5 ms 1884 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 9 ms 1912 KB Output is correct
2 Correct 10 ms 2168 KB Output is correct
3 Correct 9 ms 2040 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 12 ms 2040 KB Output is correct
2 Correct 10 ms 2168 KB Output is correct
3 Correct 6 ms 2040 KB Output is correct
4 Correct 7 ms 2032 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 11 ms 2040 KB Output is correct
2 Correct 6 ms 2040 KB Output is correct
3 Correct 9 ms 2168 KB Output is correct
4 Correct 8 ms 2040 KB Output is correct