树结构的遍历

#include <stdafx.h>
#include <vector>
#include <queue>
#include <string>
#include <assert.h>

using namespace std;
class CNode
{
public:
	CNode(CNode *pNode, const char *pStr)
	{
		m_pParent = pNode;
		m_strName = pStr;
		if ( m_pParent!=NULL)
			m_pParent->AddChild(this);
	}

	virtual ~CNode()
	{
		for (int i=0; i<m_vChildren.size(); i++)
		{
			CNode *pNode = m_vChildren[i];
			delete pNode;
		}
		m_vChildren.clear();
	}

	size_t GetChildCount() const
	{
		return m_vChildren.size();
	}

	CNode *GetChild(size_t index) const
	{
		assert(index >=0 && index <m_vChildren.size());
		return m_vChildren[index];
	}

	void RemoveChild(size_t index)
	{
		assert(index>0 && index<m_vChildren.size());
		delete m_vChildren[index];
		m_vChildren.erase(m_vChildren.begin()+index);
	}

	CNode * DetachChild(size_t index)
	{
		assert(index >=0 && index<m_vChildren.size());
		CNode* pChild = m_vChildren[index];
		m_vChildren.erase(m_vChildren.begin()+index);
		pChild->SetParent(NULL);
		return pChild;
	}

	size_t AddChild(CNode *pNode)
	{
		m_vChildren.push_back(pNode);
		pNode->SetParent(this);
		return m_vChildren.size()-1;
	}

	const char* GetName() const
	{
		return m_strName.c_str();
	}

	void SetName(const char *pName)
	{
		m_strName = pName;
	}

	void SetParent(CNode * pNode)
	{
		m_pParent = pNode;
	}

public:
	void RecursiveTraversal_Pre()
	{
		printf("%s\t", GetName());
		for (int i=0; i<m_vChildren.size(); i++)
		{
			m_vChildren[i]->RecursiveTraversal_Pre();
		}
	}

	void RecursiveTraversal_Next()
	{
		for (int i=0; i<m_vChildren.size(); i++)
		{
			CNode *pChild = m_vChildren.at(i);
			pChild->RecursiveTraversal_Next();
		}
		printf("%s\t", GetName());
	}

	void RecursiveTraversal_Layer()
	{
		queue<CNode*> q;
		q.push(this);

		while ( !q.empty())
		{
			CNode * pNode = q.front();
			printf("%s\n", pNode->GetName());

			for ( size_t t=0; t<pNode->GetChildCount(); t++)
			{
				q.push(pNode->GetChild(t));
			}
			q.pop();
		}
	}
private:
	vector<CNode*> m_vChildren;
	CNode *m_pParent;
	string m_strName;	
};


int main()
{
	CNode* root =  new CNode(NULL,"root");
	CNode* node1 = new CNode(root,"node_1");
	CNode* node2 = new CNode(root,"node_2");
	CNode* node3 = new CNode(root,"node_3");

	CNode* node4 = new CNode(node1,"node_4");
	CNode* node5 = new CNode(node1,"node_5");

	CNode* node6 = new CNode(node2,"node_6");

	CNode* node7 = new CNode(node3,"node_7");
	CNode* node8 = new CNode(node3,"node_8");

	printf("后序遍历: \n");
	root->RecursiveTraversal_Next();

	printf("先序遍历: \n");
	root->RecursiveTraversal_Pre();

	printf("逐层打印\n");
	root->RecursiveTraversal_Layer();

	delete root;
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值