Saint8083 / binary_trees

a tree that has two child

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

** C- BINARY TREE **

Traversing a tree means visiting every node in the tree. You might, for instance, want to add all the values in the tree or find the largest one. For all these operations, you will need to visit each node of the tree.

Linear data structures like arrays, stacks, queues, and linked list have only one way to read the data. But a hierarchical data structure like a tree can be traversed in different

struct node { int data; struct node* left; struct node* right; }

// Tree traversal in C

#include <stdio.h> #include <stdlib.h>

struct node { int item; struct node* left; struct node* right; };

// Inorder traversal void inorderTraversal(struct node* root) { if (root == NULL) return; inorderTraversal(root->left); printf("%d ->", root->item); inorderTraversal(root->right); }

// preorderTraversal traversal void preorderTraversal(struct node* root) { if (root == NULL) return; printf("%d ->", root->item); preorderTraversal(root->left); preorderTraversal(root->right); }

// postorderTraversal traversal void postorderTraversal(struct node* root) { if (root == NULL) return; postorderTraversal(root->left); postorderTraversal(root->right); printf("%d ->", root->item); }

// Create a new Node struct node* createNode(value) { struct node* newNode = malloc(sizeof(struct node)); newNode->item = value; newNode->left = NULL; newNode->right = NULL;

return newNode; }

// Insert on the left of the node struct node* insertLeft(struct node* root, int value) { root->left = createNode(value); return root->left; }

// Insert on the right of the node struct node* insertRight(struct node* root, int value) { root->right = createNode(value); return root->right; }

int main() { struct node* root = createNode(1); insertLeft(root, 12); insertRight(root, 9);

insertLeft(root->left, 5); insertRight(root->left, 6);

printf("Inorder traversal \n"); inorderTraversal(root);

printf("\nPreorder traversal \n"); preorderTraversal(root);

printf("\nPostorder traversal \n"); postorderTraversal(root); }

About

a tree that has two child


Languages

Language:C 100.0%