Построить список минимумов - Prolog

Узнай цену своей работы

Формулировка задачи:

Задан список целых чисел L, сформировать список L1 из элементов: минимальный элемент всего списка L, минимальный элемент из последних n-1 элементов и т.д.

Решение задачи: «Построить список минимумов»

textual
Листинг программы
domains 
int=integer
intl=int*
 
predicates
min_elt(intl,int)
task(intl,intl)
 
clauses
 
min_elt([X],X).
min_elt([H|T],H) :- min_elt(T,Y), H<Y.
min_elt([H|T],Z) :- min_elt(T,Z), H>=Z.
 
task([],[]).
task([H|T],[A|R]) :- min_elt([H|T],A), task(T,R).

Объяснение кода листинга программы

В коде используется язык программирования Prolog. Постановка задачи - построить список минимумов.

  1. В первом предложении объявлены два домена: int - целое число, intl - список целых чисел.
  2. Далее идут два предиката: min_elt - находит минимальный элемент в списке, task - основная функция, которая решает задачу.
  3. Первое предложение в блоке clauses описывает рекурсивную функцию для списка, содержащего один элемент.
  4. Второе и третье предложения в блоке clauses описывают рекурсивную функцию для списка, содержащего более одного элемента.
  5. Четвертое и пятое предложения в блоке clauses описывают рекурсивную функцию для списка, содержащего более двух элементов.
  6. Шестое и седьмое предложения в блоке clauses описывают основную функцию, которая рекурсивно вызывает функцию min_elt и функцию task.
  7. Восьмое и девятое предложения в блоке clauses описывают рекурсивный вызов функции task.
  8. Десятое и одиннадцатое предложения в блоке clauses описывают рекурсивный вызов функции min_elt.
  9. Двенадцатое и тринадцатое предложения в блоке clauses описывают сравнение текущего элемента со следующим и возвращение минимального значения.
  10. Последнее предложение в блоке clauses описывает базовый случай, когда список пустой.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

14   голосов , оценка 3.929 из 5
Похожие ответы