Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 기술면접
- 다이나믹프로그래밍
- 부스트캠프_AITech_3기
- 프로그래머스
- Level1
- 알고리즘스터디
- 최단경로
- 이진탐색
- Level2_PStage
- 백준
- 단계별문제풀이
- dfs
- mrc
- 알고리즘_스터디
- 다시보기
- 이코테
- ODQA
- 개인회고
- 구현
- U_stage
- 그리디
- 백트랙킹
- 부스트캠프_AITech3기
- Level2
- python3
- 파이썬 3
- 정렬
- 주간회고
- dp
- 그래프이론
Archives
- Today
- Total
국문과 유목민
9. 나누어 떨어지는 숫자 배열 본문
0. 문제
링크) https://programmers.co.kr/learn/courses/30/lessons/12910
1. 알고리즘 계획
- for문을 통해 리스트를 만든다. (리스트 컴프리핸션 이용)
- 새로 만든 리스트에 값이 들어가 있지 않으면 -1값을 추가
2. 나의 코드
def solution(arr, divisor):
answer = [v for v in arr if (v % divisor) == 0 ]
if len(answer) == 0:
answer.append(-1)
return sorted(answer)
3. 다른 사람의 코드
def solution(arr, divisor):
return sorted([n for n in arr if n%divisor == 0]) or [-1]
- OR의 특성을 이용한 풀이
- 나누어 떨어지지 않을 경우 -1을 return하게 함으로써 if문 코드 한 줄을 줄였다.
4. 정리 및 리뷰
- OR을 이용한 풀이가 굉장히 신박했다고 생각하지만,
- 기존에 기본적인 for문을 이용했다가, 리스트 컴프리핸션을 이용해 코드를 간추렸다는 점에서 내 코드도 만족스럽다.
코드 만족도: ★★★★☆
'알고리즘_코딩테스트 > 프로그래머스_Level1' 카테고리의 다른 글
11. 문자열 내 마음대로 정렬하기 (0) | 2020.09.10 |
---|---|
10. 두 정수 사이의 합 (0) | 2020.09.09 |
8. 같은 숫자는 싫어 (0) | 2020.09.09 |
7. 가운데 글자 가져오기 (0) | 2020.09.09 |
6. 2016년 (0) | 2020.09.09 |
Comments