笔试题:用二叉树构造双向链表

#include <iostream>
#include <string.h>
using namespace std;
struct Node
{
    Node *left;//相当于双向链表的prev指针。
    Node *right;//相当于双向链表的next指针。
    char data;
    Node(char d = char()):data(d),left(NULL),right(NULL){}
};

class MTree
{
    public:
    MTree():root(NULL){}
    void Create_Tree(char *VLR,char *LVR)
    {
        int n = strlen(LVR);
        Create_Tree(root,VLR,LVR,n);    
    }
    void Create_Tree(Node *&t,char *VLR,char *LVR,int n)
    {
        //构造二叉树。
        if(n==0)return ;
        int i = 0;
        while(VLR[0]!=LVR[i])i++;
        t = new Node(VLR[0]);
        Create_Tree(t->left,VLR+1,LVR,i);
        Create_Tree(t->right,VLR+i+1,LVR+i+1,n-i-1);    
    }   
    void Create_DList(MTree &mt)
    {
        Node *pr = NULL;
        Create_DList(root,pr,mt.root);
    }
    static void Printf(MTree &mt)
    {//双向链表打印。
       Node *p = mt.root;
       while(p!=NULL)
        {
          cout<<p->data<<" ";
          p=p->right;
                }
    }
    private:
    void Create_DList(Node *t,Node *&pr,Node *&mt)
    {
        //构造双向链表。
      if(t==NULL)
            {
        return ;
        }   
        Create_DList(t->left,pr,mt);
        if(t!=NULL)
         {
        t->left=pr;
        if(pr)
        pr->right = t;
        if(pr==NULL)mt=t;
         }
        if(pr!=NULL && pr->right==NULL)
         {
               pr->right=t;
           t->left = pr;
             }
         pr = t;
         Create_DList(t->right,pr,mt);
    }

    private:
    Node *root;
};
int main()
{
    char VLR[]="ABCDEFG";
    char LVR[]="CBDAFEG";

    MTree mt;
    mt.Create_Tree(VLR,LVR);
    MTree mtlist;
    mt.Create_DList(mtlist);
    MTree :: Printf(mtlist);
    return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值