概述
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课、树形结构的层次遍历所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复