Лексикографический порядок — различия между версиями
|  (→Определение) |  (→Определение) | ||
| Строка 1: | Строка 1: | ||
| == Определение == | == Определение == | ||
| − | Пусть нам дан алфавит, на котором определен порядок | + | Пусть нам дан алфавит, на котором определен линейный порядок.   | 
| Говорят, что слово <tex> ~A </tex> меньше слова <tex> ~B </tex>, если выполнено одно из следующих условий: | Говорят, что слово <tex> ~A </tex> меньше слова <tex> ~B </tex>, если выполнено одно из следующих условий: | ||
| # Слово <tex> ~A </tex> является префиксом слова <tex> ~B </tex>. | # Слово <tex> ~A </tex> является префиксом слова <tex> ~B </tex>. | ||
| − | # Cуществует <tex> i </tex>  <tex> \ge 0 </tex> такое, что для всех <tex> j < i </tex> выполнено неравенство <tex> A_j = B_j </tex>, а <tex> A_i < B_i </tex>.  | + | # Cуществует <tex> i </tex>  <tex> \ge 0 </tex> такое, что для всех <tex> j < i </tex> выполнено неравенство <tex> A_j = B_j </tex>, а <tex> A_i < B_i </tex>. | 
| − | |||
| Приведем псевдокод сравнения слов: | Приведем псевдокод сравнения слов: | ||
|   function isEqual(A, B : string) |   function isEqual(A, B : string) | ||
Версия 02:07, 1 декабря 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).
- Порядок слов в словаре. Предполагается, что буквы можно сравнивать, сравнивая их номера в алфавите. Тогда лексикографический порядок — это, например, ААА, ААБ, ААВ, ААГ, …, ЯЯЯ.
- Эти слова тоже записаны в лексикографическом порядке: азбука, бог, борода, сон, сонный.
