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

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>
            玖玖玖免费嫩草在线影院一区| 欧美激情中文字幕一区二区 | 伊人久久久大香线蕉综合直播| av成人黄色| 中文在线资源观看视频网站免费不卡| 欧美综合国产精品久久丁香| 久久久久久综合| 亚洲毛片在线观看| 亚洲图片欧洲图片av| 午夜免费在线观看精品视频| 欧美激情一区二区| 欧美一区二区免费视频| 性18欧美另类| 好看的日韩av电影| 久久免费视频一区| 亚洲精品1区2区| 欧美午夜性色大片在线观看| 一区二区三区 在线观看视| 亚洲一区二区在| 99视频在线精品国自产拍免费观看| 欧美精品久久久久久久久久| 国产精品区一区二区三区| 欧美一级视频精品观看| 久久gogo国模裸体人体| 欧美一区二区三区视频在线观看| 99综合视频| 国产在线高清精品| 国产精品日日摸夜夜添夜夜av| 亚洲国产天堂久久国产91| 中文av一区特黄| 亚洲午夜国产一区99re久久| 中文在线资源观看网站视频免费不卡 | 日韩视频在线你懂得| 美女精品在线| 最新成人在线| 另类国产ts人妖高潮视频| 伊人精品成人久久综合软件| 激情成人在线视频| 国产九九精品| 亚洲电影专区| 亚洲第一综合天堂另类专| 亚洲片在线资源| 午夜精品亚洲一区二区三区嫩草| 亚洲高清不卡| 玖玖玖国产精品| 欧美成人高清| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲成色777777女色窝| 可以看av的网站久久看| 亚洲人成在线观看| 欧美刺激性大交免费视频| 欧美精品在线看| 激情久久综艺| 在线视频一区二区| 免费在线亚洲| 亚洲免费福利视频| 午夜精品一区二区三区四区 | 欧美国产视频一区二区| 亚洲欧洲日产国产网站| 亚洲精选在线观看| 亚洲欧美另类中文字幕| 亚洲第一成人在线| av不卡在线看| 开心色5月久久精品| 国内揄拍国内精品少妇国语| 亚洲精品永久免费| 亚洲男人天堂2024| 亚洲国产成人午夜在线一区| 欧美一区二区三区在线免费观看 | 午夜精品久久久久久久99黑人| 中文在线不卡| 欧美激情成人在线视频| 久久精品欧美| 欧美国产精品人人做人人爱| 激情久久中文字幕| 久久国内精品视频| 午夜精品久久久久久久99热浪潮| 国产美女精品视频免费观看| 欧美电影资源| 久久精品一区二区三区中文字幕| 欧美高清免费| 国产三区精品| 亚洲深夜福利| 黄色成人小视频| 亚洲午夜精品视频| 国产欧美短视频| 亚洲视频在线观看一区| 国内精品久久久久影院优| 欧美激情国产日韩精品一区18| 国产精品久线观看视频| 午夜日韩福利| 欧美日韩免费观看一区| 午夜精品一区二区三区在线| 久久夜色精品国产| 欧美激情第五页| 亚洲精品字幕| 一本在线高清不卡dvd| 国产有码在线一区二区视频| 久久久国产精品一区二区中文| 欧美国产欧美综合| 亚洲自拍偷拍一区| 欧美国产日韩一区二区| 欧美黄色免费| 国产精品久久久久影院色老大 | 亚洲欧美日本日韩| 久久久一区二区| 久久夜色精品| 国内精品久久久久伊人av| 亚洲视频视频在线| 亚洲欧美综合一区| 国产欧美精品日韩| 午夜激情一区| 欧美国产亚洲精品久久久8v| 欧美视频中文字幕| 国产精品影音先锋| 亚洲日韩视频| 久久男人av资源网站| 亚洲第一福利视频| 久久国产主播| 亚洲欧洲在线免费| 亚洲欧美日韩国产另类专区| 黄色日韩网站| 卡一卡二国产精品| 99精品国产在热久久下载| 欧美一区二区三区视频在线观看 | 午夜精品久久久久| 免费人成精品欧美精品| 亚洲影院免费观看| 亚洲欧美激情精品一区二区| 国产日韩成人精品| 亚洲欧美激情诱惑| 美女日韩在线中文字幕| 久久精品国产亚洲一区二区| 亚洲欧美激情视频| 99在线精品视频在线观看| 欧美日韩网站| 久久久久久亚洲综合影院红桃| 日韩视频在线一区二区| 欧美激情视频一区二区三区不卡| 久久青草福利网站| 亚洲欧美国产日韩天堂区| 亚洲综合视频一区| 日韩视频永久免费| 亚洲网站视频| 日韩一级成人av| 99视频一区| avtt综合网| 亚洲裸体俱乐部裸体舞表演av| 亚洲日本激情| 亚洲一区网站| 久久成人免费日本黄色| 亚洲电影免费观看高清完整版在线观看 | 黄色国产精品一区二区三区| 欧美日韩中文另类| 国产精品视频不卡| 老司机午夜精品视频| 六月丁香综合| 欧美日韩一二三四五区| 欧美日韩国产色站一区二区三区| 欧美va天堂| 国产欧美日韩在线播放| 欧美日韩国产在线看| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲一级在线观看| 欧美大片在线观看一区二区| 最新国产拍偷乱拍精品| 欧美亚洲一区| 国产精品海角社区在线观看| 尤物yw午夜国产精品视频| 亚洲欧美日韩一区二区三区在线| 麻豆九一精品爱看视频在线观看免费| 亚洲女ⅴideoshd黑人| 欧美日韩视频在线一区二区| 国内久久精品视频| 中文在线资源观看网站视频免费不卡 | 欧美一区二区三区日韩| 欧美另类专区| 国产日韩欧美91| 亚洲一区二区在线观看视频| 亚洲欧美成人| 日韩网站免费观看| 欧美日韩视频一区二区| 亚洲视频免费| 另类尿喷潮videofree| 国产精品一区免费观看| 亚洲区在线播放| 亚洲丝袜av一区| 国产精品视频网址| 一区二区三区精密机械公司| 性欧美1819性猛交| 一本大道av伊人久久综合| 国产精品99久久不卡二区| 国产精品一区免费观看| 久久久久久久久久久久久女国产乱| 欧美h视频在线| 欧美一区二区三区久久精品| 美女精品在线| 麻豆91精品| 欧美视频在线看| 狂野欧美一区|