Partage de technologie

Comment déterminer le niveau d'une liste d'arborescence Java

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

solution
Idées d'algorithmes
Afin de déterminer à quel niveau se trouve la liste dans la structure arborescente, nous pouvons parcourir chaque nœud de manière récursive et calculer sa profondeur. Plus précisément, pour chaque nœud, nous pouvons parcourir son nœud parent vers le haut jusqu'au nœud racine, tout en accumulant la valeur de profondeur. La valeur de profondeur finale est le niveau auquel se trouve le nœud.

exemple de code
Voici un exemple de code Java simple, utilisé pour déterminer le niveau d'un nœud dans une structure arborescente :

public class TreeNode {
    private int id;
    private int parentId;

    public TreeNode(int id, int parentId) {
        this.id = id;
        this.parentId = parentId;
    }

    public int getId() {
        return id;
    }

    public int getParentId() {
        return parentId;
    }
}

public class TreeUtils {
    public static int getLevel(TreeNode node, List<TreeNode> nodeList) {
        int level = 1;
        int parentId = node.getParentId();
        
        while (parentId != 0) {
            for (TreeNode n : nodeList) {
                if (n.getId() == parentId) {
                    parentId = n.getParentId();
                    level++;
                    break;
                }
            }
        }
        
        return level;
    }
}

public class Main {
    public static void main(String[] args) {
        List<TreeNode> nodeList = new ArrayList<>();
        nodeList.add(new TreeNode(1, 0));
        nodeList.add(new TreeNode(2, 1));
        nodeList.add(new TreeNode(3, 1));
        nodeList.add(new TreeNode(4, 2));

        TreeNode node = nodeList.get(3);
        int level = TreeUtils.getLevel(node, nodeList);
        System.out.println("Node " + node.getId() + " is at level " + level);
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50