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.