フェルマーの小定理

曖昧さ回避 自然数の冪乗の和に関する定理の「フェルマーの大定理」あるいは「フェルマーの最終定理」とは異なります。

数論において、フェルマーの小定理(フェルマーのしょうていり、: Fermat's little theorem)は、素数の性質についての定理であり、実用としてもRSA暗号に応用されている定理である。

概要

p {\displaystyle p} を素数とし、 a {\displaystyle a} を整数とすると、

a p a ( mod p ) {\displaystyle a^{p}\equiv a{\pmod {p}}}

が成立すると言う定理である。また、 p {\displaystyle p} を素数とし、 a {\displaystyle a} p {\displaystyle p} の倍数でない整数( a {\displaystyle a} p {\displaystyle p} は互いに素)とするときに、

a p 1 1 ( mod p ) {\displaystyle a^{p-1}\equiv 1{\pmod {p}}}

が成立する。すなわち、 a {\displaystyle a} p 1 {\displaystyle p-1} 乗を p {\displaystyle p} で割った余りは 1 {\displaystyle 1} である。有名なフェルマーの最終定理と区別するためにあえて「小」定理と称されている。

この定理はピエール・ド・フェルマーの名を冠するが、フェルマーの他の予想と同じく、フェルマー自身によって証明が与えられていたことが確認されているわけではない。この定理に対する証明はゴットフリート・ライプニッツによって初めて与えられた。

証明

3通りの証明を示す。

証明(1)

二項定理から、数学的帰納法を用いて証明する方法が簡便である。

補題:「 ( m + 1 ) p {\displaystyle \left(m+1\right)^{p}} p {\displaystyle p} で割った余りは m p + 1 {\displaystyle m^{p}+1} p {\displaystyle p} で割った余りに等しい。」

(補題の証明)

( m + 1 ) p = m p + p C 1 m p 1 + p C 2 m p 2 + + p C p 1 m + 1 {\displaystyle (m+1)^{p}=m^{p}+{}_{p}\mathrm {C} _{1}m^{p-1}+{}_{p}\mathrm {C} _{2}m^{p-2}+\dotsb +{}_{p}\mathrm {C} _{p-1}m+1} 二項定理

右辺の両端以外の二項係数 p C k {\displaystyle {}_{p}\mathrm {C} _{k}} はすべて p {\displaystyle p} の倍数である。なぜなら、

p C k = p ( p 1 ) ( p k + 1 ) k ( k 1 ) 1 {\displaystyle {}_{p}\mathrm {C} _{k}={\frac {p(p-1)\dotsb (p-k+1)}{k(k-1)\dotsb 1}}}

であり、 p {\displaystyle p} は素数であって k < p {\displaystyle k<p} なので、分子に含まれる p {\displaystyle p} が約分されることはないからである。

したがって、 ( m + 1 ) p {\displaystyle \left(m+1\right)^{p}} p {\displaystyle p} で割った余りは、両端の項 m p + 1 {\displaystyle m^{p}+1} p {\displaystyle p} で割った余りに等しい。(補題の証明終)

命題「 a p a ( mod p ) {\displaystyle a^{p}\equiv a{\pmod {p}}} 」を、 a {\displaystyle a} についての数学的帰納法で証明する。

補題に m = 1 {\displaystyle m=1} を代入すると、 2 p = ( 1 + 1 ) p {\displaystyle 2^{p}=\left(1+1\right)^{p}} p {\displaystyle p} で割った余りは 1 p + 1 = 2 {\displaystyle 1^{p}+1=2} となり、 a = 2 {\displaystyle a=2} のとき成り立つ。

命題が、 a = k {\displaystyle a=k} のとき成り立つと仮定する。

補題から、 ( k + 1 ) p {\displaystyle \left(k+1\right)^{p}} p {\displaystyle p} で割った余りは k p + 1 {\displaystyle k^{p}+1} p {\displaystyle p} で割った余りに等しい。帰納法の仮定によって k p {\displaystyle k^{p}} p {\displaystyle p} で割った余りは k {\displaystyle k} p {\displaystyle p} で割った余りに等しいから、 ( k + 1 ) p {\displaystyle \left(k+1\right)^{p}} p {\displaystyle p} で割った余りは k + 1 {\displaystyle k+1} p {\displaystyle p} で割った余りに等しい。

したがって、命題は a = k + 1 {\displaystyle a=k+1} のときも成り立つ。

数学的帰納法によって、命題は a 2 {\displaystyle a\geqq 2} に対して成り立つ。また、 a = 0 ,   1 {\displaystyle a=0,\ 1} のときは、代入してみると明らかに成り立つので、命題は a 0 {\displaystyle a\geqq 0} に対して成り立つ。

(証明終)

証明(2)

上の補題と同様に、 ( x + y ) p x p + y p ( mod p ) {\displaystyle (x+y)^{p}\equiv x^{p}+y^{p}{\pmod {p}}} が示せる。これより、

a p = [ 1 + ( a 1 ) ] p 1 p + [ 1 + ( a 2 ) ] p 1 + 1 p + [ 1 + ( a 3 ) ] p a ( mod p ) {\displaystyle {\begin{aligned}a^{p}&=[1+(a-1)]^{p}\\&\equiv 1^{p}+[1+(a-2)]^{p}\\&\equiv 1+1^{p}+[1+(a-3)]^{p}\\&\equiv a{\pmod {p}}\end{aligned}}}

(証明終)

証明(3)

p {\displaystyle p} を素数とし、 a {\displaystyle a} p {\displaystyle p} が互いに素とするときに、

a p 1 1 ( mod p ) {\displaystyle a^{p-1}\equiv 1{\pmod {p}}}

が成立することを、ここで証明する。

集合 { 1 ,   2 ,   3 , ,   p 1 } {\displaystyle \left\{1,\ 2,\ 3,\ldots ,\ p-1\right\}} は、全体として法 p {\displaystyle p} の下で { a ,   2 a ,   3 a , ,   ( p 1 ) a } {\displaystyle \left\{a,\ 2a,\ 3a,\ldots ,\ \left(p-1\right)a\right\}} と合同である。(背理法による証明)もし後者の集合内に

i a j a ( mod p ) {\displaystyle ia\equiv ja{\pmod {p}}}

となる i ,   j {\displaystyle i,\ j} (ただし、 i j {\displaystyle i\neq j} )が存在したとする。すると、 a {\displaystyle a} p {\displaystyle p} が互いに素なので、 i j ( mod p ) {\displaystyle i\equiv j{\pmod {p}}} となり、 0 < i ,   j < p {\displaystyle 0<i,\ j<p} であることから、 i = j {\displaystyle i=j} となり、矛盾する。したがって、二つの集合は全体として合同であることが分かった。

それぞれの集合の要素をすべて掛け合わせると、

( p 1 ) ! ( p 1 ) !   a p 1 ( mod p ) {\displaystyle (p-1)!\equiv (p-1)!\ a^{p-1}{\pmod {p}}}

となる。 p {\displaystyle p} が素数であることから、 p {\displaystyle p} ( p 1 ) ! {\displaystyle \left(p-1\right)!} とは互いに素なので、

a p 1 1 ( mod p ) {\displaystyle a^{p-1}\equiv 1{\pmod {p}}}

(証明終)

オイラーの定理

詳細は「オイラーの定理 (数論)」を参照

後になってレオンハルト・オイラーはこの定理を拡張し、 a {\displaystyle a} n {\displaystyle n} と互いに素な整数とすると、

a φ ( n ) 1 ( mod n ) {\displaystyle a^{\varphi (n)}\equiv 1{\pmod {n}}}

が成り立つことを示した。ここで、 φ ( n ) {\displaystyle \varphi (n)} n {\displaystyle n} 以下の n {\displaystyle n} と互いに素な自然数の個数を表し、オイラー関数と呼ばれる。

特に n {\displaystyle n} が素数のときは、 φ ( n ) = n 1 {\displaystyle \varphi (n)=n-1} より、フェルマーの小定理に一致する。

カーマイケルの定理

m = φ ( n ) {\displaystyle m=\varphi (n)} とすれば、 a m 1 ( mod n ) {\displaystyle a^{m}\equiv 1{\pmod {n}}} n {\displaystyle n} と互いに素なすべての a {\displaystyle a} に対して成り立つが、 φ ( n ) {\displaystyle \varphi (n)} はこの性質を満たす m {\displaystyle m} の最小の数とは限らない。カーマイケルの定理はオイラーの定理を精緻化したもので、すべての a {\displaystyle a} に対して a m 1 ( mod n ) {\displaystyle a^{m}\equiv 1{\pmod {n}}} が成立するような最小の m {\displaystyle m} を与える。ただし、 n {\displaystyle n} と互いに素な a {\displaystyle a} が与えられたときに、 a m 1 ( mod n ) {\displaystyle a^{m}\equiv 1{\pmod {n}}} を満たす最小の m {\displaystyle m} は、 λ ( n ) {\displaystyle \lambda \left(n\right)} となるとは限らない。

たとえば、 n = 10000 {\displaystyle n=10000} のとき、カーマイケルの定理によれば n {\displaystyle n} と互いに素なすべての a {\displaystyle a} に対して a m 1 ( mod n ) {\displaystyle a^{m}\equiv 1{\pmod {n}}} を満たす最小の m {\displaystyle m} は500であるが、特定の a = 7 {\displaystyle a=7} に対しては 7 100 1 ( mod n ) {\displaystyle 7^{100}\equiv 1{\pmod {n}}}  が成立する。

カーマイケル関数(英語版) λ ( n ) {\displaystyle \lambda \left(n\right)} を以下のように再帰的に定義する。

n = 2 e {\displaystyle n=2^{e}} なら、

λ ( 2 e ) = { 1 ( e = 1 ) 2 ( e = 2 ) 2 e 2 ( e 3 ) {\displaystyle \lambda (2^{e})={\begin{cases}1&(e=1)\\2&(e=2)\\2^{e-2}&(e\geq 3)\end{cases}}}

n {\displaystyle n} が奇素数 p {\displaystyle p} を用いて n = p e {\displaystyle n=p^{e}} と書けるなら、

λ ( p e ) = p e 1 ( p 1 ) {\displaystyle \lambda (p^{e})=p^{e-1}(p-1)}

n {\displaystyle n} p 1 e 1 p k e k {\displaystyle p_{1}^{e_{1}}\ldots p_{k}^{e_{k}}} 素因数分解できるなら、

λ ( p 1 e 1 p k e k ) = lcm { λ ( p 1 e 1 ) , , λ ( p k e k ) } {\displaystyle \lambda (p_{1}^{e_{1}}\dotsb p_{k}^{e_{k}})=\operatorname {lcm} \{\lambda (p_{1}^{e_{1}}),\dotsc ,\lambda (p_{k}^{e_{k}})\}}

ここで lcm {\displaystyle \operatorname {lcm} } 最小公倍数

カーマイケルの定理は、 a {\displaystyle a} n {\displaystyle n} が互いに素なとき、

a λ ( n ) 1 ( mod n ) {\displaystyle a^{\lambda \left(n\right)}\equiv 1{\pmod {n}}}

が成り立つという定理である。

λ ( n ) {\displaystyle \lambda \left(n\right)} n 1 {\displaystyle n-1} の約数であるとき、 n {\displaystyle n} カーマイケル数と呼ばれ、自身と互いに素であるようなすべての底でフェルマーテストを通過する絶対擬素数となる。

フェルマーテスト

フェルマーテストは、フェルマーの小定理の対偶を用いて確率的素数判定を行うアルゴリズムである。

フェルマーの小定理の対偶をとると、これは次のように、自然数 n合成数であるための十分条件を与える。

対偶
n {\displaystyle n} と互いに素な整数 a {\displaystyle a}
a n 1 1 ( mod n ) {\displaystyle a^{n-1}\not \equiv 1{\pmod {n}}}
を満たせば、 n {\displaystyle n} は合成数である。

この十分条件を用いて、次のように自然数 n {\displaystyle n} の素数判定を行う。

  1. パラメータとして、 2 {\displaystyle 2} 以上 n {\displaystyle n} 未満の自然数 a {\displaystyle a} を1つ定める。
  2. a {\displaystyle a} n {\displaystyle n} が互いに素でなければ「 n {\displaystyle n} は合成数」と出力して終了。
  3. a n 1 1 ( mod n ) {\displaystyle a^{n-1}\not \equiv 1{\pmod {n}}} ならば「 n {\displaystyle n} は合成数」と出力して終了する。そうでないとき「 n {\displaystyle n} は確率的素数」と出力して終了する。

フェルマーテストが「合成数」と出力したとき、上のフェルマーの小定理の対偶によって n {\displaystyle n} は実際に合成数である。しかし、上の対偶は十分条件を与えるのみで必要条件を与えるものではないので、「確率的素数」と出力された場合でも n {\displaystyle n} は実際に素数であるとは限らない。素数ではないにもかかわらず「確率的素数」と判定されてしまう合成数は擬素数と呼ばれる。

疑わしければ、「確率的素数」と出力された場合にはまた異なる a {\displaystyle a} を用いて再びテストを行う。十分な回数だけ a {\displaystyle a} を取り替えて繰り返せば、フェルマーテストが「確率的素数」と判定した数は実際に素数である可能性が高い。

しかし、カーマイケル数または絶対擬素数と呼ばれる "反例" もある。カーマイケル数は合成数であるにもかかわらず、ほとんどいかなる a {\displaystyle a} を用いても「確率的素数」と判定されてしまう。従って、フェルマーテストは完全な素数判定法ではない。

フェルマーテストを改善するアルゴリズムとしては、ミラー–ラビン素数判定法AKS素数判定法がある。

一般化

フェルマーの小定理・オイラーの定理は一般の有限群の定理に拡張できる。 G {\displaystyle G} を位数 m {\displaystyle m} の有限群とすると、 G {\displaystyle G} の任意の元 g {\displaystyle g} に対して g m {\displaystyle g^{m}} は単位元に一致する。オイラーの定理は G {\displaystyle G} 乗法群 ( Z / n Z ) × {\displaystyle \left(\mathbb {Z} /n\mathbb {Z} \right)^{\times }} のときの場合であり、フェルマーの小定理はさらに n {\displaystyle n} が素数の場合である。

参考文献

  • 高木貞治『初等整数論講義』(第2版)共立出版、1971年、67,53-54頁。ISBN 4-320-01001-9。 
  • G.H.ハーディ、E・M・ライト『数論入門I』示野信一・矢神毅 訳、シュプリンガー・フェアラーク東京〈シュプリンガー数学クラシックス8〉、2001年7月、82-107頁。ISBN 4-431-70848-0。 
    • G・H・ハーディ、E・M・ライト『数論入門I』示野信一・矢神毅 訳、丸善出版〈シュプリンガー数学クラシックス8〉、2001年7月、82-107頁。ISBN 978-4-621-06226-5。http://pub.maruzen.co.jp/book_magazine/book_data/search/9784621062265.html 

外部リンク

  • 『フェルマーの小定理の証明と例題』 - 高校数学の美しい物語
  • Weisstein, Eric W. "Fermat's Little Theorem". mathworld.wolfram.com (英語).
  • Weisstein, Eric W. "Euler's Totient Theorem". mathworld.wolfram.com (英語).
  • Weisstein, Eric W. "Carmichael's Theorem". mathworld.wolfram.com (英語).