티스토리 뷰
728x90
반응형
https://programmers.co.kr/learn/courses/30/lessons/68644
코딩테스트 연습 - 두 개 뽑아서 더하기
정수 배열 numbers가 주어집니다. numbers에서 서로 다른 인덱스에 있는 두 개의 수를 뽑아 더해서 만들 수 있는 모든 수를 배열에 오름차순으로 담아 return 하도록 solution 함수를 완성해주세요. 제한
programmers.co.kr
<나의 풀이>
# 조합함수를 사용하기 위한 모듈 추가
from itertools import combinations
def solution(numbers):
answer = []
numbers.sort()
for n in numbers:
i = numbers.index(n)
new_list = numbers[:i] + numbers[i+1:] # n을 제외하고 새로운 리스트에 추가
combin = list(combinations(new_list, 2)) # 조합 함수를 통해 숫자들의 조합 만들기
for a, b in combin:
if (a+b) not in answer: # 각 숫자의 조합의 합이 answer에 없으면 추가
answer.append(a+b)
answer.sort()
return answer
<다른 사람의 풀이>
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)))
# <배운점>
# => set 함수로 중복 제거한 점
728x90
반응형
'[그 외] > ㄴ (코테연습 : 파이썬 ver)' 카테고리의 다른 글
[프로그래머스] 실패율 (파이썬) (0) | 2021.06.21 |
---|---|
[프로그래머스] 3진법 뒤집기 (0) | 2021.06.19 |
[프로그래머스] [1차] 비밀지도 (파이썬) (0) | 2021.06.18 |
[프로그래머스] 2016년 (파이썬) (0) | 2021.06.18 |
[프로그래머스] 가운데 글자 가져오기 (0) | 2021.06.18 |
댓글
250x250
반응형
TAG
- 프로그래머스 프로그래머스문제
- x만큼간격이있는n개의숫자
- 프로그래머스문제
- 설치
- SWiFT
- GIT
- 파이썬
- 월간 코드 챌린지 시즌2
- 유닉스커맨드
- 코드잇
- 프로그래머스
- 코딩테스트
- 프로그래머스코딩테스트
- 이진탐색
- Summer/Winter Coding(~2018)
- 재귀함수
- 피보나치
- 정렬
- 알고리즘
- 알고리즘문제
- 조합
- level2
- 컴퓨터개론
- 백준
- 프로그래밍언어
- KAKAO
- 파이썬문법
- 문법
- 월간 코드 챌린지 시즌1
- level1
최근에 달린 댓글
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
링크
- Total
- Today
- Yesterday