首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >使用递归打印BST - javascript的值

使用递归打印BST - javascript的值
EN

Stack Overflow用户
提问于 2018-10-25 17:37:05
回答 1查看 32关注 0票数 0

在Javascript中,我试图更好地理解BST的这段代码中的递归。我可以使用递归用两个方法打印出BST的值,但是我不知道如何在一个方法中完成所有的工作。

我怎么才能结合

代码语言:javascript
代码运行次数:0
运行
复制
BinarySearchTree.prototype.dfs = function(node) {
  if (node) {
    console.log(node.val);
    this.dfs(node.left);
    this.dfs(node.right);
  }
}

BinarySearchTree.prototype.depthFirstTraversal = function() {
  let current = this.root;
  this.dfs(current);
}

变成一个函数?我一直在努力

代码语言:javascript
代码运行次数:0
运行
复制
BinarySearchTree.prototype.sameFunction = function(node = null) {
    // if node is null use this.root
    let current = node || this.root;
 
    if (current) {
        console.log(current.val);
        this.sameFunction(current.left);
        this.sameFunction(current.right);
    }
}

http://jsfiddle.net/rj2tyd4L/

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-25 18:17:02

如果使用第二个参数isRoot并将其默认值设置为true如何?

代码语言:javascript
代码运行次数:0
运行
复制
BinarySearchTree.prototype.sameFunction = function(node = null, isRoot = true) {
  let current = isRoot ? this.root : node;
  if (current) {
    console.log(current.val);
    this.sameFunction(current.left, false);
    this.sameFunction(current.right, false);
  }
}

http://jsfiddle.net/fez1jtsx/

这使得tree.sameFunction()等同于调用tree.depthFirstTraversal()

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52995129

复制
相关文章

相似问题

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