반응형
Notice
Recent Posts
Link
«   2025/04   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
Archives
Today
Total
관리 메뉴

500error

[Cos Pro 1급, Python] 6차 3번 : 큰수와 작은수의 차이 본문

알고리즘/파이썬

[Cos Pro 1급, Python] 6차 3번 : 큰수와 작은수의 차이

Internal Server Error 2024. 3. 3. 15:59
반응형

문제

자연수가 들어있는 배열에서 숫자 K개를 선택하려 합니다. 이때, 선택한 숫자 중 가장 큰 수와 가장 작은 수의 차이가 최소가 되도록 해야합니다.
예를 들어 배열에 들어있는 숫자가 [9, 11, 9, 6, 4, 19] 이고, K = 4 라면
 
  • 숫자 4개를 [9, 11, 9, 6]로 뽑으면 (가장 큰 수 - 가장 작은 수) = (11 - 6) = 5가 됩니다.
  • [9, 9, 6, 4] 와 같이 숫자를 뽑아도  (가장 큰 수 - 가장 작은 수) = (9 - 4) = 5가 됩니다.
그러나 가장 큰 수와 가장 작은 수의 차이가 5보다 작아지도록 숫자 4개를 선택하는 방법은 없습니다.
자연수가 들어있는 배열 arr, arr의 길이 arr_len, 선택해야 하는 숫자 개수 K가 매개변수로 주어질 때, 선택한 숫자중 가장 큰 수와 가장 작은 수의 차이가 최소가 되록 arr에서 숫자 K개를 선택했을 때, 그때의  가장 큰 수와 가장 작은 수의 차이를 return 하도록 solution 함수를 완성해주세요.

 

 

 

 

 

 

 

 

 

 

코드

from itertools import combinations



def solution(arr, K):
	answer = 0
	
	num = 10001
	
	com = list(combinations(arr, K))
	
	for i in com :
		com_i = list(set(i))
		min_i = min(i)
		max_i = max(i)
		
		result = max_i - min_i
		
		
		if result < num :
			num = result
			
			answer = num
	
	
	return answer
    
    
    
    
    
arr = [9, 11, 9, 6, 4, 19]
K = 4
ret = solution(arr, K)

print("solution 함수의 반환 값은", ret, "입니다.")
반응형
Comments