二重階乗
From Wikipedia, the free encyclopedia

数学における階乗類似の組合せ論的函数の一つとして、二重階乗(にじゅうかいじょう、英: double factorial)または半階乗 (semifactorial) n!! は、与えられた自然数 n に対し、1 から n まで n と同じ偶奇性を持つものだけを全て掛けた積を言う[1]。すなわち、 さらに n = 0 のときは、空積と見て 0!! ≔ 1 と定義する。
この定義に従えば、偶数 n に対する二重階乗は で与えられ、また奇数 n に対しては で与えられる。例えば 9!! = 9 × 7 × 5 × 3 × 1 = 945である。
| (-9)!! | = 1⁄105 |
|---|---|
| (-7)!! | = −1⁄15 |
| (-5)!! | = 1⁄3 |
| (-3)!! | = −1 |
| (-1)!! | = 1 |
| 0!! | = 1 |
| 1!! | = 1 |
| 2!! | = 2 |
| 3!! | = 3 |
| 4!! | = 8 |
| 5!! | = 15 |
| 6!! | = 48 |
| 7!! | = 105 |
| 8!! | = 384 |
| 9!! | = 945 |
| 10!! | = 3840 |
| 11!! | = 10395 |
| 12!! | = 46080 |
| 13!! | = 135135 |
| 14!! | = 645120 |
| 15!! | = 2027025 |
| 16!! | = 10321920 |
| 17!! | = 34459425 |
| 18!! | = 185794560 |
| 19!! | = 654729075 |
| 20!! | = 3715891200 |
二重階乗 n!! を階乗函数の二回反復 (n!)! と混同してはならない、両者は全く異なる値をとる。
Merserve (1948)[2] (二重階乗記法を用いたおそらく最初の出版物[3]) は、二重階乗はもともとウォリス積の導出において生じるある種の三角積分の表示を簡単にするために導入されたと述べる。二重階乗は超球の体積の式にも現れ、また数え上げ組合せ論において多くの応用を持つ[1][4]。
奇数に対する二重階乗のことを奇階乗 (odd factorial) と呼ぶこともある[5]。
数え上げ組合せ論における応用

二重階乗は数え上げ組合せ論などの状況において頻繁に生じるという事実に動機づけられる。例えば奇階乗 n!! が現れる例としては:
- 奇数 n に対する完全グラフ Kn+1 の完全マッチング。そのようなグラフの任意の一つの頂点 v がマッチすることのできる頂点の選び方が n 通りで、選んだ残りは頂点数が 2 少ない完全グラフの完全マッチング問題に帰着される。例えば 4 = 3 + 1 頂点 a, b, c, d の完全グラフの完全マッチングは (ab, cd), (ac, bd), (ad, bc) で確かに 3!! = 3 通りであることが確認できる[1]。
- スターリング順列: 同じ数が二つずつの多重集合 1, 1, 2, 2, …, k, k の置換(重複度まで込めてすべての元を一回ずつ用いる順列)で同じ数の各類はそれより大きい数によってのみ分けられるようにしたもの。で、k = n + 1/2 と置く。最も大きい k は二つとも隣り合うしかなく、それを取り除けば k − 1 を最大元とする順列が残るが、そのできた順列において隣り合う k が入れるのは n 通りの位置が考えられる。これで再帰的構成が得られたから、スターリング順列の数が二重順列で数えられることは帰納的にわかる[1]。 あるいは同じ数の対の間に入れるのは大きい数だけという制約の代わりに、この多重集合の置換に現れる、同じ数の対のうち最初のほうは、あるきまった順番に並ぶという制約で考えることもできる。そのような順列が定めるのは、順列の 2k 箇所に関するマッチングであり、したがってふたたび個の順列の総数が二重階乗で数えられることがわかる[4]
- ヒープの順序木: k + 1 個のノードが 0, 1, 2, …, k でラベル付けられた木で、ルートのラベルが 0 かつ、ほかのノードのラベルはその親ノードのラベルより大きく、各ノードの子ノードが決まった順になっている。この木のオイラー巡回 (Euler tour) はスターリング順列を与え、任意のスターリング順列はこの方法で木で表現できる[1][6]
- 根なし二分木で n + 5/2 個のラベル付き葉ノードを持つもの。そのような木の各々は、葉ノードが一つ少ない木から、n 本の辺の一つを細分して、新たな頂点を新たな葉ノードの親にすれば作れる。
- 根付き二分木で n + 3/2 個のラベル付き葉ノードを持つもの。根なし木の場合と同様だが、細分できる辺の数は偶数で、辺の細分に加えて、二つの子がより小さい木および新たな葉ノードであるような新たな根を加えることにより、葉ノードが一つ少ない木にノードを加えることができる[1][4]
Callan (2009) および Dale & Moon (1993) は同様に二重階乗で数えられる組合せ論的数列をさらにさまざまにリストしている: 例えば、「台形語」("trapezoidal word": 奇数を含む複数の位取りの底を持つ混基数記数法に属する数の体系)、高さでラベル付けられたダイク路、高さでラベル付けられた順序木、"overhang path"、根付き二分木における各ノードに関する最小数付けられた葉ノードの降下列を記述するある種のベクトル、など。これらの対象のいくつかが同数であることを言う全単射による証明(双射法)は Rubey (2008) および Marsh & Martin (2011) を見よ[7][8]。
定義域の延長
負の引数
通常の階乗函数は(ガンマ函数に拡張して)各負の整数の位置に極を持ち、それらの数へ階乗を延長することは妨げられる。しかし奇数の二重階乗は、その漸化式 を逆に解いて と書くことにより、任意の負の奇数に延長することができる。この逆向きの漸化式を用いれば、−1!! = 1, −3!! = −1, −5!! = 1/3 などが計算でき、これ以降の(絶対値がより大きい)負の奇数に対して、その二重階乗は全て分数である[1]。特に、正の奇数 n に対し が言える。
複素引数
偶数引数に対する二重階乗の先述の定義はさておいて、z が正の奇数のときの値が と書けることに着目して、奇階乗の定義域をほとんどの実数または複素数に対して延長することができる[9]:266[10]。
この関係式に従えば、z が非負偶数値をとるときの z!! の値は と再定義されることになる。この意味での 0!! の値は である。
式を見れば z!! が負の偶数を除く任意の複素数に対して定義されることが分かる。またこれを定義として、半径 R の n-次元超球の体積は と表せる[11]。
その他の等式
一般化
多重階乗
- 定義 1
- 二重階乗が(一重の)階乗の概念を一般化するのと同じ仕方で、整数値多重階乗 (multiple factorial, multifactorial) あるいは「歩み」となる正整数 α を明示して α-重階乗、α-階乗 (α-factorial) 函数 は二重階乗を一般化する。n! が負の整数に対して、および n!! が負の偶数に対してそれぞれ定義されないことと同じように、n!α は α の負の倍数において定義されない。
- 定義 2
- また同様に、α の倍数より 1 大きい z における値が となることに着目してほとんどの実数および複素数に対して定義域を延長できる。
ガンマ函数を用いた最後の式はもとと比べて非常に広く定義されるもので、この定義により z!(α) は負の実軸上にある k の負の倍数を除く任意の複素数に対して定義された函数と見なせる。そして「z ≡ 1 mod α なる整数 z に対しては z!(α) = z!(α) を満たす」という意味でこの二つの定義は両立する。
z!α がほとんどの複素数 z に対して延長できることに加え、α も任意の正実数値としてこの定義は意味を為す。さらに言えば、k = 1 のとき、定義される函数 Π(z) はパイ函数である。また k = 2 のときは、奇階乗の複素変数への拡張に一致する。