好吧,因为我今天正在练习“Prolog 逻辑”,并且我在此处的另一个线程中发现了这个未解答的问题,所以我想知道它是如何工作的。
increment every element of list by its depth, example increment([0,0,[0]],[1,1,[2]]) -> true
我几乎以为我喜欢这种语言......:)) 这样的事情可能吗?谢谢。
最佳答案
以下代码完成这项工作:
increment(X,Y):- increment(X,0,Y).
increment([],_,[]) :- !.
increment([X|Xs],N,[Y|Ys]) :- !, N1 is N+1,
increment(X,N1,Y), increment(Xs,N,Ys).
increment(X,N,Y):- Y is X+N.
只是为了测试一下
?- increment([0,0,[0]],X).
X = [1, 1, [2]].
?- increment([0,0,[0,[0,0]]],X).
X = [1, 1, [2, [3, 3]]].
关于prolog - SWI-Prolog 中递增元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10066275/