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