这似乎很简单......
h(state(A,B,C,D,E,F,G,H,I),Z) :-
count_matching([A,B,C,D,E,F,G,H,I], [1,2,3,8,0,4,7,6,5], 0, Z).
count_matching([], [], N, N).
count_matching([A|As], [B|Bs], N, M) :-
( A == B
-> T is N + 1
; T is N
),
count_matching(As, Bs, T, M).
SWI-Prolog 聚合库提供了另一种解决问题的简单方法:
:- [library(aggregate)].
h(state(A,B,C,D,E,F,G,H,I),Z) :-
aggregate_all(count,
(nth1(Index, [1,2,3,8,0,4,7,6,5], Cell),
nth1(Index, [A,B,C,D,E,F,G,H,I], Cell)), Z).
使用 aggregate_all 太过分了:这里是一个使用相同模式的更简单的程序(通过 nth/3 对元素进行非确定性访问):
h(state(A,B,C,D,E,F,G,H,I),Z) :-
findall(_,
(nth1(Index, [1,2,3,8,0,4,7,6,5], Cell),
nth1(Index, [A,B,C,D,E,F,G,H,I], Cell)), L),
length(L, Z).