코딩 연습

프로젝트 오일러 123번 본문

project euler with python

프로젝트 오일러 123번

코딩아저씨 2016. 3. 15. 15:55
반응형

Let pn be the nth prime : 2,3,5,7,11,, and let r be the remainder when (pn1)n+(pn+1)n is divided by p2n.

For example, when n=3,p3=5, and 43+63=2805 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.




pn2,3,5,7,11, 에서 n 번째 소수를 나타낸다고 하자. 또한 r(pn1)n+(pn+1)np2n 으로 나눈 나머지라고 하자.

예를 들어, n=3 이면 pn=5 가 되고, (51)3+(5+1)352 으로 나눈 나머지는 5가 된다. 

이런식으로 나머지를 계산해 나갈 때, 처음으로 나머지가 109 을 넘게 되는 n7037 이 된다.

처음으로 나머지 r1010 을 넘게 되는 n 의 값을 구하시오.  


이 문제를 쉽게 풀기 위해서는 120번 문제의 두 번째 풀이법을 알고 있어야 한다.

120번 문제에 따르면 (pn1)n+(pn+1)np2n 으로 나눈 나머지는 n 이 짝수일 때는 2 가 되고, n 이 홀수일 때는 2×n×pnp2n 으로 나눈 나머지와 같다. 

따라서 이 문제는 소수들의 리스트를 먼저 만든 다음, n=7039 부터 2 씩 증가시면서 2×n×pnp2n 으로 나눈 나머지들만 살펴보면 된다.

빠른 시간 내에 답을 구할 수 있을 것이다. 


반응형

'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


Comments