package com.demos.practiceone.util;
import java.util.LinkedList;
import java.util.Map;
import java.util.Objects;
public class NestedMapFinder {
private final LinkedList<Object> orderChain = new LinkedList<>();
private boolean doesFindIt = false;
public boolean isFound() {
return this.doesFindIt;
}
public <T> LinkedList<?> find(Map<?, ?> map, T target) {
for (Map.Entry<?, ?> e : map.entrySet()) {
Object k = e.getKey();
Object v = e.getValue();
orderChain.add(k);
if ((target == null && v == null) || Objects.equals(target, v)) {
this.doesFindIt = true;
break;
} else {
if (v instanceof Map<?, ?>) {
this.find((Map<?, ?>) v, target);
} else {
orderChain.removeLast();
}
}
}
if (!this.doesFindIt && orderChain.size() != 0) {
orderChain.removeLast();
}
return orderChain;
}
}
在多层嵌套Map中查找值匹配的路径
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 路由种类: Nav,由 ion-nav 组件生成,继承自 NavControllerBase。 Tabs,由 io...
- 解题思路:首先判断根结点是否为空,不为空的话判断当前结点是否是叶子结点;如果当前存入集合的值小于target,且有...
- 唯一的解法就是,遍历所有结果。优化点就是,一旦出现 到某个节点,点数超过所要找的值,就放弃该节点,和所有它...
- 最近使用seajs开发的时候遇到一些问题,在此记录一下分享给大家。 模块定义 遵循seajs规范,模块化的js需要...
- 步骤1.找出最便宜的节点,即可再最短时间内前往的节点。2.队以该节点的邻居,检查是否有前往他们的更短路径,如果有,...