java怎么獲取下級(jí)所有childrenid

小億
158
2023-10-25 10:00:10
欄目: 編程語言

在Java中,可以使用遞歸的方式來獲取下級(jí)所有children ID。以下是一個(gè)示例代碼:

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Main {
    public static void main(String[] args) {
        Map<Integer, List<Integer>> childrenMap = new HashMap<>();
        childrenMap.put(1, List.of(2, 3));
        childrenMap.put(2, List.of(4, 5));
        childrenMap.put(3, List.of(6, 7));

        List<Integer> childrenIds = getChildrenIds(childrenMap, 1);
        System.out.println(childrenIds);
    }

    public static List<Integer> getChildrenIds(Map<Integer, List<Integer>> childrenMap, int parentId) {
        List<Integer> childrenIds = new ArrayList<>();
        List<Integer> children = childrenMap.get(parentId);

        if (children != null) {
            for (int childId : children) {
                childrenIds.add(childId);
                childrenIds.addAll(getChildrenIds(childrenMap, childId));
            }
        }

        return childrenIds;
    }
}

在上面的示例中,我們使用一個(gè)Map<Integer, List<Integer>>來表示父級(jí)和子級(jí)之間的關(guān)系。getChildrenIds方法使用遞歸的方式來獲取下級(jí)所有children ID。在每次迭代中,我們將當(dāng)前子級(jí)的ID添加到結(jié)果列表中,并繼續(xù)遞歸調(diào)用以獲取該子級(jí)的下級(jí)ID。最后,返回所有children ID的列表。

在示例中,我們使用childrenMap來表示以下關(guān)系:

  • 父級(jí)1有子級(jí)2和3
  • 子級(jí)2有子級(jí)4和5
  • 子級(jí)3有子級(jí)6和7

輸出結(jié)果為:[2, 4, 5, 3, 6, 7],表示1的所有下級(jí)ID為2、4、5、3、6和7。

0