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 | 31 |
Tags
- 입문
- 나는 리뷰어다
- Semantic Segmentation
- 나는리뷰어다
- 추천시스템
- 알고리즘
- 튜토리얼
- 한빛미디어
- Machine Learning Advanced
- 엘리스
- Image Segmentation
- hackerrank
- 프로그래머스
- Python
- TEAM EDA
- MySQL
- 스택
- DilatedNet
- TEAM-EDA
- Object Detection
- 협업필터링
- 큐
- 파이썬
- DFS
- Recsys-KR
- 코딩테스트
- pytorch
- eda
- 3줄 논문
- Segmentation
Archives
- Today
- Total
TEAM EDA
[프로그래머스] 소수 찾기 / 파이썬 본문
소수 찾기
문제 설명
한자리 숫자가 적힌 종이 조각이 흩어져있습니다. 흩어진 종이 조각을 붙여 소수를 몇 개 만들 수 있는지 알아내려 합니다.
각 종이 조각에 적힌 숫자가 적힌 문자열 numbers가 주어졌을 때, 종이 조각으로 만들 수 있는 소수가 몇 개인지 return 하도록 solution 함수를 완성해주세요.
제한사항
- numbers는 길이 1 이상 7 이하인 문자열입니다.
- numbers는 0~9까지 숫자만으로 이루어져 있습니다.
- 013은 0, 1, 3 숫자가 적힌 종이 조각이 흩어져있다는 의미입니다.
입출력 예
numbers | return |
---|---|
17 | 3 |
011 | 2 |
입출력 예 설명
예제 #1
[1, 7]으로는 소수 [7, 17, 71]를 만들 수 있습니다.
예제 #2
[0, 1, 1]으로는 소수 [11, 101]를 만들 수 있습니다.
단, 11과 011은 같은 숫자로 취급합니다.
풀이
- check라는 함수를 만들어서 소수를 판정
- 여기서, math.sqrt를 사용하는 이유는 제곱수의 경우 소수가 아니기 때문에 이를 통해 판정
- permutations를 이용해서 모든 경우의 수를 만들고 판정
- 단, 여기서 중복되는 수가 발생해서 set으로 미리 줄이고 하면 속도가 많이 빨라짐
- answer에 모든 소수를 집어넣고 길이를 출력하면 정답
from itertools import permutations
import math
def check(n):
k = math.sqrt(n)
if n < 2:
return False
for i in range(2, int(k)+1):
if n % i == 0:
return False
return True
def solution(numbers):
answer = []
for k in range(1, len(numbers)+1):
perlist = list(map(''.join, permutations(list(numbers), k)))
for i in list(set(perlist)):
if check(int(i)):
answer.append(int(i))
answer = len(set(answer))
return answer
다른사람 풀이
- 에라토스테네스 체를 이용해서 소수 판단
- 단, 위의 풀이에 비해 속도가 많이 느림
from itertools import permutations
def solution(n):
a = set()
for i in range(len(n)):
a |= set(map(int, map("".join, permutations(list(n), i + 1)))) # 모든 경우의 수를 만듬
a -= set(range(0, 2)) # 숫자 0과 1은 제거
# 모든 경우의 수에 대해서 소수 판정
for i in range(2, int(max(a) ** 0.5) + 1):
a -= set(range(i * 2, max(a) + 1, i))
return len(a)
출처: 프로그래머스 코딩 테스트 연습,https://programmers.co.kr/learn/challenges
'EDA Study > 알고리즘' 카테고리의 다른 글
[프로그래머스] 괄호 변환 / 파이썬 (2) | 2020.04.04 |
---|---|
[프로그래머스] 가장 큰 수 / 파이썬 (0) | 2020.04.04 |
[프로그래머스] 주식가격 / 파이썬 (2) | 2020.04.04 |
[프로그래머스] 큰 수 만들기 / 파이썬 (1) | 2020.04.03 |
[프로그래머스] 조이스틱 / 파이썬 (0) | 2020.04.03 |