본문 바로가기

파이썬 알고리즘 풀이

3) K번째 큰 수

문제

현수는 이 중 3장을 뽑아 각 카드에 적힌 수를 합한 값을 기록하려 고 합니다. 3장을 뽑을 수 있는 모든 경우를 기록합니다. 기록한 값 중 K번째로 큰 수를 출력 하는 프로그램을 작성하세요.

 

조건

현수는 1부터 100사이의 자연수가 적힌 N장의 카드를 가지고 있습니다. 같은 숫자의 카드가 여러장 있을 수 있습니다.

 

제한사항

첫 줄에 자연수 N(3<=N<=100)과 K(1<=K<=50) 입력되고, 그 다음 줄에 N개의 카드값이 입력 된다.

첫 줄에 K번째 수를 출력합니다. K번째 수는 반드시 존재합니다.

 

문제풀이

N, K = map(int, input().split())
a = list(map(int, input().split()))

res=set()

for i in range(N):
  for j in range(i+1, N):
    for m in range(j+1, N):
      res.add(a[i] + a[j] + a[m])

res=list(res)
res.sort(reverse=True)
print(res[K-1])

'파이썬 알고리즘 풀이' 카테고리의 다른 글

6) 자릿수의 합  (0) 2021.10.19
5) 정다면체  (0) 2021.10.19
4) 대표값  (0) 2021.10.19
2) K번째 수  (0) 2021.10.19
1) K번째 약수  (0) 2021.10.18