Skip to main content

Construct Binary Tree from preorder and inorder | Data Structure

Introduction:
In this tutorial we are going to see how we can construct the binary tree from given preorder and inorder.

Prerequisites: you should know about binary tree traversal and on paper you can draw binary tree from given preorder and inorder traversal.

Inorder:left->root->right;
Preorder:root->left->right;

Problem Statement:
we have given two arrays. one for preorder and another for inorder. by using these two array we have to built a binary tree.

eg:
preorder = [3,9,20,15,7]
inorder = [9,3,15,20,7]

solution:
Solution:
We will follow recursive approach to solve this question.let's discuss how we can
solve it.

Trick: In the given preorder the very first element will be the root of the tree.
then we will find root element in inorder also. and we know in inorder
traversal we have left part then root and then right part of the tree. by using
preorder we can get the root of the main tree and by using inorder and root we can
get the left part and right part of the tree.

So basically everytime we will get the root from preorder array and left and right part of the
 root from inorder array.

As now we have left part and right part of tree, we will do same thing on left part.
and then on right part.

Basically what i want to say is, in first iteration we will get the root of the tree
as well as left and right part of the tree. in second iteration we will get the root
of left part of the tree
as well as left and right part of the left part of the main
tree and so on. and same thing we will follow with the right part of the main tree.

Full Code:

/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* buildTreeHelper(vector<int>preorder,vector<int>inorder,int inS,int inE,int preS,int preE){
if(inS > inE){
return NULL;
}
int rootdata=preorder[preS];
int rootindex=-1;
for(int i=inS;i<=inE;i++){
if(inorder[i]==rootdata){
rootindex=i;
break;
}
}
int lIns=inS;
int lIne=rootindex-1;
int lPres=preS+1;
int lPree=lIne-lIns+lPres;
int rIns=rootindex+1;
int rIne=inE;
int rPres=lPree+1;
int rPree=preE;

TreeNode *root= new TreeNode(rootdata);
root->left=buildTreeHelper(preorder,inorder,lIns,lIne,lPres,lPree);
root->right=buildTreeHelper(preorder,inorder,rIns,rIne,rPres,rPree);
return root;
}
TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
int m=preorder.size();
int n=inorder.size();
return buildTreeHelper(preorder,inorder,0,n-1,0,m-1);
}
};

Conclusion:
We are maintaining eight variables which will keep track of both array. and in each
recursive call we are basically updating these eight variables. first we are building
left part of the tree then right part of the tree.

This problem is from leetcode and this is a very popular interview problem.
https://leetcode.com/problems/construct-binary-tree-from-preorder-and-inorder-traversal/

Comments

Popular posts from this blog

Disjiont Set Union-Find Data Structure | Code In C++

 Introduction:  In this tutorial we are going to write full program of disjoint set union find advance data structure in c++.  Problem Description: Disjoint Set Union (DSU) is an advance data structure, which basically uses in graph algorithms to find cycles. Codes:  Method1: Brute Force #include<bits/stdc++.h> using namespace std; int find(int f,vector<int>&dsuf){     if(dsuf[f]==-1)         return f;     return find(dsuf[f],dsuf); } void union_op(int from, int to, vector<int>& dsuf){     dsuf[from]=to; } bool isCycle(vector<pair<int,int> >&edge_list, vector<int>&dsuf){     for(int i=0;i<edge_list.size();i++){         int parent1=find(edge_list[i].first,dsuf);         int parent2=find(edge_list[i].second,dsuf);         if(parent1==pare...

Target Sum | Backtracking Problem

Introduction: In this tutorial we are going to solve a problem "Target Sum" which is from leetcode. and believe me it's really a good problem to understand Backtracking(Recursion). and if you try to understand the problem as well as code you will get a clear picture of Backtracking. Problem Statement: Link To Problem You are given a list of non-negative integers, a1, a2, ..., an, and a target, S. Now you have 2 symbols + and - . For each integer, you should choose one from + and - as its new symbol. Find out how many ways to assign symbols to make sum of integers equal to target S. Input: nums is [1, 1, 1, 1, 1], S is 3. Output: 5 Explanation: -1+1+1+1+1 = 3 +1-1+1+1+1 = 3 +1+1-1+1+1 = 3 +1+1+1-1+1 = 3 +1+1+1+1-1 = 3 There are 5 ways to assign symbols to make the sum of nums be target 3. Solution: As given in question, we have two operation + and -. so we will make recursive call for + and - . and if we have sum as target and we have reached upto the last ind...

Group Anagrams solution with explanation:Leetcode solution

what is Anagrams? suppose we have two strings and the characters present in both of the strings are same. then both will be called anagram of each other. eg:" rat" and "art" both are anagram of each other. the characters present in both string are same. eg: "raat" and "art" these are not anagrams of each other. and the reason is that the frequency of "a" in "raat" is 2. while the frequency of "a" in "art" is 1. so these are not anagrams of each other. in short two strings will be anagram of each other if they have same characters and the count(frequency) of each and every character must be same in both strings. Solution: There are different ways to solve this question, so here we are going to use Hashmap to solve this question. cause whenever there is need to search we should go with the data structure which use balanced binary tress or hashing. and we know that Hashmap  uses balanced binary trees. so using...