Лексикографический порядок — различия между версиями
Flanir (обсуждение | вклад) (→Примеры с комбинаторными объектами) |
Flanir (обсуждение | вклад) (→Примеры с комбинаторными объектами) |
||
| Строка 25: | Строка 25: | ||
== Примеры с комбинаторными объектами == | == Примеры с комбинаторными объектами == | ||
| − | + | {| cellpadding="4" style="margin-left: left; margin-right: left;" | |
| − | {| cellpadding=" | ||
| [[Файл:Compareperm.png|thumb|Перестановки, общий префикс, 4 < 6, поэтому 1-ая перестановка лексикографически меньше]] | | [[Файл:Compareperm.png|thumb|Перестановки, общий префикс, 4 < 6, поэтому 1-ая перестановка лексикографически меньше]] | ||
| [[Файл:Comparechoose.png|thumb|Сочетания, общий префикс, 4 < 6, поэтому 1-ое сочетание лексикографически меньше]] | | [[Файл:Comparechoose.png|thumb|Сочетания, общий префикс, 4 < 6, поэтому 1-ое сочетание лексикографически меньше]] | ||
Версия 00:49, 31 декабря 2014
Определение
| Определение: |
| Пусть даны две последовательности и
Тогда последовательность лексикографически меньше последовательности , если выполняется одно из двух условий:
|
Приведем псевдокод сравнения последовательностей из элементов множества Т:
function Сompare(A, B : list <T>) // Возвращает "LESS", если A < B, "MORE", если A > B, или "EQUAL", если последовательности равны
for i = 1 to min(len(A), len(B))
if A[i] < B[i] // i-й элемент А меньше i-го элемента B, но префиксы длины i - 1 равны
return LESS
if A[i] > B[i] // i-й элемент А больше i-го элемента B, но префиксы длины i - 1 равны
return MORE
if len(A) < len(B) // А - префикс В, но не равна ей.
return LESS
if len(A) > len(B) // В - префикс А, но не равна ей.
return MORE
return EQUAL // Длины последовательностей и все элементы равны
| Определение: |
| Последовательности записаны в лексикографическом порядке (lexicographical order), если для любых выполняется неравенство , где и последовательности с номерами и . |
Например, слово "сон" лексикографически меньше слова "сонный", так как оно является его префиксом. Слово "низ" лексикографически меньше слова "нос", поскольку первые символы совпадают, а второй символ первого слова меньше, чем второй символ второго.
Примеры с комбинаторными объектами
Другие примеры
- Последовательность чисел в любой системе счисления, записанных в фиксированной разрядной сетке (000, 001, 002, 003, 004, 005, …, 999).
- Порядок слов в словаре. Предполагается, что буквы можно сравнивать, сравнивая их номера в алфавите. Тогда лексикографический порядок — это, например, ААА, ААБ, ААВ, ААГ, …, ЯЯЯ.
- Эти слова тоже записаны в лексикографическом порядке: азбука, бог, борода, сон, сонный.

