libin103 1.4
Bibliothèque de structures de données en C
|
Structure de données d'arbre binaire contenant des valeurs de type char . Plus de détails...
#include <stdlib.h>
#include <stdbool.h>
Aller au code source de ce fichier.
Structures de données | |
struct | character_bitreenode_t |
Type de données pour un noeud de l'arbre binaire stockant des valeurs de type char Plus de détails... | |
struct | character_bitree_t |
Type de données pour l'arbre binaire. Plus de détails... | |
Définitions de type | |
typedef struct character_bitreenode_t | character_bitreenode_t |
Type de données pour un noeud de l'arbre binaire stockant des valeurs de type char | |
typedef struct character_bitree_t | character_bitree_t |
Type de données pour l'arbre binaire. | |
Fonctions | |
void | character_bitree_init (character_bitree_t *tree) |
Initialisation d'un nouvel arbre binaire. | |
void | character_bitree_destroy (character_bitree_t *tree) |
Destruction d'un arbre binaire. | |
int | character_bitree_ins_left (character_bitree_t *tree, character_bitreenode_t *node, char data) |
Insertion d'un noeud en position fils gauche dans un arbre binaire à une position donnée. | |
int | character_bitree_ins_right (character_bitree_t *tree, character_bitreenode_t *node, char data) |
Insertion d'un noeud en position fils droit dans un arbre binaire à une position donnée. | |
void | character_bitree_rem_left (character_bitree_t *tree, character_bitreenode_t *node) |
Suppression d'un sous arbre en position fils gauche dans un arbre binaire à une position donnée. | |
void | character_bitree_rem_right (character_bitree_t *tree, character_bitreenode_t *node) |
Suppression d'un sous arbre en position fils droit dans un arbre binaire à une position donnée. | |
int | character_bitree_merge (character_bitree_t *merge, character_bitree_t *left, character_bitree_t *right, char data) |
Fusion de deux arbres binaires. | |
int | character_bitree_size (character_bitree_t *tree) |
Accesseur pour la taille de l'arbre binaire. | |
character_bitreenode_t * | character_bitree_root (character_bitree_t *tree) |
Accesseur pour récupérer la racine. | |
bool | character_bitree_is_eob (character_bitreenode_t *node) |
Test si un noeud est la fin du branche. | |
bool | character_bitree_is_leaf (character_bitreenode_t *node) |
Test si un noeud est une feuille. | |
char | character_bitree_data (character_bitreenode_t *node) |
Accesseur pour récupérer la valeur stockée dans un noeud. | |
character_bitreenode_t * | character_bitree_left (character_bitreenode_t *node) |
Accesseur pour récupérer le fils gauche d'un noeud. | |
character_bitreenode_t * | character_bitree_right (character_bitreenode_t *node) |
Accesseur pour récupérer le fils droit d'un noeud. | |
Structure de données d'arbre binaire contenant des valeurs de type char .
typedef struct character_bitree_t character_bitree_t |
Type de données pour l'arbre binaire.
typedef struct character_bitreenode_t character_bitreenode_t |
Type de données pour un noeud de l'arbre binaire stockant des valeurs de type char
char character_bitree_data | ( | character_bitreenode_t * | node | ) |
Accesseur pour récupérer la valeur stockée dans un noeud.
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud pour lequel on veut la valeur |
void character_bitree_destroy | ( | character_bitree_t * | tree | ) |
Destruction d'un arbre binaire.
Met à zéro la taille et à NULL le pointeur vers la racine après avoir parcourus l'arbre pour détruire tous les noeuds en utilisant les fonctions character_bitree_ins_left et character_bitree_ins_right.
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre |
void character_bitree_init | ( | character_bitree_t * | tree | ) |
Initialisation d'un nouvel arbre binaire.
Met à zéro la taille et à NULL le pointeur vers la racine
tree | est un pointeur vers la structure de données character_bitree_t |
int character_bitree_ins_left | ( | character_bitree_t * | tree, |
character_bitreenode_t * | node, | ||
char | data ) |
Insertion d'un noeud en position fils gauche dans un arbre binaire à une position donnée.
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre |
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud auquel ajouté un fils gauche |
data | la valeur à stocker dans le fils gauche créé |
int character_bitree_ins_right | ( | character_bitree_t * | tree, |
character_bitreenode_t * | node, | ||
char | data ) |
Insertion d'un noeud en position fils droit dans un arbre binaire à une position donnée.
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre |
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud auquel ajouté un fils droit |
data | la valeur à stocker dans le fils droit créé |
bool character_bitree_is_eob | ( | character_bitreenode_t * | node | ) |
Test si un noeud est la fin du branche.
Vérifie si le noeud est NULL ou pas
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud à tester |
bool character_bitree_is_leaf | ( | character_bitreenode_t * | node | ) |
Test si un noeud est une feuille.
Vérifie que le fils gauche et le fils droit d'un noeud sont NULL
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud à tester |
character_bitreenode_t * character_bitree_left | ( | character_bitreenode_t * | node | ) |
Accesseur pour récupérer le fils gauche d'un noeud.
Donne le pointeur vers le noeud fils gauche
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud pour lequel on veut le fils gauche |
int character_bitree_merge | ( | character_bitree_t * | merge, |
character_bitree_t * | left, | ||
character_bitree_t * | right, | ||
char | data ) |
Fusion de deux arbres binaires.
merge | est un pointeur vers la structure de données character_bitree_t contenant l'arbre issu de la fusion de left et right |
left | est un pointeur vers la structure de données character_bitree_t représentant un arbre binaire qui sera en position sous arbre gauche dans la fusion |
right | est un pointeur vers la structure de données character_bitree_t représentant un arbre binaire qui sera en position sous arbre droit dans la fusion |
data | valeur de type char qui sera stockée à la racine de l'arbre binaire issue de la fusion |
void character_bitree_rem_left | ( | character_bitree_t * | tree, |
character_bitreenode_t * | node ) |
Suppression d'un sous arbre en position fils gauche dans un arbre binaire à une position donnée.
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre |
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud auquel il faut supprimer le sous-arbre gauche |
void character_bitree_rem_right | ( | character_bitree_t * | tree, |
character_bitreenode_t * | node ) |
Suppression d'un sous arbre en position fils droit dans un arbre binaire à une position donnée.
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre |
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud auquel il faut supprimer le sous-arbre droit |
character_bitreenode_t * character_bitree_right | ( | character_bitreenode_t * | node | ) |
Accesseur pour récupérer le fils droit d'un noeud.
Donne le pointeur vers le noeud fils droit
node | est un pointeur vers la structure de données character_bitreenode_t représentant le noeud pour lequel on veut le fils droit |
character_bitreenode_t * character_bitree_root | ( | character_bitree_t * | tree | ) |
Accesseur pour récupérer la racine.
Donne le pointeur vers le noeud racine
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre binaire |
int character_bitree_size | ( | character_bitree_t * | tree | ) |
Accesseur pour la taille de l'arbre binaire.
Donne le nombre de noeud dans l'arbre binaire
tree | est un pointeur vers la structure de données character_bitree_t contenant la racine de l'arbre binaire |