본문 바로가기
알고리즘/programmers

[programmers] 두 개 뽑아서 더하기

by goldory 2021. 1. 4.
728x90
반응형

문제 설명

정수 배열 numbers가 주어집니다. numbers에서 서로 다른 인덱스에 있는 두 개의 수를 뽑아 더해서 만들 수 있는 모든 수를 배열에 오름차순으로 담아 return 하도록 solution 함수를 완성해주세요.

 

제한사항

  • numbers의 길이는 2 이상 100 이하입니다.
  • numbers의 모든 수는 0 이상 100 이하입니다.

입출력 예

 

내 코드

def solution(numbers):
    answer = []
    
    numbers = sorted(numbers)
    print(numbers)
    
    for i in range(len(numbers)):
        for j in range(i+1,len(numbers)):
            print(numbers[i],"+",numbers[j],"=",numbers[i]+numbers[j])
            answer.append(numbers[i]+numbers[j])
    
    answer = sorted(list(set(answer)))
    
    return answer

푸는데 한 10분정도 걸린 문제!

 

1. 입력값 정렬

2. 완전탐색으로 덧셈해주기

3. set 자료형을 활용하여 중복 제거 후 다시 리스트 자료형으로 반환

4. 반환값도 정렬이 되어있어야함

 

반환값 정렬때문에 테스트 2개를 바로 통과하지 못했다 ㅋㅋ ㅠㅠ 문제를 잘 읽자~~


Python 코드조각 - python list  중복 제거

set을 활용한다!

set은 집합 자료형으로 (1) 중복을 허용하지 않고 (2) 순서가 없다는 특징이 있다. 

 

따라서 위 문제를 예시로 설명하면 다음과 같다.

 

answer의 자료형은 list이다.

반복문을 통해 answer에는 중복되는 값이 들어가지만 우리는 중복되지 않은 값을 반환해야한다.

반환할 때 보통 set값을 그대로 반환하면 안되는 경우가 많다. 따라서 다시  list 자료형으로 변환해주는 것을 잊지말자!

#for example
answer = [2,3,4,5,3,4,5,5,6,7]

set(answer) # answer = {2,3,4,5,6,7}
list(set(answer)) # answer = [2,3,4,5,6,7]

 

 

다시 한번 말하지만 set 자료형은 순서가 없다. 문제에서 순서를 요구하는지 꼭 확인하자

728x90
반응형

'알고리즘 > programmers' 카테고리의 다른 글

[programmers] 체육복  (0) 2021.01.04
[programmers] K번째 수  (0) 2021.01.04
[programmers] 모의고사  (0) 2021.01.04
[programmers] 완주하지 못한 선수  (0) 2021.01.04
[programmers] 크레인 인형뽑기 게임  (0) 2021.01.03