티스토리 뷰
https://programmers.co.kr/learn/courses/30/lessons/49191
코딩테스트 연습 - 순위
5 [[4, 3], [4, 2], [3, 2], [1, 2], [2, 5]] 2
programmers.co.kr
먼저 한 사람의 순위를 확정하기 위해서는 해당하는 사람의 확실한 승패를 알고있는 경기가 n-1개여야 한다. (n은 총 사람수)
입력이 results 배열이 다음과 같이 주어지면
results = {{4,3}, {4,2}, {3,2}, {1,2}, {2,5}}
4 wins 3
4 wins 2
3 wins 2
1 wins 2
2 wins 5
라는 것인데
3번 사람을 보면, 3번은 2번을 이겼다 and 2번은 5번을 이겼다.
따라서 3번은 5번을 이겼다고 할수 있다.
이 문제의 핵심은 이렇게 직접적으로 나와있지 않은 승패를 모두 찾는 것이다.
찾는 방법은 그냥 3단 for loop를 돌리면 되지만 그 방식은 Floyd Warshall 과 유사하다고 볼 수 있다.
a가 b를 이겼다면
b가 c를 이겼는지 확인하고 이겼다면
a가 c를 이겼다고 볼 수 있다.
이렇게 직접적으로 나와있지 않은 승패를 모두 구하고
한 사람을 기준으로 그 사람이 이겼거나 진 경기가 n-1개 있는지 확인하면 된다.
승 패
(1 wins 2) or (2 wins 1)
(1 wins 3) or (3 wins 1)
...
이겼거나 진 경기가 있다면 카운트를 늘려주고 카운트가 n-1개 라면 해당 선수의 등수를 확정지을수 있다.
'PS' 카테고리의 다른 글
| 백준 10610. 30 (0) | 2022.01.02 |
|---|---|
| 프로그래머스. 불량 사용자 (0) | 2021.12.30 |
| 프로그래머스. 합승 택시 요금 (플로이드 와샬) (0) | 2021.12.30 |
| 백준 1783. 병든 나이트 (0) | 2021.12.27 |
| 프로그래머스. 디스크 컨트롤러 (0) | 2021.12.26 |
- Total
- Today
- Yesterday
- Tree
- MVC
- BFS
- graph
- Spring
- Implementation
- Kruskal
- Python
- priority queue
- Brute Force
- dfs
- 자료구조
- Dijkstra
- Unity
- Stack
- binary search
- db
- floyd warshall
- greedy
- two pointer
- recursion
- C
- DP
- back tracking
- 조합
- 이분탐색
- CSS
- C++
- 재귀
- permutation
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 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 |
