본문으로 바로가기


[  이것이 취업을 위한 코딩테스트다 with 파이썬  ]


큰 수의 법칙 _ Python 파이썬


 

" 문제 "

 

동빈이의 큰수의 법칙은 다양한 수로 이루어진 배열이 있을 떄 주어진 수들을 M번 더하여
가장 큰수를 만드는 방법이다. 단, 배열의 특정한 인덱스에 해당하는 수가 연속해서 K번을 초과하여
더해 질수 없는 것이 이법칙의 특징이다.
예를 들어 순서대로 2, 4, 5, 4, 6으로 이루어진 배열이 있을 때, M이 8이고 K가 3이라고 가정하자
이 경우 특정한 인덱스의 수가 연속해서 세번까지만 더해질 수 있으므로 큰 수의 법칙에 따른 결과는
6 + 6 + 6 + 5 + 6 + 6 + 6 + 5 46이 된다.
, 서로 다른 인덱스에 해당하는 수가 같은 경우에도 서로 다른 것으로 간주한다. 예를 들어
순서대로 3, 4, 3, 4, 3으로 이루어진 배열이 있을 때 M이 7이고 K가 2라고 가정하자.
이 경우 두번째 원소에 해당하는 4와 네 번째 원소에 해당하는 4를 번갈아 두번씩 더하는 것이 가능하다.
결과적으로 4 + 4 + 4 + 4 + 4 + 4 + 4  28이 도출된다.
배열의 크기 N, 숫자가 더해지는 횟수 M, 그리고 K가 주어질 떄 동빈이의 큰수의 법칙에 따른 결과를
제출하시오

입력 조건
첫째 줄에 N(2 <= N <= 1000), M(1 <= M <= 10000), K(1 <= K <= 10000)
의 자연수가 주어지며 각자연수는 공백으로 구분한다.
둘째 줄에 N개의 자연수가 주어진다. 각 자연수는 공백으로 구분한다. 단, 각각의 자연수는 1 이상 10000 이하의 수로 주어진다.
입력으로 주어지는 K는 항상 M보다 작거나 같다.

출력 조건
첫째 줄에 동빈이의 큰수의 법칙에 따라 더해진 답을 출력한다.




" 아이디어 "

배열에서 가장 큰 수와 두번째로 크거나 같은 수를 구해서

가장 큰수를 k회 연속해서 더한 후 두번째로 큰 수를 한번 더하는 것을 반복하면 된다.

그때그때 가장 큰 수를 선택하는 그리디 알고리즘을 이용하므로

가장 큰 수와 두번째로 큰 수 이외의 수는 사용하지 않는다.

 

while 루프르 사용해도 되지만

조금 더 규칙을 활용해서 풀어보았다.




" 코드 "


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
n, m, k = map(int, input().split())
arr = list(map(int, input().split()))
 
arr.sort(reverse=True)
n1 = arr[0]
n2 = arr[1]
 
= m // (k+1)
mod = m % (k+1)
result = n1 * i * k + n2 * i
 
if mod != 0:
  result += mod * n1
 
print(result)
cs

 




" 참고자료 "

 

 

 

반응형