我正在尝试使用 Prolog 解决爱因斯坦之谜。任务是
- 挪威人住在第一间房子里。
- 英国人住在红房子里。
- 瑞典有狗作为宠物。
- 丹麦人喝茶。
- 绿屋在白宫的左边。
- 住在温室里的男人喝咖啡。
- 抽 Pall Mall 烟的人养鸟。
- 住在黄屋的男人抽登喜路。
- 住在中屋的男人喝牛奶。
- 抽 Blends 的人住在有猫的人旁边。
- 养马的人住在抽登喜路的人旁边。
- 抽蓝大师的男人喝啤酒。
- 德国人抽王子。
- 挪威人住在青瓦台旁边。
- 抽 Blends 的人是喝水的人的邻居。
- 有人有一个鱼缸。
该程序:
neighbor(Rua):-
length(Rua, 5),
Rua = [casa(_,noruegues,_,_,_)|_],
member(casa(vermelha,ingles,_,_,_),Rua),
member(casa(_,sueco,_,_,cachorros),Rua),
member(casa(_,dinamarques,cha,_,_),Rua),
esquerda(casa(verde,_,_,_,_), casa(branca,_,_,_,_),Rua),
member(casa(verde,_,cafe,_,_),Rua),
member(casa(_,_,_,pallmall,passaros),Rua),
member(casa(amarela,_,_,dunhill,_),Rua),
Rua = [_,_,casa(_,_,leite,_,_),_,_],
ao_lado(casa(_,_,_,blends,_), casa(_,_,_,_,gatos),Rua),
ao_lado(casa(_,_,_,_,cavalos), casa(_,_,_,dunhill,_),Rua),
member(casa(_,_,cerveja,bluemaster,_),Rua),
member(casa(_,alemao,_,prince,_),Rua),
ao_lado(casa(_,noruegues,_,_,_), casa(azul,_,_,_,_),Rua),
ao_lado(casa(_,_,_,blends,_), casa(_,_,agua,_,_),Rua),
member(casa(_,_,_,_,peixes),Rua).
ao_lado([X,Y|_],X, Y).
ao_lado([X,Y|_],Y, X).
ao_lado([_|L],X, Y):-
ao_lado(L, X, Y).
esquerda([A|As], A, E) :-
member2(E, As).
esquerda([_|As], A, E) :-
esquerda(As, A, E).