Squeak.ru - шаблоны программирования

Рекурсия пролога в списке

Я пытаюсь понять, как работает эта программа-пролог, и, как новичок, у меня возникают некоторые трудности. Программа выглядит следующим образом:

initialCan([w, b, w, w, w]).
scholten([X], X).
scholten([X, X | Z], Answer) :- scholten([b | Z], Answer).
scholten([X, Y | Z], Answer) :- scholten([w | Z], Answer).
run(Answer) :- initialCan(L), scholten(L, Answer).

Вот след от первого решения.

{trace}
| ?- run(A).
      1    1  Call: run(_17) ? 
      2    2  Call: initialCan(_84) ? 
      2    2  Exit: initialCan([w,b,w,w,w]) ? 
      3    2  Call: scholten([w,b,w,w,w],_17) ? 
      4    3  Call: scholten([w,w,w,w],_17) ? 
      5    4  Call: scholten([b,w,w],_17) ? 
      6    5  Call: scholten([w,w],_17) ? 
      7    6  Call: scholten([b],_17) ? 
      7    6  Exit: scholten([b],b) ? 
      6    5  Exit: scholten([w,w],b) ? 
      5    4  Exit: scholten([b,w,w],b) ? 
      4    3  Exit: scholten([w,w,w,w],b) ? 
      3    2  Exit: scholten([w,b,w,w,w],b) ? 
      1    1  Exit: run(b) ? 

A = b ? 

У меня проблемы с пониманием того, как работают рекурсивные вызовы. Что именно происходит с

scholten([X, X | Z], Answer) :- scholten([b | Z], Answer).

Больше всего сбивает с толку разница между [X, X | Z] и [b | Z]. Любая помощь будет оценена.

15.03.2013

Ответы:


1

Рассматриваемое правило гласит, что если scholten видит список, который начинается с двух идентичных элементов, эти два элемента необходимо заменить одним b. Список [b | Z] на один элемент короче, чем [X, X | Z].

Обратите внимание, что приведенное ниже правило

scholten([X, Y | Z], Answer) :- scholten([w | Z], Answer).

имеет одноэлементную (т.е. нигде больше не используемую) переменную Y. Вы должны изменить правило на

scholten([X, Y | Z], Answer) :- X \= Y, scholten([w | Z], Answer).

чтобы гарантировать, что X не равно Y, предотвращая сопоставление этого правила с теми же аргументами, что и [X, X | Z].

15.03.2013
  • Спасибо, это очень помогает. Я не мог осознать тот факт, что он проверяет, совпадают ли первые два элемента или разные. 15.03.2013
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

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

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...