[CodeKata] 특정 배열에서 덧셈 조합찾기
2021. 9. 5. 23:35ㆍ코딩일지/CodeKata

two_sum 함수에 숫자 리스트와 '특정 수'를 인자로 넘기면, 더해서 '특정 수'가 나오는 index를 배열에 담아 return 해 주세요.
nums: 숫자 배열
target: 두 수를 더해서 나올 수 있는 합계
return: 두 수의 index를 가진 숫자 배열
예를 들어,
nums은 [4, 9, 11, 14]
target은 13
nums[0] + nums[1] = 4 + 9 = 13 이죠?
그러면 [0, 1]이 return 되어야 합니다.
Supposition
target으로 보내는 합계의 조합은 배열 전체 중에 2개 밖에 없다고 가정하겠습니다.
Solution
def two_sum(nums, target):
# 아래 코드를 작성해주세요.
my_dict = {}
for i in range(len(nums) - 1):
for j in range(i+1, len(nums)):
my_dict[nums[i] + nums[j]] = [i, j]
return my_dict[target]
딕셔너리변수를 빈 값으로 지정해주고 이중 for문을 돌려서 해결합니다.
첫 번째 반복문의 (nums)의 길이를 구해서 -1을 해준다 i 인자에 넣어줍니다.
(-1 넣은이유 out of range 오류 방지를 위해서이다. 마지막까지 더할 수 있기에)
두 번째 반복문에 j인자는 i를 제외한 숫자이기에 i인자에 +1을 해주고 처음부터 끝까지 길이를 구해 j 인자에 넣어준다.
그다음 빈 딕셔너리에 index [ i ]와 [ j ]를 키로 접근해서 더한 값을 list로 준다.
그리고 마지막 index [target]으로 반환해준다.

'코딩일지 > CodeKata' 카테고리의 다른 글
| [CodeKata] 문자열에서 중복되지 않는 제일 긴 단어의 길이 반환하기 (0) | 2021.09.11 |
|---|---|
| [CodeKata] 정수를 인자로 받아 뒤집어 반환하기 (0) | 2021.09.11 |