Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 역전파법
- c#
- 냥코 센세
- 오토인코더
- Autoencoder
- 수달
- project euler
- 신경망
- 비샤몬당
- SQL
- 오일러 프로젝트
- Gram matrix
- backpropagation
- mnist
- 소인수분해
- Python
- 베이지안
- Convolutional Neural Network
- 히토요시
- neural network
- CNN
- 역전파
- 합성곱 신경망
- deep learning
- A Neural Algorithm of Artistic Style
- 딥러닝
- bayesian
- 자전거 여행
- 소수
- 전처리
Archives
- Today
- Total
통계, IT, AI
10. Summation of primes 본문
1. 개요
문제는 이곳에서 확인할 수 있다. 200만보다 작은 소수의 합을 구하는 것이 목표이다.
소수를 찾는 데에는 에라토스테네스의 체를 이용한다. 예를 들어 2 이상 120 이하의 소수를 찾는다고 하자. 먼저 2를 남기고 2의 배수를 모두 지운다. 이후 3을 남기고 3의 배수를 모두 지운다. 다음 수인 4는 이미 지워졌으므로 5를 남기고 5의 배수를 모두 지운다. 이것을 120의 양의 제곱근보다 작은 정수 중 가장 큰 정수까지 반복하면 된다. 아래 그림은 이 방법에 대한 일러스트레이션이다. 1
2. Ver 1.0
using System; using System.Collections.Generic; using System.Linq; class ProjectEuler { static void Main(string[] args) { // 에라토스테네스의 체 List<int> seive = new List<int>(); int lim = 2000000; seive.Add(2); for(int i=3; i<lim; i+=2) { seive.Add(i); } for(int i=3; i<=Math.Sqrt(lim); i+=2) { seive.RemoveAll(p=> p>i && p%i==0); } Console.WriteLine(seive.Sum(p=> Convert.ToInt64(p))); } }
답은 142913828922이다.
- 출처: 영문 위키피디아(https://en.wikipedia.org/wiki/Sieve_of_Eratosthenes) [본문으로]
'IT > PROJECT_EULER' 카테고리의 다른 글
12. Highly divisible triangular number (0) | 2017.01.08 |
---|---|
11. Largest product in a grid (0) | 2017.01.03 |
9. Special Pythagorean triplet (0) | 2017.01.02 |
8. Largest product in a series (0) | 2017.01.01 |
7. 10001st prime (0) | 2016.01.14 |
Comments