首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在js中跳出bts的traverseInOrder方法中的函数?

如何在js中跳出bts的traverseInOrder方法中的函数?
EN

Stack Overflow用户
提问于 2021-11-21 10:07:15
回答 1查看 23关注 0票数 0

我使用的是来自https://www.npmjs.com/package/@datastructures-js/binary-search-tree的bts。我不想使用traverseInOrder方法遍历整个树,在条件为真后如何停止和退出函数?

代码语言:javascript
复制
bts.traverseInOrder((node) => {
  if (condition) return;
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-21 10:30:31

不,在该方法中没有可预见的提前退出功能。

您仍然可以引发错误并捕获它:

代码语言:javascript
复制
try {
    bts.traverseInOrder(node => {
        if (condition) throw new Error("exit");
    });
} catch(e) {
    if (e?.message != "exit") throw e; // It was a different error
}

或者,定义您自己的方法。在这种情况下,我建议使用更现代的生成器模式,而不是回调模式:

代码语言:javascript
复制
// Extend the API with this generator
Object.assign(BinarySearchTree.prototype, {
    *iterateInOrder() {
        function* iterateRecursive(current) {
            if (current === null) return;
            yield* iterateRecursive(current.getLeft());
            yield current;
            yield* iterateRecursive(current.getRight());
        }
        yield* iterateRecursive(this._root);
    }
});

现在您可以使用for .. of循环:

代码语言:javascript
复制
for (let node of bst.iterateInOrder()) {
    if (condition) break;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70053540

复制
相关文章

相似问题

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