장고에 빠져있다 보니 파이썬을 잊어가는 것만 같아서 오랜만에 프로그래머스를 풀어보았다😅
정수 배열 numbers가 주어집니다. numbers에서 서로 다른 인덱스에 있는 두 개의 수를 뽑아 더해서 만들 수 있는 모든 수를 배열에 오름차순으로 담아 return 하도록 solution 함수를 완성해주세요.
# 나의 풀이
def solution(numbers):
li = []
for i in range(len(numbers)):
for j in range(-1,-(len(numbers)),-1):
if i - len(numbers) != j:
a = numbers[i]+numbers[j]
li.append(a)
s = set(li)
return sorted(list(s))
아래가 다른 분들의 풀이이다. 파이썬 예제를 오랜만에 풀어보려니까 너무 무식하게 푼 것 같다..접근 자체는 좋았는데 좀 더 간결하고 쉽게 풀 수 있도록 해야겠다🙂
# 다른 분들의 풀이
def solution(numbers):
answer = []
for i in range(len(numbers)):
for j in range(i+1, len(numbers)):
answer.append(numbers[i] + numbers[j])
return sorted(list(set(answer)))