C++ 中将给定的二叉树转换为双向链表(第 1 组)


在本教程中,我们将讨论一个将二叉树转换为双向链表的程序。

为此,我们将提供一棵二叉树。我们的任务是将其转换为一个双向链表,以便左指针和右指针变为前一个和后一个指针。此外,双向链表的顺序必须等于二叉树的中序遍历。

为此,我们有一个非常直接的方法。我们将按照顺序遍历二叉树,同时制作双向链表的节点,最后将左和右分别设为前一个和后一个节点。

示例

 实时演示

#include <iostream>
using namespace std;
//node structure of binary tree
struct node{
   int data;
   node* left;
   node* right;
};
//traversing and making nodes for
//doubly linked list
void binarytodll(node *root, node **head){
   if (root == NULL)
      return;
   static node* prev = NULL;
   //converting left subtree
   binarytodll(root->left, head);
   if (prev == NULL)
      *head = root;
   else {
      root->left = prev;
      prev->right = root;
   }
   prev = root;
   //converting right subtree
   binarytodll(root->right, head);
}
//allocating a new node
node* newNode(int data) {
   node* new_node = new node;
   new_node->data = data;
   new_node->left = new_node->right = NULL;
   return (new_node);
}
//printing nodes of doubly linked list
void print_dll(node *node){
   while (node!=NULL) {
      cout << node->data << " ";
      node = node->right;
   }
}
int main(){
   node *root = newNode(10);
   root->left = newNode(12);
   root->right = newNode(15);
   root->left->left = newNode(25);
   root->left->right = newNode(30);
   root->right->left = newNode(36);
   node *head = NULL;
   binarytodll(root, &head);
   print_dll(head);
   return 0;
}

输出

25 12 30 10 36 15

更新时间:2020 年 1 月 6 日

154 次浏览

开启您的 事业

完成课程获得认证

开始
广告