以递归方式从指定根节点,获取一个树型结构的数据

1、以递归方式从指定根节点,获取一个树型结构的数据!

/**
* 根据指定的根节点从List中遍历一个子树出来;
*
* @param paramCollect:提供树节点数据的集合;
* @param paramDesList:产生的目标子数的集合;
* @param paramTreeRoot:树根元素;
* @return void:无返回值;
*/
private static void getSubTree(List<String> paramCollect,
List<String> paramDesList, final String paramTreeRoot) {
// try {
// Thread.sleep(100);// 1秒钟查看一次
// System.out.println("=1=" + paramCollect.size());
// } catch (InterruptedException ie) {
// ie.printStackTrace();
// }

if (paramCollect.isEmpty()) {
return;
} else {
int size = (paramCollect == null) ? 0 : paramCollect.size();
List<String> tempList = new ArrayList<String>();
for (int i = (size - 1); i >= 0; i--) {
String key = paramCollect.get(i);
String[] arrKey = key.split(SYMBOL_FOR_SPLIT_BROKER_INFO);
// 此处要严格判断相等,不能使用包含关系,比如:des2,des3包含des,但不等于des;
if (arrKey[0].trim().intern() == paramTreeRoot.trim().intern()
|| arrKey[1].trim().intern() == paramTreeRoot.trim()
.intern()) {
paramDesList.add(key);
tempList.add(key);
paramCollect.remove(i);
}
}

boolean isRecursiveStopping = false;
for (int j = 0; j < (tempList == null ? 0 : tempList.size()); j++) {
String key = (String) tempList.get(j);
String[] arrKey = key.split(SYMBOL_FOR_SPLIT_BROKER_INFO);
if (arrKey[0].trim().intern() == paramTreeRoot.trim().intern()) {
getSubTree(paramCollect, paramDesList, arrKey[1]);
} else {
getSubTree(paramCollect, paramDesList, arrKey[0]);
}
isRecursiveStopping = true;
}
if (isRecursiveStopping) {
return;
}

}

}

public static void main(String[] params) {
List<String> data = new ArrayList<String>();
data.add("a<>b");
data.add("a<>c");
data.add("a<>e");
data.add("c<>d");
data.add("d<>f");
data.add("m<>l");
data.add("g<>h");
data.add("i<>j");
data.add("j<>k");
data.add("c<>h");

List<String> testList = new ArrayList<String>();
getSubTree(data, testList, "a");

for (int i = 0; i < (testList == null ? 0 : testList.size()); i++) {
String key = (String) testList.get(i);
System.out.println("=No."+(i+1)+" key is:=" + key + "=end=");
}
}
注意:Map(HashMap和Hashtable)中remove和hasNext不能同时操作,所有用List(ArrayList)数据结构来遍历;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值