mafulechka
mafulechkaJune 3, 2019, 4:31 a.m.

Tree traversal - inorder, preorder, and postorder (the three main traversals)

Tree traversal means visiting every node in the tree. For example, you can add all values to the tree or find the largest one. For all these operations, you will need to visit each node of the tree.


Linear data structures such as arrays, stacks, queues, and linked lists have only one way to read data. But a hierarchical data structure like a tree can be traversed in many different ways.

Let's think about how we can read the elements of the tree in the image shown above.

Starting from the top, left to right

1 -> 12 -> 9 -> 5 -> 6

Starting from the bottom, left to right

5 -> 6 -> 12 -> 9 -> 1

Although this process is somewhat simple, it does not take into account the hierarchy of the tree, only the depth of the nodes.

Instead, we use traversal methods that respect the underlying structure of the tree, i.e.

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

The struct node pointed to by left (left) and right (right) may have other left and right children, so we must treat them as subtrees, not subnodes.

According to this structure, each tree is a combination

  • Node carrying data
  • Two subtrees

Remember that our goal is to visit every node, so we need to visit all nodes in the subtree, visit the root node, and also visit all the nodes in the right subtree.

Depending on the order in which we do it, there can be three types of traversal .

Centered traversal type (Inorder traversal)

  1. First visit all nodes in the left subtree
  2. Then the root node
  3. Visit all nodes in the right subtree
inorder(root->left)
display(root->data)
inorder(root->right)

Direct traversal type (Preorder traversal)

  1. Visit the root node
  2. Visit all nodes in the left subtree
  3. Visit all nodes in the right subtree
display(root->data)
preorder(root->left)
preorder(root->right)

Postorder traversal

  1. visit all nodes in the left subtree
  2. visit the root node
  3. visit all nodes in the right subtree
postorder(root->left)
postorder(root->right)
display(root->data)

Let's visualize the centered traversal type. Let's start with the root node.

First we traverse the left subtree. We also need to remember to visit the root node and the right subtree when the tree is ready.

Let's put it all on a stack so we remember.

Now let's move on to the subtree specified at the top of the stack.

Again, we follow the same rule of centered type (inorder)

Left subtree -> root -> right subtree

After traversing the left subtree, we are left with

Since node "5" has no subtrees, we print it directly. After that, we print its parent node "12" and then its right child "6".

Putting everything on the stack was useful, because now that the left subtree of the root node has been traversed, we can print it out and move on to the right subtree.

After going through all the elements, the centered traversal type (inorder traversal) looks like this:

5 -> 12 -> 6 -> 1 -> 9

We don't need to create the stack ourselves because recursion maintains the correct order for us.

The complete code for centered (inorder), direct (preorder) and reverse (postorder) traversal type in the C programming language is below:

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

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

void inorder(struct node* root){
    if(root == NULL) return;
    inorder(root->left);
    printf("%d ->", root->data);
    inorder(root->right);
}

void preorder(struct node* root){
    if(root == NULL) return;
    printf("%d ->", root->data);
    preorder(root->left);
    preorder(root->right);
}

void postorder(struct node* root) {
    if(root == NULL) return;
    postorder(root->left);
    postorder(root->right);
    printf("%d ->", root->data);
}


struct node* createNode(value){
    struct node* newNode = malloc(sizeof(struct node));
    newNode->data = value;
    newNode->left = NULL;
    newNode->right = NULL;

    return newNode;
}

struct node* insertLeft(struct node *root, int value) {
    root->left = createNode(value);
    return root->left;
} 


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");
    inorder(root);

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

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

The output of the code will look like this:

Inorder traversal                                                                                                                                                         
5 ->12 ->6 ->1 ->9 ->                                                                                                                                                     
Preorder traversal                                                                                                                                                        
1 ->12 ->5 ->6 ->9 ->                                                                                                                                                     
Postorder traversal                                                                                                                                                       
5 ->6 ->12 ->9 ->1 ->
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

Comments

Only authorized users can post comments.
Please, Log in or Sign up
ОК

Qt - Test 001. Signals and slots

  • Result:47points,
  • Rating points-6
A
  • Alena
  • Jan. 19, 2025, 11:41 a.m.

C++ - Test 005. Structures and Classes

  • Result:58points,
  • Rating points-2
OI

C++ - Test 001. The first program and data types

  • Result:40points,
  • Rating points-8
Last comments
ИМ
Игорь МаксимовNov. 22, 2024, 11:51 a.m.
Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii LegotckoiOct. 31, 2024, 2:37 p.m.
Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZEOct. 19, 2024, 8:19 a.m.
Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь МаксимовOct. 5, 2024, 7:51 a.m.
Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas5July 5, 2024, 11:02 a.m.
QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Now discuss on the forum
n
nklyJan. 3, 2025, 2:52 a.m.
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
MarselAug. 16, 2023, 2:26 p.m.
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii LegotckoiJune 24, 2024, 3:11 p.m.
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey1Nov. 15, 2024, 6:04 a.m.
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProjectJune 4, 2022, 3:49 a.m.
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

Follow us in social networks