首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ocaml -打印树枝的长度(如树)的原理是从左到深

Ocaml -打印树枝的长度(如树)的原理是从左到深
EN

Stack Overflow用户
提问于 2013-06-20 00:42:44
回答 1查看 166关注 0票数 0

我有一个Ocaml示例,我正在处理它。我需要根据从左到深的原则来显示某种树中所有分支的长度。所以如果我们有这棵树:

代码语言:javascript
复制
     4

  2     6

1  3  5  7

我想在树上显示所有树枝的长度。你有什么想法吗?

我们有衬套的类型,它的定义如下:

代码语言:javascript
复制
# type 'a bush = 
   Null
   | One of 'a * 'a bush
   | Two of 'a bush * 'a * 'a bush;;

写一个函数“分支长度”‘一个灌木丛的->单元,它根据从左到深的原理显示一个灌木丛的分支的长度!

EN

回答 1

Stack Overflow用户

发布于 2013-06-20 16:51:49

根据你对分支长度的定义,你可以这样递归地遍历你的树:

代码语言:javascript
复制
let rec branches_length bush depth = match bush with
| Null -> [depth]
| One (a, b) -> (branches_length b (depth + 1))
| Two (a, b, c) -> (branches_length a (depth + 1))@(branches_length c (depth + 1))
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17196781

复制
相关文章

相似问题

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