| 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 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
													
											
												
												- enumerate
- python
- project euler
- 세그먼트 트리
- datetime
- 큰 수 나누기
- 자료구조
- list comprehension
- SUM
- 에라토스테네스의 체
- 외래키
- lower_case_table_names
- SUM()
- 파이썬
- mysql
- itertools
- Codeforces
- 네이밍
- 소수
- 리스트 컴프리헨션
- 2557
- ceil
- Dictionary
- convention
- BOJ
- 딕셔너리
- FOREIGN KEY
- flask
- timestamp
- floor
													Archives
													
											
												
												- Today
- Total
늒네 기록
[PE] Project Euler 37 본문
프로젝트 오일러 37번도 나이브하게 덤볐는데도 풀린 문제. 이 문제는 어떤 숫자 p가 주어졌을때, 이 숫자 자체도 소수이면서 좌측부터 숫자를 하나씩 제거하면서 만드는 숫자들도 전부 소수, 우측부터 숫자를 하나씩 제거하면서 만드는 숫자들도 전부 소수인 숫자를 truncatable prime이라고 정의하고, 딱 11개 존재하는 이 숫자들을 전부 찾아서 더하라는 문제다.
별 다른 테크닉 없이 10부터 시작하여 1씩 더해가면서 해당 숫자가 조건을 만족하면 리스트에 더하는 루프를 돌고, 리스트 크기가 11이 되면 루프를 빠져나오는 식으로 구현했다.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | def p_test(n):     if n<2: return False     for i in range(2,int(n**0.5)+1):         if n%i==0: return False     return True def tp_test(n):     nn = str(n)     for i in range(len(nn)):         if not p_test(int(nn[i:])):             return False         if not p_test(int(nn[:i+1])):             return False     return True l = [] x = 10 while len(l)<11:     if tp_test(x):          print(x)         l.append(x)     x+=1 print(sum(l)) | cs | 
이렇게 짜도 10초 미만에 답을 구할 수 있다.
반응형
    
    
    
  '알골 공부 기록 > Project Euler' 카테고리의 다른 글
| [PE] Project Euler 41 (0) | 2020.10.04 | 
|---|---|
| [PE] Project Euler 27 (0) | 2020.10.04 | 
| [PE] Project Euler 72 (0) | 2020.10.03 | 
| [PE] Project Euler 57 (0) | 2020.10.03 | 
| [PE] Project Euler 55 (0) | 2020.10.03 | 
			  Comments