Сибирский университет потребительской кооперации
Опубликован: 04.05.2005 | Доступ: свободный | Студентов: 4322 / 1347 | Оценка: 4.45 / 4.22 | Длительность: 12:28:00
ISBN: 978-5-9556-0034-5
Лекция 8:

Сортировка списков

< Лекция 7 || Лекция 8: 12345 || Лекция 9 >

Пузырьковая сортировка

Идея этого метода заключается в следующем. На каждом шаге сравниваются два соседних элемента списка. Если оказывается, что они стоят неправильно, то есть предыдущий элемент больше следующего, то они меняются местами. Этот процесс продолжаем до тех пор, пока есть пары соседних элементов, расположенные в неправильном порядке. Это и будет означать, что список отсортирован.

Аналогия с пузырьком вызвана тем, что при каждом проходе минимальные элементы как бы "всплывают" к началу списка.

Реализуем пузырьковую сортировку посредством двух предикатов. Один из них, назовем его permutation, будет сравнивать два первых элемента списка и в случае, если первый окажется больше второго, менять их местами. Если же первая пара расположена в правильном порядке, этот предикат будет переходить к рассмотрению хвоста.

Основной предикат bubble будет осуществлять пузырьковую сортировку списка, используя вспомогательный предикат permutation.

permutation([X,Y|T],[Y,X|T]):–
                        X>Y,!.
                              /* переставляем первые два
                                 элемента, если первый больше
                                 второго */
permutation([X|T],[X|T1]):–
                        permutation(T,T1).
                              /*переходим к перестановкам
                                в хвосте*/
bubble(L,L1):–
     permutation(L,LL), /* вызываем предикат,
                           осуществляющий перестановку */
     !,
     bubble(LL,L1). /* пытаемся еще раз отсортировать
                       полученный список */
bubble(L,L). /* если перестановок не было, значит список
                отсортирован */

Но наш пузырьковый метод работает только до тех пор, пока есть хотя бы пара элементов списка, расположенных в неправильном порядке. Как только такие элементы закончились, предикат permutation терпит неудачу, а bubble переходит от правила к факту и возвращает в качестве второго аргумента отсортированный список.

Сортировка вставкой

Теперь рассмотрим сортировку вставкой. Она основана на том, что если хвост списка уже отсортирован, то достаточно поставить первый элемент списка на его место в хвосте, и весь список будет отсортирован. При реализации этой идеи создадим два предиката.

Задача предиката insert — вставить значение (голову исходного списка) в уже отсортированный список (хвост исходного списка), так чтобы он остался упорядоченным. Его первым аргументом будет вставляемое значение, вторым — отсортированный список, третьим — список, полученный вставкой первого аргумента в нужное место второго аргумента так, чтобы не нарушить порядок.

Предикат ins_sort, собственно, и будет организовывать сортировку исходного списка методом вставок. В качестве первого аргумента ему дают произвольный список, который нужно отсортировать. Вторым аргументом он возвращает список, состоящий из элементов исходного списка, стоящих в правильном порядке.

ins_sort([ ],[ ]). /* отсортированный пустой список
                      остается пустым списком */
ins_sort([H|T],L):–
                  ins_sort(T,T_Sort),
                       /* T — хвост исходного списка,
                          T_Sort — отсортированный хвост
                          исходного списка */
                  insert(H,T_Sort,L).
                       /* вставляем H (первый элемент
                          исходного списка)в T_Sort,
                          получаем L (список, состоящий
                          из элементов исходного списка,
                          стоящих по неубыванию) */
insert(X,[],[X]). /* при вставке любого значения в пустой
                     список, получаем одноэлементный
                     список */
insert(X,[H|T],[H|T1]):–
                   X>H,!, /* если вставляемое значение
                             больше головы списка, значит
                             его нужно вставлять в хвост */
                   insert(X,T,T1).
                        /* вставляем X в хвост T,
                           в результате получаем
                           список T1 */
insert(X,T,[X|T]). /* это предложение (за счет отсечения
                      в предыдущем правиле) выполняется,
                      только если вставляемое значение
                      не больше головы списка T, значит,
                      добавляем его первым элементом
                      в список T */

Сортировка выбором

Идея алгоритма сортировки выбором очень проста. В списке находим минимальный элемент (используя предикат min_list, который мы придумали в начале этой лекции). Удаляем его из списка (с помощью предиката delete_one, рассмотренного в предыдущей лекции). Оставшийся список сортируем. Приписываем минимальный элемент в качестве головы к отсортированному списку. Так как этот элемент был меньше всех элементов исходного списка, он будет меньше всех элементов отсортированного списка. И, следовательно, если его поместить в голову отсортированного списка, то порядок не нарушится.

Запишем:

choice([ ],[ ]). /* отсортированный пустой список
                    остается пустым списком */
choice(L,[X|T]):– /* приписываем X (минимальный элемент
                     списка L) к отсортированному
                     списку T */
                min_list(L,X), /* X — минимальный элемент
                                  списка L */
                delete_one(X,L,L1),
                               /* L1 — результат удаления
                                       первого вхождения
                                       элемента X из списка L */
                choice(L1,T). /* сортируем список L1,
                                 результат обозначаем T */
< Лекция 7 || Лекция 8: 12345 || Лекция 9 >
Виктор Бондарь
Виктор Бондарь

После приведения формулы вида ПНФ к виду ССФ вы получаете формулу, в безквантовой матрице которой дизъюнкт содержит оба контранрных атома:. Как тогда проводить его унификацию, если в случае замены x на f(x) весь дизъюнкт обратится в единицу?

Ольга Потапенко
Ольга Потапенко

никак не могу увидеть тексты самих лекций.