junk/metro.pl

54 lines
1.8 KiB
Prolog

% "constraint logic programming over finite domains" ---
% the number stuff. which is the only thing going on
% in this program. oh well
%
% https://www.swi-prolog.org/pldoc/man?section=clpfd
:- use_module(library(clpfd)).
go :-
solution(Vars), labeling([ff], Vars),
add_names(Vars, NVs), keysort(NVs, SNVs), group_pairs_by_key(SNVs, Groups),
maplist(writeln, Groups).
solution_count(N) :-
setof(Vars, (solution(Vars), labeling([ff], Vars)), Res),
length(Res, N).
add_names(Vals, Named) :-
Names = [nineteen, twentyone, twentyfive, thirty, thirtyeight,
collision, explosion, kidnapping, robbery, vandalism,
hat, jacket, sunglasses, tie, turtleneck,
bat, brokenbottle, gun, knife, sword,
phone, purse, suitcase, violin, watch],
pairs_keys_values(Named, Vals, Names).
solution(Vars) :-
Vars = [Nineteen, Twentyone, Twentyfive, Thirty, Thirtyeight,
Collision, Explosion, Kidnapping, Robbery, Vandalism,
Hat, Jacket, Sunglasses, Tie, Turtleneck,
Bat, BrokenBottle, Gun, Knife, Sword,
Phone, Purse, Suitcase, Violin, Watch],
Vars ins 1..5,
all_distinct([Nineteen, Twentyone, Twentyfive, Thirty, Thirtyeight]),
all_distinct([Collision, Explosion, Kidnapping, Robbery, Vandalism]),
all_distinct([Hat, Jacket, Sunglasses, Tie, Turtleneck]),
all_distinct([Bat, BrokenBottle, Gun, Knife, Sword]),
all_distinct([Phone, Purse, Suitcase, Violin, Watch]),
Hat = Purse,
Sunglasses = Explosion,
Jacket = Bat,
adjacent(Watch, Violin),
Watch = Knife,
Thirty = Collision,
Suitcase = Twentyfive,
Gun = 3,
Turtleneck = 1,
Thirtyeight #< Robbery,
adjacent(Vandalism, Twentyfive),
Sword = Nineteen,
Tie = Twentyone,
adjacent(Turtleneck, Phone),
adjacent(Thirtyeight, BrokenBottle).
adjacent(X, Y) :- X #= Y + 1.
adjacent(X, Y) :- X #= Y - 1.