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

S.l.e!ep.¢%

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

C++樹的實現

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

C++樹的實現 收藏
C++樹的實現
STL里面沒有提供容器樹的模板實現,從網上找到一個:
?
Tree.h
//tree.h 頭文件
?
#include <list>
#include <algorithm>
using namespace std;
?
struct TreeNode; //定義一個結構體原形
classTree;????? //定義一個類原形
classIterator; //定義一個類原形
typedef list<TreeNode*> List; //重命名一個節點鏈表
?
TreeNode* clone(TreeNode*,List&,TreeNode*);//Clone復制函數
?
struct TreeNode{
?? int_data;????????????????? //數據
?? TreeNode* _parent;????????? //父節點
?? List_children;???????????? //子節點
?? TreeNode(int,TreeNode*);??? //構造函數
?? void SetParent(TreeNode&); //設置父節點
?? void InsertChildren(TreeNode&); //插入子節點
};
?
classTree{
public:
?
?//下面是構造器和運算符重載
?? Tree();??????????????????????????? //默認構造函數
?? Tree(constTree&);???????????????? //復制構造函數
?? Tree(constint);?????????????????? //帶參數構造函數
?? Tree(constint,constlist<Tree*>&);//帶參數構造函數
?? ~Tree();?????????????????????????? //析構函數
?? Tree& operator=(constTree&);????? //=符號運算符重載
?? bool operator==(constTree&);????? //==符號運算符重載
?? bool operator!=(constTree&);????? //!=符號運算符重載
?
?? //下面是成員函數
?? void Clear();????????????????????? //清空
?? boolIsEmpty()const;?????????????? //判斷是否為空
?? intSize()const;?????????????????? //計算節點數目
?? intLeaves();????????????????????? //計算葉子數
?? intRoot()const;?????????????????? //返回根元素
?? intHeight();????????????????????? //計算樹的高度
?
?
?? //下面是靜態成員函數
? static boolIsRoot(Iterator);???? //判斷是否是根
?? static boolisLeaf(Iterator);???? //判斷是否是葉子
?? static IteratorParent(Iterator); //返回其父節點
?? static intNumChildren(Iterator); //返回其子節點數目
?
?? //跌代器函數
?? Iteratorbegin();????????????????? //Tree Begin
?? Iteratorend();??????????????????? //Tree End
?? friend classIterator;???????????? //Iterator SubClass
private:
?? list<TreeNode*> _nodes;???????? //節點數組
?? list<TreeNode*>::iteratorLIt; //一個節點迭代器
?? intheight(TreeNode*);
?? intlevel(TreeNode*,Iterator);
};
?
//This is TreeSub Class Iterator
classIterator{
?? private:
??? Tree* _tree;???????????????????? //Tree data
??? list<TreeNode*>::iterator_lit; //List Iterator
?? public:
??? Iterator();?????????????????????????????? //默認構造函數
??? Iterator(constIterator&);??????????????? //復制構造函數
??? Iterator(Tree*,TreeNode*);??????????????? //構造函數
??? Iterator(Tree*,list<TreeNode*>::iterator);//構造函數
??? //運算符重載
??? void operator=(constIterator&);????????? //賦值運算符重載
??? bool operator==(constIterator&);???????? //關系運算符重載
??? bool operator!=(constIterator&);???????? //關系運算符重載
??? Iterator& operator++();?????????????????? //前綴++運算符
??? Iterator operator++(int);???????????????? //后綴++運算符
??? int operator*()const;???????????????????? //獲得節點信息
??? bool operator!();???????????????????????? //賦值運算符重載
??
??? typedef list<TreeNode*>::iteratorList;
??? friend classTree;
};
?
Tree.cpp
//tree.cpp 實現文件
?
#include "Tree.h"
?
//***** 下面是對于TreeNode結構體的定義實現*****///
?
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);
}
?
?
?
//***** 下面是對于Tree類的定義實現*****///
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);//建立根節點
?_nodes.push_back(root);//放入樹中
?list<Tree*>::const_iteratorit;
?for(it = lit.begin();it!=lit.end();it++){
?if(!((*it)->_nodes.empty())){//如果當前節點元素不為空
?? Tree* tp = newTree(**it);
?? TreeNode* p = tp->_nodes.front();
?? root->_children.push_back(p); //設置根的子節點
?? p->_parent = root;??????????? //設置節點的父節點為根
?? 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();
}
?
//***** 下面是對于Tree::Iterator類的定義實現*****///
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函數
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博客,轉載請標明出處: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>
            一本大道久久a久久综合婷婷| 亚洲精品自在在线观看| 欧美一级理论片| 亚洲一品av免费观看| 中文日韩电影网站| 亚洲欧美日韩一区二区在线 | 亚洲自拍啪啪| 亚洲欧美综合另类中字| 欧美一级网站| 美女黄毛**国产精品啪啪| 免费在线亚洲欧美| 亚洲国产欧美久久| 一本一本久久a久久精品综合妖精| 一本色道久久综合狠狠躁篇怎么玩 | 国产精品羞羞答答xxdd| 国产精品一区二区黑丝| 在线播放豆国产99亚洲| 亚洲免费观看高清在线观看| 亚洲一区二区毛片| 久久午夜精品一区二区| 亚洲国产精品日韩| 亚洲一二三区在线| 美女精品视频一区| 国产精品激情| 亚洲国产精品一区二区第四页av| 亚洲视频中文| 麻豆国产va免费精品高清在线| 亚洲精品乱码久久久久久久久| 亚洲欧美电影院| 欧美韩国一区| 伊人婷婷久久| 午夜视频一区在线观看| 亚洲第一在线| 久久婷婷蜜乳一本欲蜜臀| 国产精品成人一区二区艾草| 亚洲欧洲另类国产综合| 久久美女性网| 亚洲综合导航| 欧美视频一区二区三区| 亚洲三级视频在线观看| 久久久国产精彩视频美女艺术照福利 | 亚洲精品国产精品国自产观看| 午夜精品免费在线| 欧美日韩一区不卡| 亚洲精品视频免费观看| 久久婷婷影院| 久久精品视频va| 亚洲一区二区三区三| 欧美激情欧美激情在线五月| 在线看国产一区| 米奇777在线欧美播放| 性欧美办公室18xxxxhd| 国产精自产拍久久久久久蜜| 亚洲特级毛片| 亚洲国产一区在线观看| 欧美大片在线影院| 91久久夜色精品国产九色| 午夜精品久久久久久久99热浪潮| 夜夜爽www精品| 欧美日韩伦理在线| 亚洲天堂av在线免费| 亚洲毛片av在线| 欧美日韩精品免费| 亚洲欧美国产视频| 亚洲午夜精品福利| 国产精品永久| 国产精品久久一卡二卡| 欧美99在线视频观看| 一区二区自拍| 麻豆91精品91久久久的内涵| 久久精品日韩欧美| 狠狠干狠狠久久| 欧美电影免费观看大全| 久久躁狠狠躁夜夜爽| 亚洲国内自拍| 99国产精品99久久久久久| 欧美视频手机在线| 欧美夜福利tv在线| 久久久综合网站| 亚洲人成免费| 一本久道久久综合婷婷鲸鱼| 欧美午夜免费影院| 欧美诱惑福利视频| 麻豆精品精华液| 在线视频亚洲欧美| 亚洲欧美一区二区三区久久| 亚洲成人资源网| 99国产精品视频免费观看| 国产欧美一区二区精品性| 美女国产精品| 欧美视频一区二区| 免费观看国产成人| 欧美三区在线视频| 久久综合狠狠| 欧美日韩在线观看一区二区| 久久久噜久噜久久综合| 欧美大片免费观看| 欧美在线三级| 欧美激情精品久久久久久免费印度 | 亚洲国产日韩一区二区| 亚洲精品偷拍| 国产一二精品视频| 亚洲三级电影在线观看| 国内精品久久久| 亚洲毛片网站| 在线不卡欧美| 亚洲综合色丁香婷婷六月图片| 亚洲大胆人体视频| 亚洲欧美日韩精品久久亚洲区| 91久久久久久久久| 欧美在线视频全部完| 亚洲一卡二卡三卡四卡五卡| 久久免费一区| 久久黄金**| 欧美日韩一区二区三区在线| 欧美激情精品久久久久| 国产毛片精品国产一区二区三区| 亚洲日本va午夜在线电影| 国产香蕉久久精品综合网| 亚洲精选视频免费看| 亚洲人成毛片在线播放女女| 欧美尤物巨大精品爽| 亚洲免费人成在线视频观看| 欧美韩日亚洲| 欧美激情精品久久久久久| 精品粉嫩aⅴ一区二区三区四区| 亚洲淫性视频| 久久野战av| 国产免费成人| 亚洲一区二区三区视频| 亚洲欧洲日韩女同| 亚洲国产精品精华液2区45| 欧美日韩一区二区国产| 久久久久久伊人| 欧美福利视频在线| 性高湖久久久久久久久| 日韩视频第一页| 精东粉嫩av免费一区二区三区| 欧美日在线观看| 久久久99精品免费观看不卡| 欧美日韩在线视频首页| 亚洲国产精品一区二区www| 91久久精品国产91久久性色tv| 久久精品视频亚洲| 久久免费的精品国产v∧| 国产尤物精品| 欧美在线免费观看视频| 久久久亚洲高清| 尹人成人综合网| 欧美a级在线| 亚洲精品免费一区二区三区| 日韩午夜一区| 国产精品久久久久久久久| 亚洲自拍偷拍麻豆| 久久性色av| 亚洲国产精品成人综合| 欧美激情女人20p| 日韩视频免费| 欧美自拍偷拍午夜视频| 尹人成人综合网| 欧美激情欧美狂野欧美精品| 一区二区三区久久精品| 久久疯狂做爰流白浆xx| 国产精品99一区| 欧美在线观看www| 欧美成人精品不卡视频在线观看| 亚洲精品一二三| 国产精品日韩一区二区| 久久九九精品| 99精品热视频只有精品10| 欧美一区二区三区婷婷月色 | 久久久久女教师免费一区| 狠狠色综合网| 欧美国产一区二区| 香港成人在线视频| 欧美二区在线| 午夜精彩视频在线观看不卡| 亚洲第一页在线| 国产精品theporn| 久久综合中文字幕| 亚洲男人第一av网站| 欧美风情在线观看| 久久久国产精品一区| 一区二区免费看| 国内精品久久久久久久影视蜜臀| 国产永久精品大片wwwapp| 欧美a级片一区| 亚洲深夜激情| 在线精品高清中文字幕| 欧美日韩免费高清| 久久久久久香蕉网| 亚洲欧美日韩国产中文| 亚洲精品综合精品自拍| 另类av导航| 久久久精品一品道一区| 一级日韩一区在线观看| 亚洲高清自拍| 国内精品美女av在线播放| 欧美午夜影院| 欧美日一区二区三区在线观看国产免|