N-арные деревья в Си - PullRequest
       60

N-арные деревья в Си

15 голосов
/ 10 октября 2008

Какой была бы аккуратная реализация N-арного дерева на языке Си?

Particulary, я хочу реализовать n-арное дерево, а не самобалансирующееся, с несвязанным числом дочерних элементов в каждом узле, в котором каждый узел содержит уже определенную структуру, например, так:

struct task {
  char command[MAX_LENGTH];
  int required_time;
};

Ответы [ 2 ]

52 голосов
/ 10 октября 2008

Любое n-арное дерево может быть представлено в виде двоичного дерева, где в каждом узле левый указатель указывает на первого потомка, а правый указатель указывает на следующего брата.

             R                        R
           / | \                      |
          B  C  D                     B -- C -- D
         / \    |                     |         |
        E   F   G                     E -- F    G

Итак, ваш случай будет:

struct task {
  char command[MAX_LENGTH];
  int required_time;
};

struct node {
  struct task taskinfo;
  struct node *firstchild;
  struct node *nextsibling;
};

Преимущество этого метода заключается в том, что многие алгоритмы проще писать, поскольку они могут быть выражены в двоичном дереве, а не в более сложной структуре данных.

13 голосов
/ 10 октября 2008

В качестве первого прохода вы можете просто создать struct (назовем это TreeNode ), которая содержит задачу , а также набор указателей. TreeNode с. Этот набор может быть либо массивом (если N является фиксированным), либо связанным списком (если N является переменной). Связанный список потребует от вас объявить дополнительную struct (назовем это ListNode ) с указателем TreeNode на фактический дочерний элемент (часть дерева) и указатель на следующий ListNode в списке ( null , если в конце списка).

Это может выглядеть примерно так:

struct task {
  char command[MAX_LENGTH];
  int required_time;
};

struct TreeNode;

struct ListNode {
  struct TreeNode * child;
  struct ListNode * next;
};

struct TreeNode {
  struct task myTask;
  struct ListNode myChildList;
};
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...