Лексикографический порядок — различия между версиями
(→Определение) |
(→Определение) |
||
| Строка 2: | Строка 2: | ||
Пусть дано линейно упорядоченное множество <tex>~E=\{e_1<e_2<e_3<...<e_k\}</tex> {{---}} алфавит. Словом назовем упорядоченное множество <tex> ~S </tex> элементов алфавита <tex> ~A </tex>. Тогда если на алфавите <tex> A </tex> задан порядок, то порядок задан и на слове <tex> ~S </tex>. Тогда говорят, что множество слов <tex> ~A </tex> задано в лекcикографическом порядке, если для <tex>\forall i \in A </tex> <tex>\forall j \in A </tex> таких, что <tex> i < j </tex> выполнено, что слово <tex> ~A_i </tex> меньше, чем слово <tex> ~A_j </tex>. | Пусть дано линейно упорядоченное множество <tex>~E=\{e_1<e_2<e_3<...<e_k\}</tex> {{---}} алфавит. Словом назовем упорядоченное множество <tex> ~S </tex> элементов алфавита <tex> ~A </tex>. Тогда если на алфавите <tex> A </tex> задан порядок, то порядок задан и на слове <tex> ~S </tex>. Тогда говорят, что множество слов <tex> ~A </tex> задано в лекcикографическом порядке, если для <tex>\forall i \in A </tex> <tex>\forall j \in A </tex> таких, что <tex> i < j </tex> выполнено, что слово <tex> ~A_i </tex> меньше, чем слово <tex> ~A_j </tex>. | ||
| − | + | Рассмотрим сравнение объектов, состоящих из элементов, на которых задан порядок. Если нам даны два объекта <tex> ~P </tex> и <tex> ~Q </tex>, то <tex> ~P </tex> меньше, чем <tex> ~Q </tex>, если объект <tex> ~P </tex> является префиксом <tex> ~Q </tex>, либо если первые <tex> ~i </tex> элементов объектов совпадают, а <tex> ~P_i < ~Q_i </tex>. | |
== Сравнение слов == | == Сравнение слов == | ||
Версия 03:32, 12 ноября 2011
Определение
Пусть дано линейно упорядоченное множество — алфавит. Словом назовем упорядоченное множество элементов алфавита . Тогда если на алфавите задан порядок, то порядок задан и на слове . Тогда говорят, что множество слов задано в лекcикографическом порядке, если для таких, что выполнено, что слово меньше, чем слово .
Рассмотрим сравнение объектов, состоящих из элементов, на которых задан порядок. Если нам даны два объекта и , то меньше, чем , если объект является префиксом , либо если первые элементов объектов совпадают, а .
Сравнение слов
Что же значит, что слово меньше слова , и как вообще можно сравнивать слова?
Говорят, что слово меньше слова , если:
1. Слово является префиксом слова
2. Ни одно из слов не является префиксом другого, но такое, что для всех выполнено неравенство , а . Элементы слова мы можем сравнивать, так как это элементы алфавита, а на алфавите задан строгий порядок.
Приведем псевдокод сравнения слов:
function isEqual(A, B : string)
for i = 0 .. min(len(A), len(B)) - 1 //Длины равны, строки нумеруются с ноля
if (A[i] < B[i])
return <
if (A[i] > B[i])
return >
//Одна из строк является префиксом другой
if (len(A) < len(B))
return <
if (len(A) > len(B))
return >
return = //Длины строк и все символы равны
Примеры
- Последовательность чисел в любой системе счисления, записанных в фиксированной разрядной сетке (000, 001, 002, 003, 004, 005, …, 999).
- Порядок слов в словаре. Предполагается, что буквы можно сравнивать, сравнивая их номера в алфавите. Тогда лексикографический порядок — это, например, ААА, ААБ, ААВ, ААГ, …, ЯЯЯ.