1
0
This repository has been archived on 2025-03-06. You can view files and clone it, but cannot push or open issues or pull requests.
Jip J. Dekker f2a1c4e389 Squashed 'software/mza/' content from commit f970a59b17
git-subtree-dir: software/mza
git-subtree-split: f970a59b177c13ca3dd8aaef8cc6681d83b7e813
2021-07-11 16:34:30 +10:00

147 lines
4.1 KiB
MiniZinc

% RUNS ON mzn20_fd
% RUNS ON mzn-fzn_fd
% RUNS ON mzn20_fd_linear
% RUNS ON mzn20_mip
% WHO OWNS THE ZEBRA?
%
% This is a puzzle which has been circulating the net. There are a couple
% different versions out there which try to be a little more politically
% correct but are essentially the same problem.
% 1. There are five houses, each of a different color and inhabited by
% men of different nationalities, with different pets, drinks,
% and cigarettes.
% 2. The Englishman lives in the red house.
% 3. The Spaniard owns the dog.
% 4. Coffee is drunk in the green house.
% 5. The Ukrainian drinks tea.
% 6. The green house is immediately to the right of the ivory house.
% 7. The Old Gold smoker owns snails.
% 8. Kools are smoked in the yellow house.
% 9. Milk is drunk in the middle house.
% 10. The Norwegian lives in the first house on the left.
% 11. The man who smokes Chesterfields lives in the house next to the
% man with the fox.
% 12. Kools are smoked in the house next to the house where the horse is
% kept.
% 13. The Lucky Strike smoker drinks orange juice.
% 14. The Japanese smoke Parliaments.
% 15. The Norwegian lives next to the blue house.
% NOW, who drinks water? And who owns the zebra?
% MiniZinc Version
% Peter Stuckey September 30 2006
include "globals.mzn";
%enum Nationalities = { English, Spanish, Ukrainian, Norwegian, Japanese };
set of int: Nationalities = 0..4;
int: English = 0;
int: Spanish = 1;
int: Ukrainian = 2;
int: Norwegian = 3;
int: Japanese = 4;
%enum Colours = { Red, Green, Ivory, Yellow, Blue };
set of int: Colours = 0..4;
int: Red = 0;
int: Green = 1;
int: Ivory = 2;
int: Yellow = 3;
int: Blue = 4;
%enum Animals = { Dog, Fox, Horse, Zebra, Snails };
set of int: Animals = 0..4;
int: Dog = 0;
int: Fox = 1;
int: Horse = 2;
int: Zebra = 3;
int: Snails = 4;
%enum Drinks = { Coffee, Tea, Milk, OrangeJuice, Water };
set of int: Drinks = 0..4;
int: Coffee = 0;
int: Tea = 1;
int: Milk = 2;
int: OrangeJuice = 3;
int: Water = 4;
%enum Cigarettes = { OldGold, Kools, Chesterfields, LuckyStrike,
% Parliaments } ;
set of int: Cigarettes = 0..4;
int: OldGold = 0;
int: Kools = 1;
int: Chesterfields = 2;
int: LuckyStrike = 3;
int: Parliaments = 4;
set of int: Houses = 1..5;
array[Nationalities] of var Houses: nation;
array[Colours] of var Houses: colour;
array[Animals] of var Houses: animal;
array[Drinks] of var Houses: drink;
array[Cigarettes] of var Houses: smoke;
predicate nextto(var Houses:h1, var Houses:h2) =
h1 == h2 + 1 \/ h2 == h1 + 1;
predicate rightof(var Houses:h1, var Houses:h2) =
h1 == h2 + 1;
predicate middle(var Houses:h) = h == 3;
predicate left(var Houses:h) = h = 1;
constraint
alldifferent(nation) /\
alldifferent(colour) /\
alldifferent(animal) /\
alldifferent(drink) /\
alldifferent(smoke) /\
nation[English] == colour[Red] /\
nation[Spanish] == animal[Dog] /\
drink[Coffee] == colour[Green] /\
nation[Ukrainian] == drink[Tea] /\
colour[Green] `rightof` colour[Ivory] /\
smoke[OldGold] == animal[Snails] /\
smoke[Kools] == colour[Yellow] /\
middle(drink[Milk]) /\
left(nation[Norwegian]) /\
smoke[Chesterfields] `nextto` animal[Fox] /\
smoke[Kools] `nextto` animal[Horse] /\
smoke[LuckyStrike] == drink[OrangeJuice] /\
nation[Japanese] == smoke[Parliaments] /\
nation[Norwegian] `nextto` colour[Blue];
solve satisfy;
output [
"zebra:\n",
"nation = [",
show(nation[0]), ", ",
show(nation[1]), ", ",
show(nation[2]), ", ",
show(nation[3]), ", ",
show(nation[4]), "]\n",
"colour = [",
show(colour[0]), ", ",
show(colour[1]), ", ",
show(colour[2]), ", ",
show(colour[3]), ", ",
show(colour[4]), "]\n",
"animal = [",
show(animal[0]), ", ",
show(animal[1]), ", ",
show(animal[2]), ", ",
show(animal[3]), ", ",
show(animal[4]), "]\n",
"drink = [",
show(drink[0]), ", ",
show(drink[1]), ", ",
show(drink[2]), ", ",
show(drink[3]), ", ",
show(drink[4]), "]\n",
"smoke = [",
show(smoke[0]), ", ",
show(smoke[1]), ", ",
show(smoke[2]), ", ",
show(smoke[3]), ", ",
show(smoke[4]), "]\n"
];