我是靠谱客的博主 坚定毛巾,最近开发中收集的这篇文章主要介绍C++数据结构第58课、树形结构的层次遍历,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、问题:如何按层次遍历通用树结构中的每一个数据元素?树是非线性的数据结构,树的结点没有固定的编号方式

2、新的需求:为通用树结构提供新的方法,能快速遍历每一个结点

  • 设计思路(游标):
    1、在树中定义一个游标GTreeNode<T>*
    2、遍历开始前将游标指向根结点 root()
    3、获取游标指向的数据元素
    4、通过结点中的 child 成员移动游标
  • 提供一组遍历相关的函数,按层次访问树中的数据元素
    在这里插入图片描述
    层次遍历算法:
    — 原料:class LinkQueue;
    — 游标:LinkQueue::front();
    — 思想:
    在这里插入图片描述
    在这里插入图片描述

GTreeNode.h

#ifndef GTREENODE_H
#define GTREENODE_H

#include "TreeNode.h"
#include "LinkList.h"

namespace XiebsLib
{

template <typename T>
class GTreeNode : public TreeNode<T>
{
protected:
    bool m_flag;
    GTreeNode(const GTreeNode<T>&);
    GTreeNode<T>* operator = (const GTreeNode<T>&);

    void* operator new(unsigned int size)
    {
        return Object::operator new(size);
    }
public:

    LinkList<GTreeNode<T>*> child;

    GTreeNode()
    {
        m_flag = false;
    }

    bool flag()
    {
        return m_flag;
    }

    static GTreeNode<T>* NewNode()
    {
        GTreeNode<T>* ret = new GTreeNode<T>;
        if(ret != nullptr)
        {
            ret->m_flag = true;
        }
        return ret;
    }
};
}

#endif // GTREENODE_H

GTree.h

protected:
    LinkQueue<GTreeNode<T>*> m_queue;

    GTree(const GTree<T>&);
    GTree* operator=(const GTree<T>&);
public:
    GTree()
    {

    }

    bool begin()
    {
        bool ret = (root() != NULL);

        if( ret )
        {
            m_queue.clear();
            m_queue.add(root());
        }

        return ret;
    }

    bool end()
    {
        return (m_queue.length() == 0);
    }

    bool next()
    {
        bool ret = (m_queue.length() > 0);

        if( ret )
        {
            GTreeNode<T>* node = m_queue.front();

            m_queue.remove();

            for(node->child.move(0); !node->child.end(); node->child.next())
            {
                m_queue.add(node->child.current());
            }
        }

        return ret;
    }

    T current()
    {
        if( !end() )
        {
            return m_queue.front()->value;
        }
        else
        {
            THROW_EXCEPTION(InvalidParameterException, "No value at current position ...");
        }
    }

main.cpp

#include <iostream>
#include "GTree.h"

using namespace std;
using namespace XiebsLib;

int main()
{
    GTree<char> t;
    GTreeNode<char>* node = nullptr;

    t.insert('A', nullptr);
    node = t.find('A');

    t.insert('B', node);
    t.insert('C', node);
    t.insert('D', node);

    node = t.find('B');
    t.insert('E', node);
    t.insert('F', node);

    node = t.find('E');
    t.insert('K', node);
    t.insert('L', node);

    node = t.find('C');
    t.insert('G', node);

    node = t.find('G');
    t.insert('N', node);

    node = t.find('D');
    t.insert('H', node);
    t.insert('I', node);
    t.insert('J', node);

    node = t.find('H');
    t.insert('M', node);

    for(t.begin(); !t.end(); t.next())
    {
        cout << t.current() << endl;
    }
    return 0;
}

在这里插入图片描述

最后

以上就是坚定毛巾为你收集整理的C++数据结构第58课、树形结构的层次遍历的全部内容,希望文章能够帮你解决C++数据结构第58课、树形结构的层次遍历所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部