Лексикографический порядок — различия между версиями
(→Определение) |
(→Определение) |
||
Строка 1: | Строка 1: | ||
== Определение == | == Определение == | ||
− | + | Пусть нам дан алфавит, на котором определен порядок. То есть для любых <tex> i < j </tex> выполнено неравенство <tex> K_i < K_j </tex>, где <tex> K_i ~- </tex> <tex> i</tex>-ый элемент алфавита. | |
− | Говорят, что слово <tex> ~A </tex> меньше слова <tex> ~B </tex>, если выполнено | + | Говорят, что слово <tex> ~A </tex> меньше слова <tex> ~B </tex>, если выполнено одно из следующих условий: |
# Слово <tex> ~A </tex> является префиксом слова <tex> ~B </tex>. | # Слово <tex> ~A </tex> является префиксом слова <tex> ~B </tex>. | ||
Строка 9: | Строка 9: | ||
Приведем псевдокод сравнения слов: | Приведем псевдокод сравнения слов: | ||
function isEqual(A, B : string) | function isEqual(A, B : string) | ||
− | for i = | + | for i = 1 .. min(len(A), len(B)) |
if (A[i] < B[i]) | if (A[i] < B[i]) | ||
return < | return < | ||
if (A[i] > B[i]) | if (A[i] > B[i]) | ||
return > | return > | ||
− | //Одна из строк является префиксом другой | + | // Одна из строк является префиксом другой |
if (len(A) < len(B)) | if (len(A) < len(B)) | ||
return < | return < | ||
if (len(A) > len(B)) | if (len(A) > len(B)) | ||
return > | return > | ||
− | return = //Длины строк и все символы равны | + | return = // Длины строк и все символы равны |
+ | |||
+ | Слова записаны в лексикографическом порядке, если для любых <tex> i<j </tex> выполняется неравенство <tex> S_i<S_j </tex>, где <tex> S_i </tex> и <tex> S_j </tex> слова с номерами <tex> i </tex> и <tex> j </tex>. | ||
== Примеры == | == Примеры == |
Версия 02:27, 22 ноября 2011
Определение
Пусть нам дан алфавит, на котором определен порядок. То есть для любых
выполнено неравенство , где -ый элемент алфавита.Говорят, что слово
меньше слова , если выполнено одно из следующих условий:- Слово является префиксом слова .
- Cуществует такое, что для всех выполнено неравенство , а . Элементы слова мы можем сравнивать, так как это элементы алфавита, а на алфавите задан строгий порядок.
Приведем псевдокод сравнения слов:
function isEqual(A, B : string) for i = 1 .. min(len(A), len(B)) 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).
- Порядок слов в словаре. Предполагается, что буквы можно сравнивать, сравнивая их номера в алфавите. Тогда лексикографический порядок — это, например, ААА, ААБ, ААВ, ААГ, …, ЯЯЯ.
- Эти слова тоже записаны в лексикографическом порядке: азбука, бог, борода, сон, сонный.