문제 제목 : 소수 찾기
문제 출처 : 프로그래머스
알고리즘 : Brute Force
https://school.programmers.co.kr/learn/courses/30/lessons/42839
from itertools import permutations
def makePrime(n):
prime=[0,0]+[1]*~-n
for i in range(int(n**.5)+1):
if prime[i]:prime[i*i::i]=[0]*(n//i-i+1)
return prime
def solution(numbers):
ans = 0; nlen = len(numbers)
num = [i for i in numbers]
p = makePrime(10000000)
perm = []
for i in range(1, nlen+1): perm += list(permutations(num, i))
num_arr = [int(("").join(p)) for p in perm]
for i in num_arr:
if p[i]: ans+=1; p[i] = 0
return ans
'Problem Solving' 카테고리의 다른 글
[Math] 점프와 순간이동-프로그래머스 (0) | 2022.10.12 |
---|---|
[Queue] 다리를 지나는 트럭-프로그래머스 (0) | 2022.10.11 |
[Simulation] 교차로-소프티어(별3) (0) | 2022.09.04 |
[Brute Force] 카펫-프로그래머스(Lv.2) (0) | 2022.07.24 |
[Brute Force] 모의고사-programmers(Lv.1) (0) | 2022.07.24 |