일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Big-O 예제
- 일차변환
- Big Omega
- python
- linear dependence
- itertools
- 이진 탐색
- 배열 섞기
- 빅오 표기법
- 빅오메가
- 재귀함수
- matrix trnasformations
- homogeneous linear system
- 코틀린 시작하기
- nonhomogeneous linear system
- NumPy
- Big-Oh 예제
- matrix fo a linear transformation
- 랜덤 순서 배열
- trivial solution
- 빅세타
- 페이지 겹칩
- includepdf
- recursive algorithms
- one-to-one
- Big-Oh notation
- nontrivial solution
- 코틀린 Hello World!
- 알고리즘 분석의 실례
- Big Theta
- Today
- Total
코딩 연습
프로젝트 오일러 123번 본문
Let pn be the nth prime : 2,3,5,7,11,⋯, and let r be the remainder when (pn−1)n+(pn+1)n is divided by p2n.
For example, when n=3,p3=5, and 43+63=280≡5 mod 25.
The least value of n for which the remainder first exceeds 109 is 7037.
Find the least value of n for which the remainder first exceeds 1010.
pn 이 2,3,5,7,11,⋯ 에서 n 번째 소수를 나타낸다고 하자. 또한 r 은 (pn−1)n+(pn+1)n 을 p2n 으로 나눈 나머지라고 하자.
예를 들어, n=3 이면 pn=5 가 되고, (5−1)3+(5+1)3 을 52 으로 나눈 나머지는 5가 된다.
이런식으로 나머지를 계산해 나갈 때, 처음으로 나머지가 109 을 넘게 되는 n 은 7037 이 된다.
처음으로 나머지 r 가 1010 을 넘게 되는 n 의 값을 구하시오.
이 문제를 쉽게 풀기 위해서는 120번 문제의 두 번째 풀이법을 알고 있어야 한다.
120번 문제에 따르면 (pn−1)n+(pn+1)n 을 p2n 으로 나눈 나머지는 n 이 짝수일 때는 2 가 되고, n 이 홀수일 때는 2×n×pn 을 p2n 으로 나눈 나머지와 같다.
따라서 이 문제는 소수들의 리스트를 먼저 만든 다음, n=7039 부터 2 씩 증가시면서 2×n×pn 을 p2n 으로 나눈 나머지들만 살펴보면 된다.
빠른 시간 내에 답을 구할 수 있을 것이다.
'project euler with python' 카테고리의 다른 글
프로젝트 오일러 125번 (0) | 2016.03.15 |
---|---|
프로젝트 오일러 124번 (0) | 2016.03.15 |
프로젝트 오일러 122번 (0) | 2016.03.15 |
프로젝트 오일러 121번 (0) | 2016.03.15 |
프로젝트 오일러 120번 (0) | 2016.03.15 |