새소식

Computer Science/코딩테스트 문제 풀이

[예제] [파이썬] [그리디] 창고 정리

  • -

창고에 상자가 가로방향으로 일렬로 쌓여 있습니다.
만약 가로의 길이가 7이라면

1열은 높이가 6으로 6개의 상자가 쌓여 있고, 2열은 3개의 상자, 3열은 9개의 상자가 쌓여 있
으며 높이는 9라고 읽는다.
창고 높이 조정은 가장 높은 곳에 상자를 가장 낮은 곳으로 이동하는 것을 말한다.
가장 높은 곳이나 가장 낮은 곳이 여러곳이면 그 중 아무거나 선택하면 된다.
위에 그림을 1회 높이 조정을 하면 다음과 같아진다.

창고의 가로 길이와 각 열의 상자 높이가 주어집니다. m회의 높이 조정을 한 후 가장 높은 곳
과 가장 낮은 곳의 차이를 출력하는 프로그램을 작성하세요.

▣ 입력설명
첫 번째 줄에 창고 가로의 길이인 자연수 L(1<=L<=100)이 주어집니다.
두 번째 줄에 L개의 자연수가 공백을 사이에 두고 입력됩니다. 각 자연수는 100을 넘지
않습니다
세 번째 줄에 높이 조정 횟수인 M(1<=M<=1,000)이 주어집니다.

▣ 출력설명
M회의 높이 조정을 마친 후 가장 높은곳과 가장 낮은 곳의 차이를 출력하세요.

▣ 입력예제 1
10
69 42 68 76 40 87 14 65 76 81
50

▣ 출력예제 1
20


 

오름차순 정렬을 통해 가장 낮은 높이는 가장 왼쪽에 가장 높은 높이는 가장 오른쪽에 있고
가장 왼쪽 상자를 하나씩 증가, 가장 오른쪽 상자를 하나씩 감소 시킨다.

그리고 정렬을 반복한다. 

 


import sys
sys.stdin=open('input.txt','r')

if __name__=="__main__":
    L=int(input())
    boxes=list(map(int, input().split()))
    M=int(input())
    boxes.sort()
    for i in range(M):
        boxes[0]+=1
        boxes[-1]-=1
        boxes.sort()
            
    print(boxes[-1]-boxes[0])

 


그럼 이번에는 상자들의 높이가 가장 고르게 될때까지 최소 몇번을 수행해야하는지 알아보는 코드를 작성해보자.

 


import sys
sys.stdin=open('input.txt','r')

if __name__=="__main__":
    L=int(input())
    boxes=list(map(int, input().split()))
    M=int(input())
    boxes.sort()
    res=boxes[-1]-boxes[0]
    cnt=0
    while True:
        if res<=1:
            break
        boxes[0]+=1
        boxes[-1]-=1
        cnt+=1
        boxes.sort()

        res=boxes[-1]-boxes[0]

    
    print(cnt)
    print(boxes)
Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.