我正在 Prolog 中编写数独求解器。数独本身作为向量的向量给出:
P =
[[1,_,_, _,_,_, _,_,_],
[_,_,2, 7,4,_, _,_,_],
[_,_,_, 5,_,_, _,_,4],
[_,3,_, _,_,_, _,_,_],
[7,5,_, _,_,_, _,_,_],
[_,_,_, _,_,9, 6,_,_],
[_,4,_, _,_,6, _,_,_],
[_,_,_, _,_,_, _,7,1],
[_,_,_, _,_,1, _,3,_]].
我正在使用以下代码将其转换为矩阵:
convert_to_matrix(P, Puzzle) :-
dim(Puzzle, [9, 9]), % create square matrix
( multifor([I, J], 1, 9), % fill array
param(P, Puzzle)
do
nth1(I, P, RowI),
nth1(J, RowI, Elem),
subscript(Puzzle, [I , J], Elem)
).
这适用于前 8 行和列,但每次 I 或 J 为 9 时都会失败。执行 nth1(9, P, RowI) 会使 RowI 成为一个全新的变量,而不是第 9 个向量/行。执行 nth1(9,RowI, Elem) 不会返回第 9 个元素(对于第 8 行,它应该返回 1,但返回一个新变量)。这是 Eclipse-clp 中的错误还是我遗漏了什么?