TIL#78 예제연습(7)

Dasom·2020년 10월 1일
0

python

목록 보기
38/50
post-thumbnail

장고에 빠져있다 보니 파이썬을 잊어가는 것만 같아서 오랜만에 프로그래머스를 풀어보았다😅

정수 배열 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)))
profile
개발자꿈나무🌲

0개의 댓글