青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
簡(jiǎn)單、開放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

C++樹的實(shí)現(xiàn)

Posted on 2010-02-19 13:15 S.l.e!ep.¢% 閱讀(1256) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C++

C++樹的實(shí)現(xiàn) 收藏
C++樹的實(shí)現(xiàn)
STL里面沒有提供容器樹的模板實(shí)現(xiàn),從網(wǎng)上找到一個(gè):
?
Tree.h
//tree.h 頭文件
?
#include <list>
#include <algorithm>
using namespace std;
?
struct TreeNode; //定義一個(gè)結(jié)構(gòu)體原形
classTree;????? //定義一個(gè)類原形
classIterator; //定義一個(gè)類原形
typedef list<TreeNode*> List; //重命名一個(gè)節(jié)點(diǎn)鏈表
?
TreeNode* clone(TreeNode*,List&,TreeNode*);//Clone復(fù)制函數(shù)
?
struct TreeNode{
?? int_data;????????????????? //數(shù)據(jù)
?? TreeNode* _parent;????????? //父節(jié)點(diǎn)
?? List_children;???????????? //子節(jié)點(diǎn)
?? TreeNode(int,TreeNode*);??? //構(gòu)造函數(shù)
?? void SetParent(TreeNode&); //設(shè)置父節(jié)點(diǎn)
?? void InsertChildren(TreeNode&); //插入子節(jié)點(diǎn)
};
?
classTree{
public:
?
?//下面是構(gòu)造器和運(yùn)算符重載
?? Tree();??????????????????????????? //默認(rèn)構(gòu)造函數(shù)
?? Tree(constTree&);???????????????? //復(fù)制構(gòu)造函數(shù)
?? Tree(constint);?????????????????? //帶參數(shù)構(gòu)造函數(shù)
?? Tree(constint,constlist<Tree*>&);//帶參數(shù)構(gòu)造函數(shù)
?? ~Tree();?????????????????????????? //析構(gòu)函數(shù)
?? Tree& operator=(constTree&);????? //=符號(hào)運(yùn)算符重載
?? bool operator==(constTree&);????? //==符號(hào)運(yùn)算符重載
?? bool operator!=(constTree&);????? //!=符號(hào)運(yùn)算符重載
?
?? //下面是成員函數(shù)
?? void Clear();????????????????????? //清空
?? boolIsEmpty()const;?????????????? //判斷是否為空
?? intSize()const;?????????????????? //計(jì)算節(jié)點(diǎn)數(shù)目
?? intLeaves();????????????????????? //計(jì)算葉子數(shù)
?? intRoot()const;?????????????????? //返回根元素
?? intHeight();????????????????????? //計(jì)算樹的高度
?
?
?? //下面是靜態(tài)成員函數(shù)
? static boolIsRoot(Iterator);???? //判斷是否是根
?? static boolisLeaf(Iterator);???? //判斷是否是葉子
?? static IteratorParent(Iterator); //返回其父節(jié)點(diǎn)
?? static intNumChildren(Iterator); //返回其子節(jié)點(diǎn)數(shù)目
?
?? //跌代器函數(shù)
?? Iteratorbegin();????????????????? //Tree Begin
?? Iteratorend();??????????????????? //Tree End
?? friend classIterator;???????????? //Iterator SubClass
private:
?? list<TreeNode*> _nodes;???????? //節(jié)點(diǎn)數(shù)組
?? list<TreeNode*>::iteratorLIt; //一個(gè)節(jié)點(diǎn)迭代器
?? intheight(TreeNode*);
?? intlevel(TreeNode*,Iterator);
};
?
//This is TreeSub Class Iterator
classIterator{
?? private:
??? Tree* _tree;???????????????????? //Tree data
??? list<TreeNode*>::iterator_lit; //List Iterator
?? public:
??? Iterator();?????????????????????????????? //默認(rèn)構(gòu)造函數(shù)
??? Iterator(constIterator&);??????????????? //復(fù)制構(gòu)造函數(shù)
??? Iterator(Tree*,TreeNode*);??????????????? //構(gòu)造函數(shù)
??? Iterator(Tree*,list<TreeNode*>::iterator);//構(gòu)造函數(shù)
??? //運(yùn)算符重載
??? void operator=(constIterator&);????????? //賦值運(yùn)算符重載
??? bool operator==(constIterator&);???????? //關(guān)系運(yùn)算符重載
??? bool operator!=(constIterator&);???????? //關(guān)系運(yùn)算符重載
??? Iterator& operator++();?????????????????? //前綴++運(yùn)算符
??? Iterator operator++(int);???????????????? //后綴++運(yùn)算符
??? int operator*()const;???????????????????? //獲得節(jié)點(diǎn)信息
??? bool operator!();???????????????????????? //賦值運(yùn)算符重載
??
??? typedef list<TreeNode*>::iteratorList;
??? friend classTree;
};
?
Tree.cpp
//tree.cpp 實(shí)現(xiàn)文件
?
#include "Tree.h"
?
//***** 下面是對(duì)于TreeNode結(jié)構(gòu)體的定義實(shí)現(xiàn)*****///
?
TreeNode::TreeNode(inttype= 0,TreeNode* Parent = 0){
?_data = type;
?_parent = Parent;
}
void TreeNode::SetParent(TreeNode& node){
?_parent = &node;
}
void TreeNode::InsertChildren(TreeNode& node){
?TreeNode* p = &node;
?_children.push_back(p);
}
?
?
?
//***** 下面是對(duì)于Tree類的定義實(shí)現(xiàn)*****///
Tree::Tree(){
?
}
?
Tree::Tree(constinttype){
?_nodes.push_back(new TreeNode(type));
}
?
Tree::Tree(constTree& t){
?if(t._nodes.empty())return;
?clone(t._nodes.front(),_nodes,0);
}
Tree::Tree(constinttype,constlist<Tree*>& lit){
?TreeNode* root = new TreeNode(type);//建立根節(jié)點(diǎn)
?_nodes.push_back(root);//放入樹中
?list<Tree*>::const_iteratorit;
?for(it = lit.begin();it!=lit.end();it++){
?if(!((*it)->_nodes.empty())){//如果當(dāng)前節(jié)點(diǎn)元素不為空
?? Tree* tp = newTree(**it);
?? TreeNode* p = tp->_nodes.front();
?? root->_children.push_back(p); //設(shè)置根的子節(jié)點(diǎn)
?? p->_parent = root;??????????? //設(shè)置節(jié)點(diǎn)的父節(jié)點(diǎn)為根
?? list<TreeNode*>::iteratorlit1 = tp->_nodes.begin();
?? list<TreeNode*>::iteratorlit2 = tp->_nodes.end();
?? list<TreeNode*>::iteratorlit3 = _nodes.end();
?? _nodes.insert(lit3,lit1,lit2);
?}
?}
}
?
Tree::~Tree(){
?for(list<TreeNode*>::iteratorit = _nodes.begin();it!=_nodes.end();it++){
?delete* it;
?}
}
?
Tree& Tree::operator =(constTree & t){
?Clear();
?Tree* p = newTree(t);
?_nodes = p->_nodes;
?return *this;
}
?
boolTree::operator ==(constTree& t){
?if(_nodes.size()!=t._nodes.size()){
?return false;
?}
?list<TreeNode*>::iteratorit = _nodes.begin();
?list<TreeNode*>::const_iterator_it = t._nodes.begin();
?while(it!=_nodes.end()&&_it!=t._nodes.end()){
?if((*it)->_data!=(*_it)->_data){
?? return false;
?}
?it++;
?_it++;
?}
?return true;
}
?
boolTree::operator !=(constTree& t){
?if(_nodes.size()!=_nodes.size()){
?return true;
?}
?else{
?list<TreeNode*>::iteratorit = _nodes.begin();
???? list<TreeNode*>::const_iterator_it = t._nodes.begin();
?while(it!=_nodes.end()&&_it!=t._nodes.end()){
?? if((*it)->_data!=(*_it)->_data){
??? return true;
?? }
?? it++;
?? _it++;
?}
?return false;
?}
}
?
void Tree::Clear(){
?for(list<TreeNode*>::iteratorit = _nodes.begin();it!=_nodes.end();it++){
?delete* it;
?}
?_nodes.clear();
}
?
boolTree::IsEmpty()const{
?return _nodes.empty();
}
?
intTree::Size()const{
?return (int)_nodes.size();
}
?
intTree::Leaves(){
?inti = 0;
?list<TreeNode*>::iteratorit = _nodes.begin();
?while(it!=_nodes.end()){
?if((*it)->_children.size()==0){
?? i++;
?}
?it++;
?}
?return i;
}
?
?
intTree::Height(){
?if(_nodes.size()!=0){
?TreeNode* TNode = _nodes.front();
?return height(TNode);
?}
?else{
?return -1; //判斷為空樹
?}
}
?
intTree::height(TreeNode* node){
?if(!node){
?return -1;
?}
?else{
?list<TreeNode*> plist = node->_children;
?if(plist.size()==0){
?? return 0;
?}
?inthA = 0;
?for(list<TreeNode*>::iteratorit = plist.begin();it!=plist.end();it++){
? inthB = height(*it);
?? if(hB>hA){
??? hA = hB;
?? }
?}
?return hA+1;
?}
}
?
?
IteratorTree::begin(){
?return Iterator(this,_nodes.begin());
}
?
IteratorTree::end(){
?return Iterator(this,_nodes.end());
}
intTree::Root()const{
?return (*_nodes.begin())->_data;
}
?
?
boolTree::IsRoot(Iteratorit){
?TreeNode p = *it;
?if(p._parent == 0){
?return true;
?}
?return false;
}
?
boolTree::isLeaf(Iteratorit){
?TreeNode p = *it;
?if(p._children.size() == 0){
?return true;
?}
?return false;
}
?
IteratorTree::Parent(Iteratorit){
?TreeNode p = *it;
?Tree* t = it._tree;
?IteratorIte(t,p._parent);
?return Ite;
}
?
?
intTree::NumChildren(Iteratorit){
?TreeNode p = *it;
?return (int)p._children.size();
}
?
//***** 下面是對(duì)于Tree::Iterator類的定義實(shí)現(xiàn)*****///
Iterator::Iterator(){
}
?
Iterator::Iterator(constIterator& it){
?_tree = it._tree;
?_lit = it._lit;
}
?
Iterator::Iterator(Tree* t, TreeNode* n){
?_tree = t;
?list<TreeNode*>& nodes = _tree->_nodes;
?_lit = find(nodes.begin(),nodes.end(),n);//<algorithm> Members
}
?
Iterator::Iterator(Tree * t, list<TreeNode*>::iteratorlt){
?_tree = t;
?_lit = lt;
}
?
void Iterator::operator =(constIterator& it){
?_tree = it._tree;
?_lit = it._lit;
}
?
boolIterator::operator ==(constIterator & it){
?return _tree == it._tree && _lit == it._lit;
}
?
boolIterator::operator !=(constIterator & it){
?return _tree != it._tree || _lit != it._lit;
}
?
Iterator& Iterator::operator ++(){
?++_lit;
?return *this;
}
?
IteratorIterator::operator ++(int){
?Iteratorit(*this);
?++_lit;
?return it;
}
?
intIterator::operator *() const{
?return ((*_lit)->_data);
}
?
boolIterator::operator !(){
?return _lit == _tree->_nodes.end();
}
?
//Clone函數(shù)
TreeNode* clone(TreeNode* node,List& nodes,TreeNode* nodep){
?TreeNode* cp = new TreeNode(node->_data,nodep);
?nodes.push_back(cp);
?List& l = node->_children;
?List& cl = cp->_children;
?for(list<TreeNode*>::iteratorlt = l.begin();lt!=l.end();lt++){
?cl.push_back(clone(*lt,nodes,cp));
?}
?return cp;
}


本文來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/stephenxu111/archive/2008/05/14/2446382.aspx

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区三区四区精品| 国产精品美女999| 欧美福利在线观看| 亚洲人成久久| 一区二区视频欧美| 亚洲电影激情视频网站| 一区二区三区亚洲| 亚洲国产综合在线| 99国产精品99久久久久久| 99视频在线观看一区三区| 夜夜嗨av一区二区三区网页| 一区二区欧美激情| 亚洲永久在线| 欧美专区日韩视频| 毛片av中文字幕一区二区| 久久影视三级福利片| 欧美激情四色| 一区二区三区四区五区在线| 亚洲欧美高清| 久久综合给合久久狠狠色| 女女同性精品视频| 国产精品草莓在线免费观看| 国产日韩欧美在线播放不卡| 亚洲第一久久影院| 一区二区不卡在线视频 午夜欧美不卡在| 一区二区三区欧美激情| 久久精品天堂| 亚洲日本欧美| 中国成人黄色视屏| 久久久欧美精品| 欧美日韩一区二区精品| 精品9999| 亚洲欧美在线免费| 欧美激情在线狂野欧美精品| 亚洲一区国产一区| 欧美大片免费观看在线观看网站推荐| 国产精品久久久久久模特| 尤物视频一区二区| 亚洲欧美日韩国产成人| 欧美成人四级电影| 亚洲欧美成人一区二区在线电影 | 国产日韩欧美麻豆| 一区二区三区精密机械公司| 玖玖视频精品| 亚洲欧美日本伦理| 欧美日本不卡视频| 亚洲国产一区二区三区在线播 | 99这里有精品| 久久久综合激的五月天| 国产精品资源在线观看| 亚洲精品一区在线观看香蕉| 欧美日韩在线播放一区二区| 伊大人香蕉综合8在线视| 亚洲国产一区二区视频| 久久视频免费观看| 亚洲综合二区| 国产精品久久7| 日韩一级欧洲| 亚洲第一在线| 久久久久一区二区三区| 国内精品久久久久影院 日本资源| 亚洲一区二区三区在线视频| 91久久国产自产拍夜夜嗨| 久久亚洲影院| 亚洲夫妻自拍| 欧美国产日本高清在线| 久久久久久午夜| 激情伊人五月天久久综合| 久久久免费精品| 欧美亚洲一区| 韩日成人av| 免费看精品久久片| 老司机免费视频久久| 亚洲黄一区二区| 亚洲电影免费观看高清完整版| 蜜桃久久精品一区二区| 亚洲精选国产| 日韩亚洲一区二区| 国产精品福利在线观看网址| 亚洲欧美久久久| 午夜精品久久| 在线不卡视频| 91久久精品视频| 欧美日韩在线播| 欧美一区日本一区韩国一区| 欧美在线一区二区| 最新成人在线| 亚洲天堂成人在线观看| 国产日韩欧美在线一区| 亚洲成色777777在线观看影院| 你懂的视频一区二区| 亚洲一区二区动漫| 午夜精品视频在线观看| 在线观看中文字幕不卡| 日韩午夜电影在线观看| 国产一区视频观看| 亚洲第一在线| 国产欧美一区视频| 欧美国产先锋| 国产精品久久久一区二区三区| 久久精品30| 欧美激情网站在线观看| 久久精品国产欧美亚洲人人爽| 你懂的国产精品永久在线| 香蕉久久久久久久av网站| 久久久之久亚州精品露出| 亚洲专区一区| 欧美成人亚洲成人日韩成人| 亚洲欧美日韩系列| 欧美mv日韩mv国产网站| 久久se精品一区二区| 欧美日产一区二区三区在线观看| 久久精品国产亚洲aⅴ| 久久久久久亚洲综合影院红桃 | 在线亚洲精品福利网址导航| 国内成+人亚洲| 亚洲人成网站精品片在线观看| 国产酒店精品激情| 亚洲精品国产精品国自产观看浪潮 | 国产欧美亚洲日本| 亚洲日本中文字幕| 黄色一区二区三区四区| 亚洲视频网在线直播| 日韩视频三区| 久久综合一区二区| 久久久久国产精品一区| 欧美日韩中文在线观看| 欧美国产欧美综合 | 午夜久久福利| 欧美日韩岛国| 欧美激情在线有限公司| 影音先锋欧美精品| 欧美一区二区三区免费视| 亚洲欧美日韩在线不卡| 欧美视频一区二区在线观看| 亚洲激情第一页| 亚洲欧洲一区二区在线观看| 久久午夜电影| 欧美福利在线| 亚洲国产精品高清久久久| 久久久精品一区| 久久免费观看视频| 亚洲成人资源网| 久久亚洲私人国产精品va| 蜜臀av在线播放一区二区三区| 国产日韩精品一区二区三区| 亚洲欧美日本伦理| 久久精品伊人| 国内一区二区在线视频观看 | 亚洲乱亚洲高清| 亚洲剧情一区二区| 欧美激情一区二区三区蜜桃视频| 亚洲国产精品一区制服丝袜| 亚洲狼人精品一区二区三区| 欧美国产日韩二区| 日韩亚洲在线观看| 午夜视频久久久| 国产日韩一区二区| 久久久免费精品| 亚洲乱码日产精品bd| 亚洲免费一在线| 狠色狠色综合久久| 欧美国产高潮xxxx1819| 亚洲精品一区二区网址| 亚洲免费在线看| 狠狠色丁香婷综合久久| 蜜乳av另类精品一区二区| 一区二区免费在线播放| 亚洲国产精品久久久久秋霞影院 | 欧美激情在线| 亚洲婷婷综合色高清在线| 欧美在线观看www| 一区二区在线观看av| 欧美高清日韩| 亚洲砖区区免费| 欧美成人在线影院| 日韩视频二区| 国产欧美午夜| 欧美另类综合| 久久gogo国模裸体人体| 亚洲韩国一区二区三区| 亚洲欧美日韩国产中文| 91久久视频| 国产美女精品人人做人人爽| 老司机午夜免费精品视频| 一区二区三区成人精品| 老色批av在线精品| 亚洲免费影院| 99热这里只有成人精品国产| 国产欧美日韩精品一区| 欧美激情bt| 久久精品国产免费观看| 中文无字幕一区二区三区| 欧美福利一区二区三区| 久久成人av少妇免费| 一区二区三区久久| 精品电影在线观看| 国产精品自拍网站| 欧美日韩国产一级| 久久综合网hezyo|