Mic*_*ahl 3 lambda prolog meta-predicate
我想用maplist/3实现的目标可以是跟随伪代码:
maplist(
lambda X: Z/Y=X, to_lower(Z,LC), char_code(L,LC), return L/Y,
['A'/42, 'B'/500],
Res).
Res = ['a'/42, 'b'/500]
Run Code Online (Sandbox Code Playgroud)
我知道可以写例如
maplist(plus(1), [1,2,3,4], Res).
Res = [2,3,4,5].
Run Code Online (Sandbox Code Playgroud)
所以我可以将伪代码定义lambda X: Z/Y=X, to_lower(Z,LC), char_code(L,LC), return L/Y为普通谓词,并在maplist中使用此谓词...
但是,我很好奇是否可以在不创建全新谓词的情况下执行此操作?
我想这样做的原因是因为我觉得阅读更自然,而不是在代码中跳转来找到谓词
?- maplist(\ (Z/Y)^(L/Y)^ ( char_code(Z,ZC),
to_lower(ZC,LC),
char_code(L,LC) ), ['A'/42, 'B'/500], Res).
Res = [a/42, b/500].
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
90 次 |
| 最近记录: |