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 |