사용자 도구

사이트 도구


ps:problems:boj:2569

문제제목

ps
링크acmicpc.net/…
출처BOJ
문제 번호2569
문제명짐정리
레벨플래티넘 1
분류

그리디

시간복잡도O(n)
인풋사이즈n<=1000
사용한 언어Python
제출기록30864KB / 68ms
최고기록56ms
해결날짜2022/03/02

풀이

코드

"""Solution code for "BOJ 2569. 짐정리".

- Problem link: https://www.acmicpc.net/problem/2569
- Solution link: http://www.teferi.net/ps/problems/boj/2569

Tags: [Greedy]
"""

import sys


def main():
    n = int(sys.stdin.readline())
    w = [int(sys.stdin.readline()) for x in range(n)]

    min_w = min(w)
    orders = sorted(range(n), key=w.__getitem__)
    is_visited = [False] * n
    answer = 0

    for i in range(n):
        if is_visited[i]:
            continue
        weights = []
        cur = i
        while not is_visited[cur]:
            is_visited[cur] = True
            weights.append(w[cur])
            cur = orders[cur]
        answer += min(
            sum(weights) + min(weights) * (len(weights) - 2),
            sum(weights) + min(weights) + min_w * (len(weights) + 1))
    print(answer)


if __name__ == '__main__':
    main()

토론

댓글을 입력하세요:
A O I M​ E
 
ps/problems/boj/2569.txt · 마지막으로 수정됨: 2022/03/04 16:30 저자 teferi