首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >取一棵树,列一张表

取一棵树,列一张表
EN

Stack Overflow用户
提问于 2012-03-27 18:25:22
回答 4查看 183关注 0票数 0

我已经写了一个程序,可以获取列表并将其转换为树。

代码语言:javascript
复制
build_tree([X,Y],'Tree'(X,Y)) :- !.

build_tree([X|Y],'Tree'(X,Z)) :- build_tree(Y, Z).

如果我想颠倒这个过程,把树改回列表,我该怎么做呢?

EN

Stack Overflow用户

发布于 2012-03-27 18:40:34

请注意,树->列表转换不是一个函数,因为树可能对应于多个列表:

代码语言:javascript
复制
?- build_tree([1, 2, 3], T).
T = 'Tree'(1, 'Tree'(2, 3)).

?- build_tree([1, 'Tree'(2, 3)], T).
T = 'Tree'(1, 'Tree'(2, 3)).

如果您想要一个可以从树生成所有列表的谓词,请从build_tree中删除cut,并使用变量first参数应用它。如果需要确定性转换,请编写一个新的谓词tree_to_list

票数 0
EN
查看全部 4 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9887704

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档