반응형
📜 문제
문제 설명
- 소인수분해란 어떤 수를 소수들의 곱으로 표현하는 것입니다. 예를 들어 12를 소인수 분해하면 2 * 2 * 3 으로 나타낼 수 있습니다. 따라서 12의 소인수는 2와 3입니다. 자연수 n이 매개변수로 주어질 때 n의 소인수를 오름차순으로 담은 배열을 return하도록 solution 함수를 완성해 주세요.
제한 사항
- 2 ≤ n ≤ 10,000
✅ 정답
def solution(n):
answer = []
num = 2
while num <= n:
if n % num == 0:
answer.append(num)
n = n // num
else:
num += 1
return list(dict.fromkeys(answer))
📌 풀이
- dic.fromkeys()를 사용하면 순서는 유지하면서 중복값들은 제거한다.
- set()을 사용하면 중복을 제거하지만 순서가 랜덤이므로 오답이 출력된다.
- dic.fromkeys(seq, value) 형태
- 딕셔너리를 생성할 때 편리하게 사용할 수 있는 메소드. seq 옵션 값에 문자열을 입력할 수도 있다.
- seq : 생성하려는 딕셔너리의 키(key)의 목록
- value : 생성하려는 dictionary의 값(value)
반응형
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[Python]프로그래머스_등수 매기기(LV.0) (0) | 2023.05.24 |
---|---|
[Python]프로그래머스_세균 증식(LV.0) (0) | 2023.04.09 |
[Python]프로그래머스_가위 바위 보(LV.0) (0) | 2023.04.09 |
[Python]프로그래머스_암호 해독(LV.0) (0) | 2023.04.06 |
[Python]프로그래머스_제곱수 판별하기(LV.0) (0) | 2023.04.06 |