包装列表中的每个元素
Wrap every element from a list
如何包装列表中的每个元素?
我有这样的东西(2*3*4*...)^6
如何使用此输出制作列表:2^6 * 3^6 * 4^6 * ...
我正在考虑使用 maplist 做一些简单的事情,但我不确定如何在第一个参数中向函数发送参数。
simplify(X^Y,R):- X=..[*|Args], maplist(?^Y, Args, Args2), R=..[*|Args2], !.
:- simplify((2*x)^6, (2^6) * (x^6)). %should be true
顺便用Swi-prolog
您的输入数据结构不包含任何列表,它是一个嵌套结构,叶子上有数字:
?- write_canonical(2*3*4*5).
*(*(*(2, 3), 4), 5)
因此maplist在这里用处不大。相反,编写一个简单的递归谓词来遍历(并重构)递归数据结构:
simplify(N, Exp, N^Exp) :-
number(N).
simplify(L*R, Exp, LExp*RExp) :-
simplify(L, Exp, LExp),
simplify(R, Exp, RExp).
代码结构遵循数据结构。示例 运行
?- simplify(2*3*4*5, 6, E).
E = 2^6*3^6*4^6*5^6
Yes (0.00s cpu)
如何包装列表中的每个元素?
我有这样的东西(2*3*4*...)^6
如何使用此输出制作列表:2^6 * 3^6 * 4^6 * ...
我正在考虑使用 maplist 做一些简单的事情,但我不确定如何在第一个参数中向函数发送参数。
simplify(X^Y,R):- X=..[*|Args], maplist(?^Y, Args, Args2), R=..[*|Args2], !.
:- simplify((2*x)^6, (2^6) * (x^6)). %should be true
顺便用Swi-prolog
您的输入数据结构不包含任何列表,它是一个嵌套结构,叶子上有数字:
?- write_canonical(2*3*4*5).
*(*(*(2, 3), 4), 5)
因此maplist在这里用处不大。相反,编写一个简单的递归谓词来遍历(并重构)递归数据结构:
simplify(N, Exp, N^Exp) :-
number(N).
simplify(L*R, Exp, LExp*RExp) :-
simplify(L, Exp, LExp),
simplify(R, Exp, RExp).
代码结构遵循数据结构。示例 运行
?- simplify(2*3*4*5, 6, E).
E = 2^6*3^6*4^6*5^6
Yes (0.00s cpu)