forked from mmalita/PrologPuzzles
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmessage.pl
55 lines (50 loc) · 1.58 KB
/
message.pl
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
/* File: message.pl Author: M. Malita
Title: Message sending
Email is out of order at St. Mary's College and the teacher wants to tell Robert something urgent
The teacher meets Craig and asks him to tell Robert she wants to speak with him.
Craig says that if he meets Robert its OK, but else he will send the message to everyone he meets and the message will go further.
Each student tells each student he meets that the teacher waits for Robert in her office.
The students meet each other (we don't know in what order):
1) Craig meets John and Jason
2) Jason meets Kiki and Adam and David
3) Adam meets Scott and Jeremy
4) Jeremy meets John and Scott
5) Kiki meets Chris
6) Chris meets David and Adam
7) David meets Robert
Do you think the teacher will wait for ever in her office until Robert comes?
Display all the possible paths from Craig to Robert.
Ex :- ?- start,nl,false.
[ro,da,ch,ki,ja,ad,je,jo,cr]
[ro,da,ja,ad,je,jo,cr]
[ro,da,ja,ki,ch,ad,je,jo,cr]
[ro,da,ch,ad,je,jo,cr]
[ro,da,ch,ki,ja,ad,sc,je,jo,cr]
[ro,da,ja,ad,sc,je,jo,cr]
[ro,da,ja,ki,ch,ad,sc,je,jo,cr]
[ro,da,ch,ad,sc,je,jo,cr]
[ro,da,ch,ki,ja,cr]
[ro,da,ch,ad,ja,cr]
[ro,da,ja,cr]
*/
:- encoding(utf8).
:- use_module(library(lists)).
arc(cr,jo). arc(cr,ja).
arc(ja,ki). arc(ja,ad). arc(ja,da).
arc(ad,sc). arc(ad,je).
arc(je,jo). arc(je,sc).
arc(ki,ch).
arc(ch,da). arc(ch,ad).
arc(da,ro).
arc1(Y,X) :- arc(X,Y); arc(Y,X).
initial(cr).
final(ro).
start :-
initial(S),
bkt(S,[],Sol),
write(Sol).
bkt(Node,Path,[Node|Path]) :- final(Node).
bkt(Node,Path,Sol) :-
arc1(Node,N1),
\+member(N1,Path),
bkt(N1,[Node|Path],Sol).