[프로그래머스] 코딩테스트 연습 소수찾기 - 완전탐색

JinUk Lee·2022년 12월 29일
0

프로그래머스

목록 보기
4/47

https://school.programmers.co.kr/learn/courses/30/lessons/42839

from itertools import permutations

def solution(numbers):

    num_list = list(numbers)

    per_list = []

    for i in range(1,len(numbers)+1):
        per_list += list(permutations(num_list,i))

    num_list = [  int(''.join(i)) for i in per_list]

    num_list = list(set(num_list))

    if 0 in num_list:
        num_list.remove(0)

    if 1 in num_list:
        num_list.remove(1)


    ans_list = []
    for i in num_list:
        check = True

        for j in range(2,int(i**0.5)+1):
            if i%j == 0:
                check = False
                break
        if check:
            ans_list.append(i)

    answer = len(ans_list)
    return answer

print(solution('011'))

순열을 사용하여 푸는 문제였다.

소수 판별=> 해당 소수의 제곱근까지만 해준다.

profile
개발자 지망생

0개의 댓글