Книга: Программирование на языке Пролог для искусственного интеллекта
6.2.2. Вывод списков
6.2.2. Вывод списков
Кроме стандартного прологовского формата для списков существуют несколько других естественных форм их внешнего представления, которые в некоторых ситуациях являются более предпочтительными. Следующая процедура
вывспис( L)
выводит список L так, что каждый его элемент занимает отдельную строку:
вывспис( []).
вывспис( [X | L) :-
write( X), nl,
вывспис( L).
Если у нас есть список списков, то одной из естественных форм его выводе является такая, при которой все элементы каждого списка записываются на отдельной строке. Для этого мы определим процедуру вывспис2
. Вот пример ее использования:
?- вывспис2( [ [а, b, с], [d, e, f], [g, h, i] ] ).
а b с
d e f
g h i
Процедура, выполняющая эту работу, такова:
вывспис2( []).
вывспис2( [L | LL] ) :-
строка( L), nl,
вывспис1( LL).
строка( []).
строка( [X | L] ) :-
write( X), tab( 1),
строка( L).
Список целых чисел иногда удобно представить в виде диаграммы. Следующая процедура диагр
выводит список в такой форме (предполагается, что числа списка заключены между 0 и 80). Пример ее использования:
?- диагр( [3, 4, 6, 5] ).
***
****
******
*****
Процедуру диагр
можно определить так:
диагр( [N | L]) :-
звездочки( N), nl,
диагр( L).
звеэдочки( N) :-
N > 0,
write( *),
N1 is N - 1,
звездочки( N1).
звездочки( N) :-
N =< 80.
- Просмотр списков на узле SharePoint
- Вложение файлов в элементы списков
- Стеки на основе односвязных списков
- Сортировка списков данных
- 9.1.2. Сортировка списков
- Реализация связанных списков в ядре Linux
- Содержимое списков
- Процедуры ввода и вывода
- Очереди на основе односвязных списков
- Лекция 8. Формат списков аннулированных сертификатов
- Лекция 9. Типы списков аннулированных сертификатов и схемы аннулирования
- 3.1. Представление списков