Лексикографический порядок
Версия от 21:20, 5 декабря 2013; YanaZimka (обсуждение | вклад) (Добавлены поля определений. Формулировка переделана в терминах последовательностей. Псевдокод удобнее для чтения. Английская вики.)
Определение
Определение: |
Пусть даны две последовательности Тогда последовательность | и
Приведем псевдокод сравнения последовательностей:
function Сompare(A, B : string) // Возвращает "LESS", если A < B, "MORE", если A > B, или "EQUAL", если последовательности равны for i = 1 .. 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 // Длины последовательностей и все элементы равны
Определение: |
Последовательности записаны в лексикографическом порядке (in lexicographical order), если для любых | выполняется неравенство , где и последовательности с номерами и .
Например, слово "сон" лексикографически меньше слова "сонный", так как оно является его префиксом. Слово "низ" лексикографически меньше слова "нос", поскольку первые символы совпадают, а второй символ первого слова меньше, чем второй символ второго.
Примеры
- Последовательность чисел в любой системе счисления, записанных в фиксированной разрядной сетке (000, 001, 002, 003, 004, 005, …, 999).
- Порядок слов в словаре. Предполагается, что буквы можно сравнивать, сравнивая их номера в алфавите. Тогда лексикографический порядок — это, например, ААА, ААБ, ААВ, ААГ, …, ЯЯЯ.
- Эти слова тоже записаны в лексикографическом порядке: азбука, бог, борода, сон, сонный.