<Minimum Path cover in DAG>
DAG(Directed Acyclic Graph)에서 모든 정점을 커버하는 겹치지 않는 최소의 경로의 수를 구하는 문제
전체 정점의 수가 N 커버한 경로상의 간선이 X라면 N-X개의 경로로 커버할 수 있다.
만약에 간선으로 커버가 되지 않았다면, 각 정점 하나가 경로가 될 것이다.
따라서 최대한 간선을 많이 선택하면 된다.
따라서 X를 최대화 시켜야한다.
간선을 고를 때 제약 조건은 한 정점이 선택 될 때 오직 하나의 indegree와 오직 하나의 outdegree가 선택되어야 한다는 점이다.
즉, indegree와 outdegree가 최대한으로 매칭되어야 한다.
이를 이용하여 indegree를 상징하는 정점과 outdegree의 정점을 상징하는 정점으로 그래프를 구성하여 해당 그래프의 이분 매칭을 구함으로서 Minimum Path cover in DAG를 구할 수 있다.
'알고리즘' 카테고리의 다른 글
Sqrt Decompositon(평방분할) & Mo's Algorithm (0) | 2018.04.05 |
---|---|
문자열 해싱 (0) | 2018.03.31 |
L-R flow : 하한이 있는 플로우 (0) | 2018.03.31 |
유량 테크닉 (0) | 2018.03.31 |
codeforces)447b (0) | 2017.12.21 |