辞書式順序
この記事は英語版の対応するページを翻訳することにより充実させることができます。(2024年5月) 翻訳前に重要な指示を読むには右にある[表示]をクリックしてください。
|
数学における辞書式順序(じしょしきじゅんじょ、英: lexicographical order. lexicographic-, dictionary-)とはいくつかの順序集合の直積集合上に順序を定める方法の一つである。順序集合 A と B が与えられた際の直積集合 A × B 上の辞書式順序は
として定められる。辞書式順序という名前は、この順序の定め方が辞書における項目の並べ方を一般化したものと見なせることに由来する。つまり、単語(文字の並び)a1a2...ak が別の単語 b1b2...bk の前に現れるのは ai が bi と異なるような最初の i について、文字の順番の中で ai が bi より前に現れる場合である。このとき2つの単語は同じ長さ(文字数)であるものと仮定されているが、実際の辞書では普通短い単語の方を後ろにどんな文字よりも先の順番にある空白を付け加えることで単語の長さが揃っているものとして考える、という操作が行われる。
概要
編集整列順序の入った添字集合 I で添字づけられた全順序集合の族 (Ai)i ∈ I が与えられたとする。このとき、直積集合 ∏i ∈ I Ai 上に以下のようにして定められる順序は ∏i ∈ I Ai 上の辞書式順序と呼ばれる:
上の定義は I が特に有限集合 {1, ... , n} の場合にも適用できる。その場合には次のように言いかえることができる。すなわち A1, ... , An を全順序集合とするとき、直積集合 A1 × … × An 上の辞書式順序とは次のようになる: a = (a1, ... , an) と b = (b1, ... , bn) を A1 × … × An の元とする。
- 「先頭の文字」a1 と b1 が異なり、a1 < b1 ならば a < b、
- 反対に a1 > b1 ならば a > b とし、
- a1 = b1 だったならば a2 と b2 を同様に比べる、
という操作を繰り返して a と b の間の大小関係が決定される。
辞書式順序の重要な性質に整列性を保つというものがある。つまり、順序集合 A と B が整列順序集合ならば辞書式順序をいれた直積集合も整列順序集合になる。
辞書式順序の応用
編集単項式に対する順序
編集多変数の多項式の集合の中での単項式の集合は各変数に関する単項式集合たちの直積集合と見なすことができる。したがってこの単項式の集合上にそれぞれの変数の単項式に関する順序をもとにした辞書式順序を考えることができる。
社会での応用
編集辞書式順序の実社会における応用として日付の書式に関するISO 8601規格が挙げられる。この規格では日付は YYYYMMDD(Yは年、Mは月、Dは日を表す)という書式によって表され、単純に文字の並びとして並べ替えるだけの整列アルゴリズムで時系列順の並べ替えが得られる。ここで、このアルゴリズムが機能するためには年は4つの数字で表され、月や日は2つの数字で表されていなければならないので、たとえば数字1つの日付には0を付け足して '01' などと表すことになる。