Лексикографический порядок
Версия от 23:28, 16 января 2012; Proshev (обсуждение | вклад)
Определение
Пусть нам дан алфавит , на котором определен линейный порядок.
Говорят, что слово меньше слова , если выполнено одно из следующих условий:
- Слово является префиксом слова .
- Cуществует такое, что для всех выполнено неравенство , а .
Приведем псевдокод сравнения слов:
function Сompare(A, B : string) // Возвращает "<" (если A < B), ">" (если A > B), или "=", (если строки равны)
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).
- Порядок слов в словаре. Предполагается, что буквы можно сравнивать, сравнивая их номера в алфавите. Тогда лексикографический порядок — это, например, ААА, ААБ, ААВ, ААГ, …, ЯЯЯ.
- Эти слова тоже записаны в лексикографическом порядке: азбука, бог, борода, сон, сонный.