로그인하고 있지 않습니다. 편집하면 당신의 IP 주소가 공개적으로 기록됩니다. 계정을 만들고 로그인하면 편집 시 사용자 이름만 보이며, 위키 이용에 여러 가지 편의가 주어집니다.스팸 방지 검사입니다. 이것을 입력하지 마세요!'''에라토스테네스의 체'''(sieve of Eratosthenes)는 특정 범위의 [[자연수]] 중 [[소수 (정수)|소수]]를 찾는 알고리즘이다. 명칭에서 알 수 있듯이 고대 그리스의 수학자인 에라토스테네스가 처음 고안한 방법으로, 꽤 고전적인 방법이면서도 소수 찾기의 초석이 되는 데 의미가 있다. == 아이디어 == 2부터 <math>N</math>까지의 자연수 집합이 주어져 있다. 목표는 이 집합 내에서 [[합성수]]를 걸러내고 소수들만 남기는 것이다. 에라토스테네스의 체의 알고리즘을 세우는 데 앞서 아래 정리들을 짚고 넘어간다. * 모든 자연수 <math>1<m<\sqrt{n}</math>에 대해 <math>m \nmid n</math>이면 <math>n</math>은 소수이다. * 자연수 <math>a,b,n</math>에 대해 <math>ab \mid n</math>이면 <math>a \mid n, b \mid n</math>이다. 즉 <math>a \nmid n</math>이라는 사실이 확인되면 자동으로 모든 <math>a</math>의 배수는 <math>n</math>의 약수가 아니게 된다. * 1을 제외한 가장 작은 약수가 <math>q</math>인 합성수 중 가장 작은 수는 <math>q^2</math>이다. 첫째와 둘째 정리를 종합하면, <math>\sqrt{N}</math> 이하의 모든 소수들로 나눗셈을 해보면 <math>N</math> 이하의 모든 합성수를 지울 수 있다. == 알고리즘 == [[파일:Sieve of Eratosthenes animation.gif|오른쪽]] 오른쪽 그림은 2부터 120까지의 자연수에 대한 에라토스테네스의 체의 적용 과정을 나타낸 것으로, 아래 방법을 따라간다. *<math>p \le \lfloor \sqrt{120} \rfloor</math>을 만족하는 소수 <math>p</math>를 먼저 찾는다. 이 소수들은 2, 3, 5, 7이다. *2를 제외한 2의 배수를 지운다. (4부터 시작) *3을 제외한 3의 배수를 지운다. (9부터 시작) *5를 제외한 5의 배수를 지운다. (25부터 시작) *7을 제외한 7의 배수를 지운다. (49부터 시작) *다음 소수는 11이지만 11의 제곱은 121로 주어진 범위를 벗어난다. 따라서 여기까지 남은 수들은 모두 소수이다. == 집합을 이용한 접근 == 위 글을 집합을 도입해서 서술하면 아래와 같이 써진다. 먼저 몇 가지 문자를 정의한다. *<math>P_1 = \emptyset</math> *<math>A_1 = \{x \in \mathbb{N}|2 \le x \le N \}</math> *<math>p_k</math>는 집합 <math>A_k</math> 내의 가장 작은 원소이다. 즉 <math>p_k=\min(A_k)</math>이며, 이는 <math>k</math>번째 소수를 의미한다. *<math>B_k = \{p_k x| x \in A_k,p_k x \le N \}</math> *<math>A_{k+1} = A_{k} \setminus (B_k \cup \{p_k \})</math> *<math>P_{k+1} = P_{k} \cup \{p_k \}</math> *<math>B_m = \emptyset</math>이 되면 알고리즘을 종료한다. 이때 <math>P_m \cup A_m</math>이 바로 <math>N</math> 이하의 소수들의 집합이다. 가령 <math>N=120</math>일 때, 알고리즘은 아래와 같이 서술할 수 있다. #<math>P_1 = \emptyset,\ A_1 = \{2, 3, 4, 5, \cdots 119, 120 \}</math> #*<math>p_1 = \min(A_1) = 2</math>: 첫 번째 소수는 2이다. #*<math>B_1 = \{4, 6, 8, 10, \cdots 118, 120 \}</math>: 이 집합은 1을 제외한 가장 작은 약수가 2인 120 이하의 합성수들을 모은 것이다. #*<math>A_1</math>에서 <math>B_1</math>의 원소들을 지운다. 또, 나눗셈 검사를 마친 원소인 2는 <math>A_1</math>에서 빼고 <math>P_2</math>에 넣는다. #<math>P_2 = \{2 \},\ A_2 = A_1 \setminus (B_1 \cup \{2 \}) = \{3, 5, 7, 9, \cdots 117, 119 \}</math> #*<math>p_2 = \min(A_2) = 3</math>: 두 번째 소수는 3이다. #*<math>B_2 = \{9, 15, 21, 27, \cdots 111, 117 \}</math>: 이 집합은 1보다 큰 가장 작은 약수가 3인 합성수들을 모은 것이다. #*같은 방법으로 <math>B_2</math>의 원소들을 제외하고, 3은 <math>P_3</math>에 넣는다. #<math>P_3 = \{2, 3 \},\ A_3 = A_2 \setminus (B_2 \cup \{3 \}) = \{5, 7, 11, 13, \cdots 115, 119 \}</math>. 이어서 똑같은 방법을 반복한다. #*<math>p_3 = 5</math>: 세 번째 소수는 5이다. #*<math>B_3 = \{25, 35, 55, 65, 85, 95, 115 \}</math> #<math>P_4 = \{2, 3, 5 \},\ A_4 = \{7, 11, 13, 17, \cdots 113, 119 \}</math> #*<math>p_4 = 7</math>: 네 번째 소수는 7이다. #*<math>B_4 = \{49, 77, 91, 119 \}</math> #<math>P_5 = \{2, 3, 5, 7 \},\ A_5 = \{11, 13, 17, 19, \cdots 109, 113 \}</math> #*<math>p_5=11,\ p_5^2 = 121 > N</math>이므로 <math>B_5 = \emptyset</math>이다. 이로써 알고리즘은 여기서 끝난다. #<math>P_5 \cup A_5 = \{2, 3, 5, 7, 11, 13, 17, 19, \cdots 109, 113 \}</math>으로, 이것이 우리가 찾고자 한 120 이하의 소수들의 집합이다. 참고로 <math>P_5</math>는 <math>\sqrt{N}</math> 이하의 소수들의 집합, <math>A_5</math>는 <math>\sqrt{N} < p \le N</math> 범위의 소수들을 모은 집합이다. {{각주}} {{수론 알고리즘}} [[분류:정수론]] 요약: 리브레 위키에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 3.0 라이선스로 배포됩니다(자세한 내용에 대해서는 리브레 위키:저작권 문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요. 글이 직접 작성되었거나 호환되는 라이선스인지 확인해주세요. 리그베다 위키, 나무위키, 오리위키, 구스위키, 디시위키 및 CCL 미적용 사이트 등에서 글을 가져오실 때는 본인이 문서의 유일한 기여자여야 하고, 만약 본인이 문서의 유일한 기여자라는 증거가 없다면 그 문서는 불시에 삭제될 수 있습니다. 취소 편집 도움말 (새 창에서 열림) | () [] [[]] {{}} {{{}}} · <!-- --> · [[분류:]] · [[파일:]] · [[미디어:]] · #넘겨주기 [[]] · {{ㅊ|}} · <onlyinclude></onlyinclude> · <includeonly></includeonly> · <noinclude></noinclude> · <br /> · <ref></ref> · {{각주}} · {|class="wikitable" · |- · rowspan=""| · colspan=""| · |} {{lang|}} · {{llang||}} · {{인용문|}} · {{인용문2|}} · {{유튜브|}} · {{다음팟|}} · {{니코|}} · {{토막글}} {{삭제|}} · {{특정판삭제|}}(이유를 적지 않을 경우 기각될 가능성이 높습니다. 반드시 이유를 적어주세요.) {{#expr:}} · {{#if:}} · {{#ifeq:}} · {{#iferror:}} · {{#ifexist:}} · {{#switch:}} · {{#time:}} · {{#timel:}} · {{#titleparts:}} __NOTOC__ · __FORCETOC__ · __TOC__ · {{PAGENAME}} · {{SITENAME}} · {{localurl:}} · {{fullurl:}} · {{ns:}} –(대시) ‘’(작은따옴표) “”(큰따옴표) ·(가운뎃점) …(말줄임표) ‽(물음느낌표) 〈〉(홑화살괄호) 《》(겹화살괄호) ± − × ÷ ≈ ≠ ∓ ≤ ≥ ∞ ¬ ¹ ² ³ ⁿ ¼ ½ ¾ § € £ ₩ ¥ ¢ † ‡ • ← → ↔ ‰ °C µ(마이크로) Å °(도) ′(분) ″(초) Α α Β β Γ γ Δ δ Ε ε Ζ ζ Η η Θ θ Ι ι Κ κ Λ λ Μ μ(뮤) Ν ν Ξ ξ Ο ο Π π Ρ ρ Σ σ ς Τ τ Υ υ Φ φ Χ χ Ψ ψ Ω ω · Ά ά Έ έ Ή ή Ί ί Ό ό Ύ ύ Ώ ώ · Ϊ ϊ Ϋ ϋ · ΐ ΰ Æ æ Đ(D with stroke) đ Ð(eth) ð ı Ł ł Ø ø Œ œ ß Þ þ · Á á Ć ć É é Í í Ĺ ĺ Ḿ ḿ Ń ń Ó ó Ŕ ŕ Ś ś Ú ú Ý ý Ź ź · À à È è Ì ì Ǹ ǹ Ò ò Ù ù · İ Ż ż ·  â Ĉ ĉ Ê ê Ĝ ĝ Ĥ ĥ Î î Ĵ ĵ Ô ô Ŝ ŝ Û û · Ä ä Ë ë Ï ï Ö ö Ü ü Ÿ ÿ · ǘ ǜ ǚ ǖ · caron/háček: Ǎ ǎ Č č Ď ď Ě ě Ǐ ǐ Ľ ľ Ň ň Ǒ ǒ Ř ř Š š Ť ť Ǔ ǔ Ž ž · breve: Ă ă Ğ ğ Ŏ ŏ Ŭ ŭ · Ā ā Ē ē Ī ī Ō ō Ū ū · à ã Ñ ñ Õ õ · Å å Ů ů · Ą ą Ę ę · Ç ç Ş ş Ţ ţ · Ő ő Ű ű · Ș ș Ț ț 이 문서에서 사용한 틀: 틀:Skin (원본 보기) (준보호됨)틀:각주 (원본 보기) (준보호됨)틀:둘러보기 상자 (원본 보기) (보호됨)틀:둘러보기 상자/핵심 (원본 보기) (보호됨)틀:수론 알고리즘 (편집) 틀:틀바 (원본 보기) (준보호됨)