问题描述
- java 递归 输入一个ID 怎么把这个ID下所有的子ID 放入一个list里面 递归都写好了
-
HashMap> results = new HashMap>();//输入的ID int ID=Integer.parseInt(Catid); //表中所有的数据 aas=cloudnewscategory.selectAllGory(); System.out.println("所有记录="+aas); for (CloudNewsCategory gory : aas) { System.out.println("536456747="+results.get(gory.getPARENTID())); List<CloudNewsCategory> beans = results.get(gory.getPARENTID()); if (beans == null) { beans = new ArrayList<CloudNewsCategory>(); results.put(gory.getPARENTID(), beans); } beans.add(gory); } displayMap(results,ID,""); public static void displayMap(HashMap<Integer, List<CloudNewsCategory>> results, int startKey, String str) { List<CloudNewsCategory> list = results.get(startKey);
// System.out.println("shuji="+results.get(startKey));
for (CloudNewsCategory gory : list) {
vv.add(gory.getID());
System.out.println(str + gory.getID() + "|"+gory.getCATEGORY());
if (results.containsKey(gory.getID())) {
displayMap(results, gory.getID(), str + " ");} } } 控制台打印如下:![图片说明](http://img.ask.csdn.net/upload/201508/20/1440034025_984725.png) 怎么得到一个list 里面是所有的子ID阿 急求~~~~~
解决方案
你这样肯定不好,推荐你用Map<父ID,子ID的List>,你这样去做,父ID就记录了,也能按照相应的记录去取,另外,你要先把对应的子ID整合成List.
尽量不要用递归,数据量大的时候,会有问题。
解决方案二:
循环就可以了吧,只有有子的,都放到List中去
时间: 2024-12-13 21:53:34