首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在BinTree上使用typescript在PreOrder中旅行

在BinTree上使用typescript在PreOrder中旅行
EN

Stack Overflow用户
提问于 2018-04-02 17:56:20
回答 2查看 148关注 0票数 3

嗨,我接到了一个任务,要实现一个遍历bin树的函数,并按预排序返回它的所有值。代码如下:

代码语言:javascript
复制
interface BinTree {
    root: number;
    left?: BinTree;
    right?: BinTree;
};
const TreePreArray =(t:BinTree):number[] => {
    let list = new Array<number>();
    if (t==undefined) {return list }
    else {
        list.push(t.root)
        list.concat(TreePreArray(t.left))
        list.concat(TreePreArray(t.right))
    }
    return list
}
let bn : BinTree = {
    root: 1,
    left: { root: 2 },
    right: { root: 3 }
}
console.log((TreePreArray(bn)));

但输出只有1,而不是1,2,3我已经复制了这个链接Recursive Tree Traversal Method With Return Type Array的想法,并在typescript中实现了它。

EN

回答 2

Stack Overflow用户

发布于 2018-04-02 18:06:56

您需要推送或者使用concat的结果。因为缺少concat结果的赋值,所以您错过了遍历分支的结果。

任一

代码语言:javascript
复制
list = list.concat(TreePreArray(t.left))
list = list.concat(TreePreArray(t.right))

代码语言:javascript
复制
list.push(...TreePreArray(t.left))
list.push(...TreePreArray(t.right))
票数 1
EN

Stack Overflow用户

发布于 2018-04-02 18:08:48

这实际上是迭代器的一个很好的用例:

代码语言:javascript
复制
 function* leftFirst({left, right, root} : BinTree) {
  yield root; 
  if(left) yield* leftFirst(left); 
  if(right) yield* leftFirst(right); 
 }

要获得一个数组,只需执行以下操作:

代码语言:javascript
复制
 [...leftFirst(someTree)]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49609088

复制
相关文章

相似问题

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