알고리즘 문제풀이/백준

[백준2262] 토너먼트 만들기

taemin 2021. 5. 3.

www.acmicpc.net/problem/2262

 

2262번: 토너먼트 만들기

월드시에서는 매년 n명의 사람들이 모여 월드 크래프트라는 게임의 토너먼트 대회를 치른다. 이 게임은 특성상 실력만이 승패를 좌우하기 때문에, 아무리 실력이 엇비슷한 사람이 시합을 치러

www.acmicpc.net

 

풀이

 

처음에는 DP인가 생각했다. 결국 못풀어 답을 참고하니 간단한 그리디 문제였다.

 

붙는 선수끼리의 랭킹차이가 적어야 한다.

이기는 선수(여러번 붙는 선수)는 랭킹이 높은 선수이다.

따라서 낮은 랭킹이 올라가서 여러번 붙으면 안된다. 올라가는 선수들은 랭킹이 높은 선수들이기 때문에 차이값이 많아진다.

즉 랭킹이 낮은 선수부터 시합을 뛰게해 제거한다.

 

랭킹이 제일 낮은 선수를 찾고 양 옆의 선수중 차이가 적은 선수랑 붙는다.

그리고 랭킹이 낮은 선수를 제거한다.

1명이 남을 때까지 반복한다.

 

시간복잡도

반복문이 n의 크기만큼 돈다. 한번 반복문에서 max, min, index, del 함수를 사용한다. 모두 시간복잡도가 O(n)이다.

즉 총 시간복잡도는 O(n^2)이다.

코드

n = int(input())
ranks = list(map(int,input().split()))
answer = 0
while len(ranks) !=1:
    rank = max(ranks)
    idx = ranks.index(rank)
    diff = 0

    if idx == 0:
        diff = rank - ranks[1]
    elif idx == len(ranks)-1:
        diff = rank - ranks[idx-1]
    else:
        diff = min(rank - ranks[idx-1],rank - ranks[idx+1])
    answer+=diff
    del ranks[idx]

print(answer)

 

'알고리즘 문제풀이 > 백준' 카테고리의 다른 글

[백준1747] 소수&팰린드롬  (0) 2021.05.05
[백준2872] 우리집엔 도서관이 있어  (0) 2021.05.05
[백준3980] 선발 명단  (0) 2021.05.05
[백준1958] LCS 3  (0) 2021.05.03
[백준1114] 통나무 자르기  (0) 2021.05.03

댓글