Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- 백준
- BOJ
- BST
- graph
- Cycle detecting
- Eulerian path
- POJ
- hashing
- BFSDFS
- GCD
- Segment Tree
- mathematics
- Dag
- graph modeling
- Shortest path
- bitmask
- flows
- implementation
- CS Academy
- Sieve_of_Eratosthenes
- Algospot
- disjoint-set
- DynamicProgramming
- scc
- Eulerian circuit
- dynamic programming
- Euler circuit
- Euler path
- backtracking
- Greedy
Archives
- Today
- Total
목록Networkflow (1)
그냥 하는 노트와 메모장
BOJ 2679 - Route Redundancy(맨체스터의 도로)
A에서 B로 갈 수 있는 모든 경로의 차의 수 최대값은 최대 유량으로 충분히 가능하다. 하지만 또 하나가 있는게 이 중에서도 한 경로만 사용했을 때, 최대값을 구해서 앞서 구한 모든 경로의 차의 최대값과 한 경로의 차의 수 최대값의 비율을 계산하라고 한다. 단순 최대유량 문제만 내기엔 부족했나보다. 편의상 A에서 B로 가는 모든 경로의 차의 수 최대값을 X라고 하고, 한 경로의 차의 수 최대값을 Y라고하면 구하고자 하는 값은 Y/X가 된다. X는 단순 최대 유량으로 구해서 계산하며 Y는 backtracking으로 정의하여 계산한다. Y를 구할 때, 기저 사례는 B를 만날 때까지고, 재귀를 돌며 방문했던 정점은 다시 방문하지 않도록 한다. 재귀의 반환값은 현재 정점에서 방문 가능한 정점 중에서 차를 최대한..
Solved problems
2018. 1. 9. 22:20