【发布时间】:2021-12-08 08:11:39
【问题描述】:
我正在尝试使用递归在树状对象中查找最小值和最大值,但我实际上并不了解如何找到这些值。此外,我的函数必须是纯函数,不能使用循环或 forEach。只有 map、reduce、filter 可用。所以这就是我的数据的样子:
const tree = {
children: [
{
children: [
{
children: [],
values: [15.667786122807836]
}
],
values: [35.77483035532576, 1.056418140526505]
},
{
children: [
{
children: [
{
children: [],
values: [67.83058067285563]
}
],
values: [98.89823527559626]
}
],
values: [51.49890385802418, 41.85766285823911]
},
],
values: [6.852857017193847, 28.110428400306265, 51.385186145220494]};
我正在尝试做这样的事情:
const min = graph => {
if (!graph.children.length && !graph.values.length) return;
if (!graph.children.length && graph.values.length) {
return Math.min(...graph.values);
}
return graph.children.map(el => {
const minValue = Math.min(...el.values);
min(el);
return minValue;
});
};
但这并不好用。所以任何人都可以解释调用堆栈是如何工作的,也许给我一些很好的例子,并解释如何解决我的问题。感谢您的帮助,抱歉英语不好)。哦,还有))如何获取不同深度级别的两个节点之间的距离?
【问题讨论】:
-
你意识到map、reduce和filter都是循环对吧?见:Find the minimum and maximum values in the nested object
-
感谢您的帮助,好帖子!
标签: javascript recursion data-structures binary-tree