• 编程之美2: 二进制重建


    称号:

    在队列中,队列给定二进制序列前导,这种二元结构。

    前言:

    a b d c e f

    后序:

    d b a e c f


    使用递归实现例如以下:

    #include<stdio.h>
    #include<iostream>
    
    
    using namespace std;
    
    typedef struct tagNode{
            tagNode* left;
            tagNode* right;
            char value;
    } Node;
    
    void rebuildtree(char* pPreOrder, char* pInOrder, int len, Node** root)
    {
            if(len <= 0) return;
            //1: find root's value and create root Node
            char chroot = *pPreOrder;
            Node* pNode = new Node();
            pNode->left = NULL;
            pNode->right = NULL;
            pNode->value = chroot;
            *root = pNode;
    
            if(len == 1) return;
    
            //2: find root's left child and find right child
            int i = 0;
            while(i < len)
            {
                    if(*(pInOrder + i) == chroot) break;
                    i ++;
            }
    
            if(i == len) return;
    
            //leftchild
            rebuildtree(pPreOrder+1, pInOrder, i, &((*root)->left));
            //rightchild
            rebuildtree(pPreOrder+i+1, pInOrder+i+1, len -i -1, &((*root)->right));
    }
    
    
    void printTree(Node* root)
    {
            if(root == NULL) return;
            printTree(root->left);
            printTree(root->right);
            cout << root->value << ",";
    }
    int main()
    {
            char p1[7] = "abdcef";
            char p2[7] = "dbaecf";
            Node* root = NULL;
            rebuildtree(p1, p2, 6, &root);
            //end print tree
            printTree(root);
    		getchar();
    }



    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    JavaScript-----7.循环
    3. CSS新特性之动画
    JavaScript-----6.流程控制:分支
    JavaScript-----5.运算符
    JavaScript-----4.数据类型
    2. CSS新特性之2D转换transform
    JavaScript-----3.变量
    JavaScript-----2初识
    JavaScript---1.计算机的编程基础
    品优购学习心得
  • 原文地址:https://www.cnblogs.com/yxwkf/p/4677618.html
Copyright © 2020-2023  润新知