color(red).
color(green).
color(blue).
color(yellow).
adjacent(鶴見, 神奈川).
adjacent(神奈川, 西).
adjacent(西, 中).
adjacent(中, 南).
adjacent(南, 港南).
adjacent(港南, 磯子).
adjacent(磯子, 金沢).
adjacent(金沢, 栄).
adjacent(栄, 港南).
adjacent(中, 保土ケ谷).
adjacent(保土ケ谷, 西).
adjacent(保土ケ谷, 旭).
adjacent(旭, 瀬谷).
adjacent(瀬谷, 泉).
adjacent(泉, 戸塚).
adjacent(戸塚, 栄).
adjacent(都筑, 港北).
adjacent(都筑, 青葉).
adjacent(都筑, 緑).
adjacent(港北, 神奈川).
adjacent(緑, 青葉).
adjacent(港北, 鶴見).
adjacent(保土ケ谷, 緑).
different(X-Y, Z-W) :-
(adjacent
(X
, Z
); adjacent
(Z
, X
)) -> Y \
= W
; true.
coloring([
鶴見-A, 神奈川-B, 西-C, 中-D, 南-E, 港南-F,
磯子-G, 金沢-H, 栄-I, 保土ケ谷-J, 旭-K, 瀬谷-L,
泉-M, 戸塚-N, 都筑-O, 港北-P, 緑-Q, 青葉-R
]) :-
color(A), color(B), color(C), color(D),
color(E), color(F), color(G), color(H),
color(I), color(J), color(K), color(L),
color(M), color(N), color(O), color(P),
color(Q), color(R),
Vars = [
鶴見-A, 神奈川-B, 西-C, 中-D, 南-E, 港南-F,
磯子-G, 金沢-H, 栄-I, 保土ケ谷-J, 旭-K, 瀬谷-L,
泉-M, 戸塚-N, 都筑-O, 港北-P, 緑-Q, 青葉-R
],
% 制約を先にまとめて課す
forall(
(member(X1-Y1, Vars), member(X2-Y2, Vars), X1 @< X2),
different(X1-Y1, X2-Y2)
),
% 出力
print_colors(Vars).
print_colors([]).
print_colors([区-色 | 残り]) :-
print_colors(残り).
:- coloring(_).
Y29sb3IocmVkKS4KY29sb3IoZ3JlZW4pLgpjb2xvcihibHVlKS4KY29sb3IoeWVsbG93KS4KCmFkamFjZW50KOm2tOimiywg56We5aWI5bedKS4KYWRqYWNlbnQo56We5aWI5bedLCDopb8pLgphZGphY2VudCjopb8sIOS4rSkuCmFkamFjZW50KOS4rSwg5Y2XKS4KYWRqYWNlbnQo5Y2XLCDmuK/ljZcpLgphZGphY2VudCjmuK/ljZcsIOejr+WtkCkuCmFkamFjZW50KOejr+WtkCwg6YeR5rKiKS4KYWRqYWNlbnQo6YeR5rKiLCDmoIQpLgphZGphY2VudCjmoIQsIOa4r+WNlykuCmFkamFjZW50KOS4rSwg5L+d5Zyf44Kx6LC3KS4KYWRqYWNlbnQo5L+d5Zyf44Kx6LC3LCDopb8pLgphZGphY2VudCjkv53lnJ/jgrHosLcsIOaXrSkuCmFkamFjZW50KOaXrSwg54Cs6LC3KS4KYWRqYWNlbnQo54Cs6LC3LCDms4kpLgphZGphY2VudCjms4ksIOaIuOWhmikuCmFkamFjZW50KOaIuOWhmiwg5qCEKS4KYWRqYWNlbnQo6YO9562RLCDmuK/ljJcpLgphZGphY2VudCjpg73nrZEsIOmdkuiRiSkuCmFkamFjZW50KOmDveetkSwg57eRKS4KYWRqYWNlbnQo5riv5YyXLCDnpZ7lpYjlt50pLgphZGphY2VudCjnt5EsIOmdkuiRiSkuCmFkamFjZW50KOa4r+WMlywg6ba06KaLKS4KYWRqYWNlbnQo5L+d5Zyf44Kx6LC3LCDnt5EpLgoKZGlmZmVyZW50KFgtWSwgWi1XKSA6LQogICAgKGFkamFjZW50KFgsIFopOyBhZGphY2VudChaLCBYKSkgLT4gWSBcPSBXIDsgdHJ1ZS4KCmNvbG9yaW5nKFsKICAgIOm2tOimiy1BLCDnpZ7lpYjlt50tQiwg6KW/LUMsIOS4rS1ELCDljZctRSwg5riv5Y2XLUYsCiAgICDno6/lrZAtRywg6YeR5rKiLUgsIOaghC1JLCDkv53lnJ/jgrHosLctSiwg5petLUssIOeArOiwty1MLAogICAg5rOJLU0sIOaIuOWhmi1OLCDpg73nrZEtTywg5riv5YyXLVAsIOe3kS1RLCDpnZLokYktUgpdKSA6LQogICAgY29sb3IoQSksIGNvbG9yKEIpLCBjb2xvcihDKSwgY29sb3IoRCksCiAgICBjb2xvcihFKSwgY29sb3IoRiksIGNvbG9yKEcpLCBjb2xvcihIKSwKICAgIGNvbG9yKEkpLCBjb2xvcihKKSwgY29sb3IoSyksIGNvbG9yKEwpLAogICAgY29sb3IoTSksIGNvbG9yKE4pLCBjb2xvcihPKSwgY29sb3IoUCksCiAgICBjb2xvcihRKSwgY29sb3IoUiksCgogICAgVmFycyA9IFsKICAgICAgICDptrTopostQSwg56We5aWI5bedLUIsIOilvy1DLCDkuK0tRCwg5Y2XLUUsIOa4r+WNly1GLAogICAgICAgIOejr+WtkC1HLCDph5HmsqItSCwg5qCELUksIOS/neWcn+OCseiwty1KLCDml60tSywg54Cs6LC3LUwsCiAgICAgICAg5rOJLU0sIOaIuOWhmi1OLCDpg73nrZEtTywg5riv5YyXLVAsIOe3kS1RLCDpnZLokYktUgogICAgXSwKCiAgICAlIOWItue0hOOCkuWFiOOBq+OBvuOBqOOCgeOBpuiqsuOBmQogICAgZm9yYWxsKAogICAgICAgIChtZW1iZXIoWDEtWTEsIFZhcnMpLCBtZW1iZXIoWDItWTIsIFZhcnMpLCBYMSBAPCBYMiksCiAgICAgICAgZGlmZmVyZW50KFgxLVkxLCBYMi1ZMikKICAgICksCgogICAgJSDlh7rlipsKICAgIHdyaXRlKCc06Imy44Gn5aGX44KK5YiG44GR5Y+v6IO9JyksIG5sLAogICAgcHJpbnRfY29sb3JzKFZhcnMpLgoKcHJpbnRfY29sb3JzKFtdKS4KcHJpbnRfY29sb3JzKFvljLot6ImyIHwg5q6L44KKXSkgOi0KICAgIHdyaXRlKOWMuiksIHdyaXRlKCcgLT4gJyksIHdyaXRlKOiJsiksIG5sLAogICAgcHJpbnRfY29sb3JzKOaui+OCiikuCgo6LSBjb2xvcmluZyhfKS4K