Форум программистов, компьютерный форум, киберфорум
Prolog
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 30.09.2013
Сообщений: 147

Написать на языке Prolog программу для решения известной задачи о волке, козе и капусте

21.04.2020, 17:28. Показов 1397. Ответов 4

Студворк — интернет-сервис помощи студентам
Нужно написать на языке Prolog программу для решения известной задачи о волке, козе и капусте. Программа должна быть написана в visual prolog 5.2
Ранее никогда не работала с данной программой, поэтому прошу у вас помощи. Может у кого-то есть готовая программа. Либо уже именно файл программы, который можно будет запустить. Буду благодарна!
Задание: У фермера есть волк, коза и капуста, и все они находятся на левом берегу реки. Необходимо провести это “трио” на правый берег, но в лодку может поместиться что-то одно – волк, коза или капуста. Рискованно оставлять на одном берегу волка вместе с козой, равно как и козу вместе с капустой.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.04.2020, 17:28
Ответы с готовыми решениями:

Swi Prolog. Задача о волке, козе и капусте
Здравствуйте! Помогите решить пожалуйста на Swi Prolog задачу о волке, козе и капусте. Решение: Приходится начать с козы. Крестьянин,...

Разработать программу на языке Java для решения следующей задачи:
Опишите класс отрезков на плоскости. Задайте функцию сравнения двух отрезков, а также функцию, проверяющую, пересекаются ли отрезки в...

Составьте программу для решения поставленной задачи, используя оператор switch - case. (на языке Си)
Составить программу, которая читает натуральное число N в десятичном представлении (N < 10000), а на выходе выдает это же число в...

4
 Аватар для arlat
798 / 601 / 158
Регистрация: 07.10.2013
Сообщений: 1,330
22.04.2020, 11:22
Prolog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
% main.pro
 
implement main
    open
        core,
        console %, list, math, string
 
constants
    wolf : symbol = "wolf".
    goat : symbol = "goat".
    cabbage : symbol = "cabbage".
    alone : symbol = "alone".
    left : symbol = "left".
    right : symbol = "right".
 
domains
    slist = string*.
    state = wgc(string, slist, slist).
    history = state*.
    moves = tuple{state, string}*.
 
class predicates
    solve_dfs : (state, history, moves) nondeterm (i,i,o).
    initial_state : (state) procedure (o).
    final_state : (state) determ anyflow.
    move : (state, string) multi (i,o).
    update : (state, string, state) nondeterm (i,i,o).
    update_boat : (string, string) determ (i,o).
    update_bank : (string, string, slist, slist, slist, slist) nondeterm (i,i,i,i,o,o).
    select : (string, slist, slist) nondeterm (i,i,o).
    insert : (string, slist, slist) nondeterm (i,i,o).
    precedes : (string, string) nondeterm (i,i).
    legal : (state) determ (i).
    illegal : (slist) nondeterm (i).
    test : () determ.
 
clauses
    test() :-
        initial_state(State),
        write(State),
        nl,
        solve_dfs(State, [State], Moves),
        foreach tuple(CurrentState, Animal) in Moves do
            write(CurrentState, " -> ", Animal),
            nl
        end foreach,
        final_state(State1),
        write(State1),
        nl,
        !.
 
    solve_dfs(State, _, []) :-
        final_state(State).
    solve_dfs(State, History, [tuple(State, Move) | Moves]) :-
        move(State, Move),
        update(State, Move, State1),
        legal(State1),
        not(State1 in History),
        solve_dfs(State1, [State1 | History], Moves).
 
    initial_state(wgc(left, [wolf, goat, cabbage], [])).
 
    final_state(wgc(right, [], [wolf, goat, cabbage])).
 
    move(wgc(left, L, _), Cargo) :-
        Cargo in L.
    move(wgc(right, _, R), Cargo) :-
        Cargo in R.
    move(wgc(_, _, _), alone).
 
    update(wgc(B, L, R), Cargo, wgc(B1, L1, R1)) :-
        update_boat(B, B1),
        update_bank(Cargo, B, L, R, L1, R1).
 
    update_boat(left, right).
    update_boat(right, left).
 
    update_bank(alone, _, L, R, L, R).
    update_bank(Cargo, left, L, R, L1, R1) :-
        select(Cargo, L, L1),
        insert(Cargo, R, R1).
    update_bank(Cargo, right, L, R, L1, R1) :-
        select(Cargo, R, R1),
        insert(Cargo, L, L1).
 
    insert(X, [Y | Ys], [X, Y | Ys]) :-
        precedes(X, Y).
    insert(X, [Y | Ys], [Y | Zs]) :-
        precedes(Y, X),
        insert(X, Ys, Zs).
    insert(X, [], [X]).
 
    precedes(wolf, _).
    precedes(_, cabbage).
 
    legal(wgc(left, _, R)) :-
        not(illegal(R)).
    legal(wgc(right, L, _)) :-
        not(illegal(L)).
 
    illegal(L) :-
        wolf in L,
        goat in L.
    illegal(L) :-
        goat in L,
        cabbage in L.
 
    select(X, [X | Xs], Xs).
    select(X, [Y | Ys], [Y | Zs]) :-
        select(X, Ys, Zs).
 
class predicates
    run : (integer).
clauses
    run(7) :-
        write("Задача о волке, козе и капусте"),
        nl,
        test,
        !.
    run(_).
 
    run() :-
        initUtf8,
        setConsoleTitle("Visual Prolog 9 Personal Edition: Консольное приложение"),
        run(7),
        _ = readLine().
 
end implement main
 
goal
    main::run.
Миниатюры
Написать на языке Prolog программу для решения известной задачи о волке, козе и капусте  
0
 Аватар для arlat
798 / 601 / 158
Регистрация: 07.10.2013
Сообщений: 1,330
22.04.2020, 11:23
Цитата Сообщение от anna587 Посмотреть сообщение
должна быть написана в visual prolog 5.2
только 9, надо идти в ногу со временем
0
0 / 0 / 0
Регистрация: 18.05.2021
Сообщений: 7
21.10.2021, 16:47
получается на 5.2 код не запустится?
а то в универе именно 5.2 просят...
0
 Аватар для arlat
798 / 601 / 158
Регистрация: 07.10.2013
Сообщений: 1,330
21.10.2021, 18:00
Цитата Сообщение от Vita56 Посмотреть сообщение
получается на 5.2 код не запустится?
надо модифицировать по мелочам, сделайте новый консольный проект в 5.2 и посмотрите что там за шаблон...

Добавлено через 5 минут
Если бы 7.5. хотя бы, а 5.2 искать и ставить как-то...
Где-то тут есть знатоки, возможно implement не надо, секция predicates с другим систаксисом, не помню точно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.10.2021, 18:00
Помогаю со студенческими работами здесь

Написать на С++ программу для решения задачи
Помогите написать код для решения задачи по нахождению радиуса круга, описанного вокруг треугольника

Написать программу для решения задачи
Вот сама задача Нарушение пунктов 5.4, 5.18 правил форума. Закрыто.

Написать программу для решения задачи
Всем привет, помогите, пожалуйста написать программу для решения следующей задачи: в заданной числовой последовательности подсчитать и...

Написать программу для решения задачи
Написать программу для решения задачи из определенной предметной области. Дано натуральное число n (n ≤ 100). Определить: ...

Составить программу на языке Паскаль для решения задачи: Дано слово. Вывести на экран его третий символ
Составить программу на языке Паскаль для решения задачи: Дано слово. Вывести на экран его третий символ.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru