Skip to main content

Program to convert Binary tree to Doubly linked list

The order of Doubly linked list will be same as the inorder of the Binary tree.So the first node of DLL will be the leftmost node of Binary tree.Let us assume that the given Binary tree is



Now the order of the Doubly linked list will be 31 23 36 15 42 34.

Algorithm :

The algorithm of this program is pretty simple.We will first find the inorder of the left subtree and convert into DLL.Then we again find the inorder of right subtree and convert into DLL.Then finally we join both DLL to the root node of the tree.

1) Recursively convert left subtree to DLL
2) Now find the inorder predecessor of root node. Inorder predecessor is the right most node of left subtree.Let take it as IP node.
3) Now nake root node as next of IP node and IP node as previous of root node.
4) Recursively convert Right subtree to DLL
5) Now find the inorder successor of root node.The inorder successor of root node is the left node of right subtree.Let take it as IS node.
6) Now make IS node next of root node and root node as previous of IS node.
7) Find the left most node and return it ie the head of DLL.

Program :

#include<stdio.h>
#include<conio.h>
struct node
{
int data;
node *left;
node *right;
}

node* newNode(int data)
{
    node* newnode = new node;
    newnode->data = data;
    newnode->left = newnode->right = NULL;
    return (newnode);
}

node* bintree2DLL(node* root)
{
   
    if (root == NULL)
        return root;

    if (root->left != NULL)
    {
       
        node* left = bintree2DLL(root->left);           // Convert the left subtree

       
        while(left->right!=NULL)
           left=left->right                                         // Find inorder predecessor
                                                       

        left->right = root;                                      // Make root as next of the predecessor

       
        root->left = left;                                       // Make predecessor as previous of root
    }

   
    if (root->right!=NULL)
    {
       
        node* right = bintree2DLL(root->right);     // Convert the right subtree

       
        while(right->left!=NULL)                           // Find inorder successor
              right = right->left
       
        right->left = root;                                       // Make root as previous of successor

       
        root->right = right;                                    // Make successor as next of root
    }

    return root;
}


int main()
{

 node *root        = newNode(15);
    root->left        = newNode(23);
    root->right       = newNode(34);
    root->left->left  = newNode(31);
    root->left->right = newNode(36);
    root->right->left = newNode(42);
  node  *r= bintree2DLL(root);
 while(r->left!=NULL)
{
r=r->left;
}
while(r!=NULL)
{
printf("%d",r->data)
r=r->right;
}
    getch();

}

Comments

Popular posts from this blog

Tricky Questions or Puzzles in C ( Updated for 2026)

Updated for 2026 This article was originally written when C/C++ puzzles were commonly asked in interviews. While such language-specific puzzles are less frequent today, the problem-solving and logical reasoning skills tested here remain highly relevant for modern Software Engineering, Data Engineering, SQL, and system design interviews . Why These Puzzles Still Matter in 2026 Although most Software &   Data Engineering interviews today focus on Programming, SQL, data pipelines, cloud platforms, and system design , interviewers still care deeply about how you think . These puzzles test: Logical reasoning Edge-case handling Understanding of execution flow Ability to reason under pressure The language may change , but the thinking patterns do not . How These Skills Apply to Data Engineering Interviews The same skills tested by C/C++ puzzles appear in modern interviews as: SQL edge cases and NULL handling Data pipeline failure scenarios Incremental vs ...

Program to uncompress a string ie a2b3c4 to aabbbcccc

Below is the program to uncompress a string #include<stdio.h> #include<conio.h> #include<stdlib.h> int main() { char str[100]="a2b3c4d8u7"; for(int i=0;str[i]!='\0';i++) { if(i%2!=0) { for(int j=0;j<atoi(&str[i]);j++) { printf("%c",str[i-1]); } } } getch(); } Want to become a Data Engineer? Check out below blog posts  1.  5 Key Skills Every Data Engineer needs in 2023 2.  How to prepare for Data Engineering Interviews 3.  Top 25 Data Engineer Questions

Programs and Puzzles in technical interviews i faced

I have attended interview of nearly 10 companies in my campus placements and sharing their experiences with you,though i did not got selected in any of the companies but i had great experience facing their interviews and it might help you as well in preparation of interviews.Here are some of the puzzles and programs asked to me in interview in some of the good companies. 1) SAP Labs I attended sap lab online test in my college through campus placements.It had 3 sections,the first one is usual aptitude questions which i would say were little tricky to solve.The second section was Programming test in which you were provided snippet of code and you have to complete the code (See Tricky Code Snippets  ).The code are from different data structures like Binary Tree, AVL Tree etc.Then the third section had questions from Database,OS and Networks.After 2-3 hours we got the result and i was shortlisted for the nest round of interviews scheduled next day.Then the next day we had PPT of t...