java map递归_java – 如何递归flatMap流?

参见英文答案 >

In Java, how do I efficiently and elegantly stream a tree node’s descendants?                                    4个

我被要求检索作为树节点的descandant的每个叶节点.我很快意识到我可以在一条线上完成这项工作!

public Set> getLeaves() {

return getChildrenStream().flatMap(n -> n.getChildrenStream()).collect(toSet());

}

第一眼看上去很擅长,但很快就遇到StackOverflowExcepetion,树深达到10,这是我无法接受的.后来我开发了一个没有递归和流的实现(但是用我的大脑烤了),但我仍然想知道是否有办法用流做递归flatMaps,因为我发现如果不触及流内部结构就不可能这样做.它需要一个新的Op,比如RecursiveOps,或者我必须将每个步骤中的所有结果收集到Set中,然后对该Set进行操作:

Set> prev = new HashSet<>();

prev.add(this);

while (!prev.isEmpty()) {

prev = prev.stream().flatMap(n -> n.getChildrenStream()).collect(toSet());

}

return prev;

看起来并不好.流是一个管道.在添加终端操作之前,不会计算其结果和中间结果.上述方法显然违反了这一原则.它也不像溪流那样容易混淆.我可以递归flatMap而无需手动计算所有中间结果吗?

PS1:TreeNode声明:

public class TreeNode {

// ...

/**

* Get a stream of children of the current node.

*

*/

public Stream> getChildrenStream(){

// ...

}

public Set> getLeaves() {

// main concern

}

}f

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值