로그인하고 있지 않습니다. 편집하면 당신의 IP 주소가 공개적으로 기록됩니다. 계정을 만들고 로그인하면 편집 시 사용자 이름만 보이며, 위키 이용에 여러 가지 편의가 주어집니다.스팸 방지 검사입니다. 이것을 입력하지 마세요!== 변칙 알고리즘 == <math>E=L(B)=\operatorname{lcm}(2, 3, \cdots B), Q=a^E-1 \mod N</math>을 셈하는 것이 기본 과정이지만 여기에서 계산 방식을 바꾸거나, 효율을 한층 개선하는 방법이 있다. === 지수 바꾸기 === 앞서 <math>E</math>의 값은 최소공배수 연산으로 고르는 것이 보통 효율적이라고 밝혔으나, 가끔은 [[계승]]을 기준으로 할 때 더 쉽게 풀리기도 한다. 그 특수한 예로 <math>N=3060774511=p_1p_2, p_1=65537, p_2=46703</math>을 들 수 있다. 먼저 <math>p_1-1=2^{16}, p_2-1=2 \cdot 19 \cdot 1229</math>이다. 그러면 <math>p_1-1 \mid L(B)</math>이 성립하려면 <math>B \geq 2^{16}</math>이어야 하고, <math>p_2-1</math>의 경우 <math>B \geq 1229</math>이다. 하지만 이 경우는 계승으로 다시 설정하면 보다 쉽게 풀린다. <math>E=18!</math>로 잡으면 <math>2^{16} \mid 18!</math>이므로 <math>p_1-1 \mid E</math> 조건식에 걸려들고, 본 알고리즘은 성공한다. <math>18! \ll L(1229)</math>임을 생각하면 이쪽이 훨씬 쉬운 경로임을 알 수 있다. === 두 단계 분할 === 임의의 소인수에 대해 <math>p-1=r_1r_2 \cdots r_k</math> 꼴로 소인수분해하고, <math>r_i (1 \leq i \leq k)</math>는 소수 또는 소수의 거듭제곱을 크기 순으로 배열한 값이라고 하자. 그러면 상당한 경우 가장 큰 항인 <math>r_k</math>는 그 다음으로 큰 <math>r_{k-1}</math>보다 훨씬 큰 경향을 보인다. 가령 <math>187477-1=2^2 \cdot 3 \cdot 17 \cdot 919</math>와 같이 끝 항이 굵직하게 남는 경우와, <math>134597-1=2^2 \cdot 7 \cdot 11 \cdot 19 \cdot 23</math>과 같이 자잘한 소인수들로 나뉘는 경우 중 전자가 빈번하게 나타난다. 사실 큰 수로 갈수록 후자와 같은 특징을 보이는 소인수를 찾을 수 있다면 운이 아주 좋은 경우다. 위에서 소개한 기본 알고리즘은 <math>B \geq r_k</math>를 만족하도록 기준치 <math>B</math>의 값을 충분히 올리는 것이다. 하지만 소인수분해 성공을 위한 최소한의 기준치가 너무 높다 싶을 때, 기본 목표를 먼저 <math>B_1 \geq r_{k-1}</math>까지만으로 낮춘 다음, 다른 방법으로 <math>B_2 \geq r_k</math>까지 빠르게 도약할 수 있다면 계산 시간을 단축할 수 있을 것이다. 구체적인 방법은 이와 같다: * 먼저 기본 알고리즘과 같이 첫째 목표치 <math>B_1</math>과 그에 따른 지수를 셈한다. * <math>\displaystyle E=\prod_{\text{primes}\ q \leq B_1}q^{\lfloor \log_{q}B_1 \rfloor}</math> * 마찬가지로 <math>Q_0=a^E-1 \mod N</math>을 셈한다. * 여기까지가 1단계(stage 1)이다. 만약 <math>\gcd(Q_0, N)</math>을 셈해서 운 좋게 약수를 찾았다면, 여기서 알고리즘을 종료할 수 있다. 약수를 찾지 못했다면, 2단계(stage 2)로 넘어간다. * <math>H =a^E \mod N (=Q_0+1)</math>을 저장하고, 둘째 목표치인 <math>B_2</math>를 상정한다. * <math>B_1 < q \leq B_2</math>를 만족하는 소수<ref>경우에 따라서는 (밑이 큰) 소수의 거듭제곱도 포함할 수도 있다.</ref> 목록을 작성하고 이를 오름차순으로 정렬한다. * <math>H^2, H^4, H^6, \cdots \mod N</math>의 값들을 계산해서 메모리에 저장해둔다. 이 목록은 길수록 좋다(즉 저장할 메모리를 많이 확보하면 좋다) * 앞서 작성한 목록<math>\{q_n\} (1 \leq n \leq M)</math> 중 첫째 항을 꺼내서 <math>S_1=H^{q_1} \mod N, Q_1=S_1-1</math>을 계산한다. * 이어서 <math>d_n = q_{n+1}-q_n</math>을 셈하고, 해당 값에 대응하는 <math>H^{d_n} \mod N</math>의 값을 메모리에서 불러온 다음 <math>S_{n+1}=H^{q_{n+1}}=S_nH^{d_n} \mod N, Q_{n+1}=Q_n(S_{n+1}-1) \mod N</math>을 차례대로 셈한다. * 마지막 항까지 계산해서 <math>\displaystyle Q_M=\prod_{1 \leq n \leq M}(H^{q_n}-1) \mod N</math>의 값을 구한다. * <math>\gcd(Q_M, 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: Ă ă Ğ ğ Ŏ ŏ Ŭ ŭ · Ā ā Ē ē Ī ī Ō ō Ū ū · à ã Ñ ñ Õ õ · Å å Ů ů · Ą ą Ę ę · Ç ç Ş ş Ţ ţ · Ő ő Ű ű · Ș ș Ț ț