物の数は数え方によらないことを確認する【鳩の巣原理】

2024/10/20

みなさんこんにちは。物、数えてますか?

例えばここにりんごがいくつかあります。

3つのりんごが横に並んでいる

左から1、2、3と数えると、りんごが3つあるとわかります。

これは数学的には、集合 {1,2,3}\{1, 2, 3\} からりんごへの全単射(1対1対応)を見つけたということになります。

1、2、3という数字がよこにならんでおり、その下に3つのりんごが並んでいる。1から左のりんごに線が伸びている。2から真ん中のりんごに線が伸びている。3から右のりんごに線が伸びている

しかし、全単射はこの1種類だけではありません。

人によっては、右のりんごから1、2、3と数えるかもしれません。

1、2、3という数字がよこにならんでおり、その下に3つのりんごが並んでいる。1から右のりんごに線が伸びている。2から真ん中のりんごに線が伸びている。3から左のりんごに線が伸びている

または、真ん中、右、左と数える人もいるかもですね。

1、2、3という数字がよこにならんでおり、その下に3つのりんごが並んでいる。1から真ん中のりんごに線が伸びている。2から右のりんごに線が伸びている。3から左のりんごに線が伸びている

一般に、n個のりんごについて n!n! 種類の全単射があります。どのような全単射でも(どのような数え方でも)りんごを正しく数えていると言えるのでしょうか?

つまり、{1,2,,n}\{1, 2, \cdots, n \} から {1,2,,m}\{1, 2, \cdots, m \} への全単射を見つけたなら、n=mn = m と言えるでしょうか?

今回はCoqでこれを示してみました。つまり背理法禁止です。

リポジトリ:https://github.com/sititou70/constructive-pigeonhole/tree/main

この記事では、証明の大まかな流れを紹介します。

ステップ1:鳩の巣原理を示す

鳩の巣原理とは、「nn 羽のハトが mm 個の巣に入っているとき、n>mn > m ならば、複数のハトが入っている巣がある」というものです1

4羽のハトが縦に並んでいる。その右に3つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2から巣2に線が伸びている。ハト3とハト4から巣3に線が伸びている

当たり前に思えますが、ちゃんと示すにはハトの羽数 nn について帰納法を適用します。

0の場合

前提の 0>m0 > m が成り立たない(そんな自然数 mm はない)ので成り立ちます。

n + 1の場合

nで原理が成り立つことを仮定して、n + 1でも成り立つことを示します。

一番最後のハトが入る巣について、同じ巣に入る他のハトがいるかどうかによって場合分けします2

同じ巣に入る他のハトがいる場合

以下のような状況です。

4羽のハトが縦に並んでいる。その右に3つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2から巣2に線が伸びている。ハト3とハト4から巣3に線が伸びている

この場合、一番最後のハトと同じ巣に入るハトがいるので、原理は成り立ちます。

同じ巣に入る他のハトがいない場合

以下のような状況です。

4羽のハトが縦に並んでいる。その右に3つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2と3から巣2に線が伸びている。ハト4から巣3に線が伸びている

この場合は、一番最後のハトと、対応する巣を取り除きます。

4羽のハトが縦に並んでいる。その右に3つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2と3から巣2に線が伸びている。ハト4から巣3に線が伸びている。ハト4と巣3が点線で囲まれており、取り除くと書かれている

そうすると、残った nn 羽のハトに対して帰納法の仮定より原理を適用できます。

4羽のハトが縦に並んでいる。その右に3つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2と3から巣2に線が伸びている

結局、のこりのなかで複数のハトの入る巣が見つかるので、原理が示されました。

ステップ2:鳩の巣原理の変形版を示す

鳩の巣原理の変形版とは、「nn 羽のハトが mm 個の巣に入っているとき、n<mn < m ならば、ハトが入っていない巣がある」というものです。

3羽のハトが縦に並んでいる。その右に4つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2から巣2に線が伸びている。ハト3から巣3に線が伸びている

当たり前に思えますが、ちゃんと示すにはハトの羽数 nn について帰納法を適用します。

0の場合

ハトがいないため、例えば最初の巣にはハトが入っていないため成り立ちます。

n + 1の場合

最後のハトと対応する巣を取り除きます。もしその巣に入っている他のハトがいる場合は、適当に最初の巣に入れます。

3羽のハトが縦に並んでいる。その右に4つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2から巣2に線が伸びている。ハト3から巣3に線が伸びている。ハト3と巣3が点線で囲まれており、取り除くと書かれている

そうすると、残った nn 羽のハトに対して帰納法の仮定より原理を適用できます。

3羽のハトが縦に並んでいる。その右に4つのハトの巣が縦に並んでいる。上から順にハト1、ハト2……、巣1、巣2……とする。ハト1から巣1に線が伸びている。ハト2から巣2に線が伸びている

結局、のこりのなかでハトの入っていない巣が見つかるので原理が示されました。

ステップ3:物の数は数え方によらないことを示す

いま、nn 羽のハトが mm 個の巣に入っているとします。

鳩の巣原理とその変形版から、それぞれ以下が言えます。

  • n>mn > m ならば、複数のハトが入っている巣がある。
  • n<mn < m ならば、ハトが入っていない巣がある。

それぞれの対偶を取ります。

  • 複数のハトが入っている巣がない、ならば nmn \leq m
  • ハトが入っていない巣がない、ならば nmn \geq m

ここで、「複数のハトが入っている巣がない」とは単射のことで、「ハトが入っていない巣がない」とは全射のことです。なので

  • ハトから巣への単射が存在するならば nmn \leq m
  • ハトから巣への全射が存在するならば nmn \geq m

したがって2つを組み合わせると

「ハトから巣への単射が存在し、かつ全射が存在する」ならば「nmn \leq m かつ nmn \geq m

となって、

ハトから巣への全単射が存在するならば n=mn = m

が示せました!

なのでより一般的に、{1,2,,n}\{1, 2, \cdots, n \} から {1,2,,m}\{1, 2, \cdots, m \} への全単射を見つけたなら、n=mn = m と言えます。

まとめ

お疲れ様でした。

私達は物を数えるとき、無意識のうちに自然数から対象への全単射(1対1対応)を探しています。

そして、鳩の巣原理とその変形版を示すことで、全単射の取り方によらず物が数えられることがわかりました。鳩の巣原理は、物の数を数えるという基本的なことの、さらに基礎になっているようです。

鳩の巣原理は、一見すると自明に思えます。「ハトの数が巣の数より多いんだから当たり前じゃん」といった感じです。

しかし「新井敏康、鳩はどこへ行った?」によれば、

結局,鳩の巣原理を,集合の要素の個数の大小を比較することによって自明であるとするのは,集合の要素の個数そのものが鳩の巣原理によって決まるので,循環していると考えられる.

とのことです。

そういえば、小学校の算数の授業で、みかんとぶどうを線で対応させてどちらの数が多いか、または同じ数かというのをやった気がします。

左側にはいくつかのみかんとぶどうのアイコンが無作為に散らばっており、いくつかのみかんとぶどうのペアは線で1対1に繋がれている。右側にはみかんの数とぶどうの数を書き込むための余白が用意されている

出典:【小学校受験】 数の多少(1対1対応)問題を徹底解説!解き方のポイント・家庭での教え方

こんな時期から、全単射、1対1対応という概念が登場していたんですね。小学校で習うような内容であっても、実は突き詰めていくと奥が深いんだなぁと感じます。

私はこういう分野にはまったく詳しくないのですが、おもしろかったので紹介しました。あと、Coqで書いた証明の内容を忘れないうちに書いておきたかったのもあります。

ありがとうございました。

参考文献

フリー画像の出典


  1. pigeonholeを鳩の巣とするのは誤訳であり、単なる仕切り箱や分類箱の意味ではないかという説があります。しかし、実際のハトと考えたほうが可愛いので、この記事ではそうします。
  2. この場合分けは帰納法によって示せます

続けて読む…

Blenderと魚

2017/06/13

Blenderでアニメ調にレンダリングしてみる

2017/01/28

Advent of Code 2021攻略ガイド

2021/12/28

Gitの内部表現から理解するSquash

2024/03/25

ざっくりホーア論理

2024/09/28

Blenderと岩

2017/04/25

書いた人

sititou70のアイコン画像
sititou70

都内の社会人エンジニア4年生。Web技術、3DCG、映像制作が好き。