일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- java #자바 #나동빈
- 알고리즘
- 파이썬 #백준 #알고리즘 #코딩테스트
- 백준 #파이썬 #알고리즘 #코딩테스트
- 파이썬
- 다익스트라
- BFS
- react #리액트 #동빈나
- 프로그래머스 #파이썬 #코딩테스트 #알고리즘
- dp
- css #생활코딩 #웹
- 백트랙킹
- 코딩테스트
- 파이썬 #알고리즘 #코딩테스트 #프로그래머스
- 투포인터
- css #웹 #생활코딩
- 백준 #알고리즘 #파이썬 #코딩테스트
- Dijkstra
- java #자바
- 자바 #java
- 다이나믹프로그래밍
- 프로그래머스 #파이썬 #알고리즘 #코딩테스트
- react #리액트 #동빈나 #나동빈 #유튜브강의
- 프로그래머스
- 재귀
- 백준
- java #자바 #생활코딩
- PYTHON
- java #자바 #동빈나
- DFS
Archives
- Today
- Total
커리까지
백준 5636번 소수 부분 문자열 파이썬 본문
728x90
SMALL
문제
숫자로 이루어진 문자열이 주어진다. 이때, 부분 문자열 중에서 가장 큰 소수를 찾는 프로그램을 작성하시오.
이 문제에서는 2보다 크거나 같고, 100,000보다 작거나 같은 소수만 소수이다.
입력
입력은 여러 개의 테스트 케이스로 이루어져 있다. 테스트 케이스의 개수는 1,000개를 넘지 않는다.
각 테스트 케이스는 길이가 255를 넘지 않는 숫자 문자열로 이루어져 있다. 입력의 마지막 줄에는 0이 하나 주어진다.
출력
각 테스트 케이스에 대해서, 가장 큰 소수 부분 문자열을 출력한다.
예제 입력 1
11245
91321150448
1226406
0
예제 출력 1
11
1321
2
제출답안
import math
import sys
input = sys.stdin.readline
def is_prime_number(x):
for i in range(2, int(x ** 0.5) + 1):
if x % i == 0:
return False
return True
num_list = []
for i in range(2,100000+1):
if is_prime_number(i) == True:
num_list.append(i)
list_prime = []
k = 1
while True:
a = list(input().strip())
max_num = 0
if sum(list(map(int,a))) == 0:
break
number = 1
while number < len(a):
b = 0
for i in range(number,len(a)+1):
prime = int(''.join(a[b:i]))
if prime in num_list:
max_num = max(max_num,prime)
b +=1
number +=1
if prime in num_list:
max_num = max(max_num, prime)
if 1 < max_num <= 100000:
list_prime.append(str(max_num))
print('\n'.join(list_prime))
- 우선 범위인 2~100,000까지 소수를 다 구한다.
- 입력받은 문자열을 1개,2개,3개씩 길이만큼 계속 만들어서 소수를 확인한다.
- 그러면서 max를 비교해서 리스트에 저장한다.
- 최종적으로 출력하자.
728x90
LIST
'알고리즘 > 풀이' 카테고리의 다른 글
프로그래머스 2021 카카오 블라인드 신규 아이디 추천 파이썬 (0) | 2021.03.01 |
---|---|
백준 9020번 골드바흐의 추축 파이썬 (0) | 2021.02.26 |
백준 2623번 음악프로그램 파이썬 (0) | 2021.02.24 |
백준 14950번 정복자 파이썬 (0) | 2021.02.24 |
백준 10775번 공항 파이썬 (0) | 2021.02.22 |
Comments