zoukankan      html  css  js  c++  java
  • 数据结构--树

    /*******************************************************************
    Copyright(c) 2016, Harry He
    All rights reserved.
    Distributed under the BSD license.
    (See accompanying file LICENSE.txt at
    https://github.com/zhedahht/CodingInterviewChinese2/blob/master/LICENSE.txt)
    *******************************************************************/
    
    //==================================================================
    // 《剑指Offer——名企面试官精讲典型编程题》代码
    // 作者:何海涛
    //==================================================================
    
    #pragma once
    
    #include <vector>
    
    struct TreeNode 
    {
        int                       m_nValue;    
        std::vector<TreeNode*>    m_vChildren;    
    };
    
    __declspec( dllexport ) TreeNode* CreateTreeNode(int value);
    __declspec( dllexport ) void ConnectTreeNodes(TreeNode* pParent, TreeNode* pChild);
    __declspec( dllexport ) void PrintTreeNode(const TreeNode* pNode);
    __declspec( dllexport ) void PrintTree(const TreeNode* pRoot);
    __declspec( dllexport ) void DestroyTree(TreeNode* pRoot);
    /*******************************************************************
    Copyright(c) 2016, Harry He
    All rights reserved.
    Distributed under the BSD license.
    (See accompanying file LICENSE.txt at
    https://github.com/zhedahht/CodingInterviewChinese2/blob/master/LICENSE.txt)
    *******************************************************************/
    
    //==================================================================
    // 《剑指Offer——名企面试官精讲典型编程题》代码
    // 作者:何海涛
    //==================================================================
    
    #include "Tree.h"
    
    TreeNode* CreateTreeNode(int value)
    {
        TreeNode* pNode = new TreeNode();
        pNode->m_nValue = value;
    
        return pNode;
    }
    
    void ConnectTreeNodes(TreeNode* pParent, TreeNode* pChild)
    {
        if(pParent != nullptr)
        {
            pParent->m_vChildren.push_back(pChild);
        }
    }
    
    void PrintTreeNode(const TreeNode* pNode)
    {
        if(pNode != nullptr)
        {
            printf("value of this node is: %d.
    ", pNode->m_nValue);
    
            printf("its children is as the following:
    ");
            std::vector<TreeNode*>::const_iterator i = pNode->m_vChildren.begin();
            while(i < pNode->m_vChildren.end())
            {
                if(*i != nullptr)
                    printf("%d	", (*i)->m_nValue);
            }
    
            printf("
    ");
        }
        else
        {
            printf("this node is nullptr.
    ");
        }
    
        printf("
    ");
    }
    
    void PrintTree(const TreeNode* pRoot)
    {
        PrintTreeNode(pRoot);
    
        if(pRoot != nullptr)
        {
            std::vector<TreeNode*>::const_iterator i = pRoot->m_vChildren.begin();
            while(i < pRoot->m_vChildren.end())
            {
                PrintTree(*i);
                ++i;
            }
        }
    }
    
    void DestroyTree(TreeNode* pRoot)
    {
        if(pRoot != nullptr)
        {
            std::vector<TreeNode*>::iterator i = pRoot->m_vChildren.begin();
            while(i < pRoot->m_vChildren.end())
            {
                DestroyTree(*i);
                ++i;
            }
    
            delete pRoot;
        }
    }
  • 相关阅读:
    10.14 正睿做题笔记
    斯坦纳树
    django+uwsgi+nginx 前后端分离部署配置
    pandas 取 groupby 后每个分组的前 N 行
    使用 Java SDK 获取 MaxCompute 的表结构并写入到 Excel 中
    PPYOLO模型参数配置理解
    分子表面计算库MSMS的linux安装教程
    使用Python的seaborn画热力图heatmap以及将两个矩阵合并画热图的方法
    常见图片格式分析-bmp,png
    BUUOJ-Misc刷题笔记
  • 原文地址:https://www.cnblogs.com/music-liang/p/12610811.html
Copyright © 2011-2022 走看看