亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? bitree.h

?? 數據結構實例 可以學一下。。
?? H
字號:
#pragma once
#include "mylib.h"

namespace mylib {
	template<typename elemtype> class bitnode {
	public:
		typedef elemtype value_type;
		bitnode(void);                              //構造函數
		bitnode(const bitnode<elemtype>&);          //拷貝構造函數
		const elemtype date(void) const;            //讀取數據
		const bitnode<elemtype>* lchild(void) const;//返回左指針
		const bitnode<elemtype>* rchild(void) const;//返回右指針
		void get_date(const elemtype);              //輸入數據
		void get_lchild (const bitnode<elemtype>*); //輸入左指針
		void get_rchild (const bitnode<elemtype>*); //輸入右指針
		const bitnode<elemtype>&
			operator= ( const bitnode<elemtype>& );  //賦值,只聲明
	private:
		elemtype          _date;                    //節點數據
		bitnode<elemtype> *_lchild, *_rchild;       //左右孩子指針
	};//二叉樹的節點

	//bitnode類函數實現
	template<typename elemtype>
		bitnode<elemtype>::bitnode()
	{ 
       get_date( 0 );
       get_rchild( 0 );
       get_lchild( 0 );
    }
	
	template<typename elemtype >const
		bitnode<elemtype>* bitnode<elemtype>::lchild() const 
    { 
       return _lchild; 
    }

	template<typename elemtype> const 
		bitnode<elemtype>* bitnode<elemtype>::rchild() const
    { 
       return _rchild;
    }

	template<typename elemtype> const
		elemtype bitnode<elemtype>::date () const
    { 
       return _date;
    }

	template<typename elemtype>
		void bitnode<elemtype>::get_date(const elemtype de) 

    { 
       _date = de;
    }

	template<typename elemtype> 
		void bitnode<elemtype>::
		get_lchild(const bitnode<elemtype>* pev) 
    {
       _lchild = (bitnode<elemtype>*) pev;
    }

	template<typename elemtype>
		void bitnode<elemtype>::
		get_rchild (const bitnode<elemtype>* pev) 
    {
       _rchild = (bitnode<elemtype>*) pev; 
    }

	//tree類
	template<typename elemtype> class BiTree{
	public:
		typedef elemtype value_type;

		BiTree(void);                             //構造函數
		BiTree(const BiTree<elemtype>&);
		const bitnode<elemtype>* 
			copy(const bitnode<elemtype>*);
		void print(void) const;                  //打印樹中數據  
		bool empty(void) const;            //測試樹是否為空
		const int node(void) const;              //返回節點個數
		const BiTree<elemtype>&
			operator= (const BiTree<elemtype>&); //賦值
	
	private:
		size_t             node_nu;               //節點個數
		bitnode<elemtype> *pv;                    //根指針
		void add_node(void);                      //增加節點
		const bitnode<elemtype>* init(void);      //初始化
		void fvisit(const bitnode<elemtype>*) const;//先序遍歷
		void mvisit(const bitnode<elemtype>*) const;//中序遍歷
		void hvisit(const bitnode<elemtype>*) const;//后序遍歷
	};

	//二叉樹類代碼實現
	//公有函數集合
	template<typename elemtype>
		BiTree<elemtype>::BiTree()
    {
       pv = NULL;
       node_nu = 0;
       pv = ( bitnode* ) init();
    }

	template<typename elemtype> BiTree<elemtype>::
		BiTree(const BiTree<elemtype>& tree)
   {
       if(tree.empty())
       pv = (bitnode<elemtype>*) copy(tree.pv);
   }   

   template<typename elemtype>
	   void BiTree<elemtype>::print() const
    {
       cout << "請選擇打印順序:先序[x]?中序[z]?后序[h]?:";
       char ch;
       cin >> ch;
       if ( empty() != 0 )
	   {
           switch ( ch ) 
           {
              case 'x':  fvisit( pv ); break; 
              case 'z':  mvisit( pv ); break; 
              case 'h':  hvisit( pv ); break; 
              default: cerr << "錯誤操作。無法輸出!" << endl;
           }
       }
       else 
           cerr << "樹為空" << endl;
    }

	template<typename elemtype> 
		bool BiTree<elemtype>::empty() const
    {
       if(node_nu == 0)
           return false;
       else 
           return true;
    }

	template<typename elemtype> const
		int BiTree<elemtype>::node() const
    {
       return node_nu;
    }

	template<typename elemtype> const 
		bitnode<elemtype>* BiTree<elemtype>::
		copy(const bitnode<elemtype>* ptr)
    {
       bitnode<elemtype> *pev;
       if(ptr == 0)
           return 0;
       if (ptr->date() == 0)
           pev = 0;
       else
	   {
           if ( !(pev = new bitnode<elemtype>) )
              return 0 ;

           add_node();
           pev->get_date(ptr->date());
           pev->get_lchild( copy(ptr->lchild()) );
           pev->get_rchild( copy(ptr->rchild()) ); 

       }
       return pev;
    }

	template<typename elemtype> 
		const BiTree<elemtype>& BiTree<elemtype>::
		operator =( const BiTree<elemtype>& tree )
	{
		if(this != &tree)
		{
			if( tree.empty() )
				pv = copy( tree.pv );
		}
		return *this;
	}

	//私有函數集合

	template<typename elemtype> const 
		bitnode<elemtype>* BiTree<elemtype>::init()
    {
       bitnode<elemtype> *pev;
       elemtype de;
       cout << "請輸入第"
            << node() + 1
            << "個數據:";
       cin >> de;
       if ( de == 0 )
           pev = NULL;
       else
	   {
           if ( !( pev = new bitnode<elemtype> ) )
              return 0 ;

           add_node();
           pev->get_date( de );
           pev->get_lchild( init() );
           pev->get_rchild( init() );      
       }

       return pev;
    }

	template<typename elemtype>
		void BiTree<elemtype>::add_node() 
    { 
       ++node_nu;
    }

	template<typename elemtype>
		void BiTree<elemtype>::
		fvisit(const bitnode<elemtype> *pev) const
   {
       if ( pev != NULL ) 
           cout << pev->date() << endl;    
       if ( pev->lchild() != NULL )
           fvisit( pev->lchild() );
       if ( pev->rchild() != NULL )
           fvisit( pev->rchild() );
    }

   template<typename elemtype>
	   void BiTree<elemtype>::
	   mvisit(const bitnode<elemtype> *pev) const
    {
       if ( pev->lchild() != NULL )
           mvisit( pev->lchild() );
       if ( pev != NULL ) 
           cout << pev->date() << endl;
       if ( pev->rchild() != NULL )
           mvisit( pev->rchild() );
    }

	template<typename elemtype>
		void BiTree<elemtype>::
		hvisit(const bitnode<elemtype> *pev) const
    {
       if (pev->lchild() != NULL)
           hvisit( pev->lchild() );
       if (pev->rchild() != NULL)
           hvisit( pev->rchild() );
       if (pev != NULL) 
          cout << pev->date() << endl;
    }

};  

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品嫩草影院com| 色综合久久久久综合99| 日韩三级视频在线看| 亚洲成人动漫一区| 欧美日韩视频一区二区| 亚洲电影中文字幕在线观看| 欧美性猛片xxxx免费看久爱| 亚洲精品v日韩精品| 欧美亚洲综合色| 日日夜夜免费精品| 日韩免费高清av| 国产激情91久久精品导航| 欧美激情综合五月色丁香小说| 成人午夜电影久久影院| 国产精品卡一卡二卡三| 在线视频亚洲一区| 日韩精品一级二级| 久久亚洲精品国产精品紫薇| 成人天堂资源www在线| 亚洲综合在线免费观看| 777久久久精品| 国产福利91精品一区二区三区| 国产精品久久一卡二卡| 欧美日韩一二区| 麻豆中文一区二区| 国产精品不卡一区| 欧美日韩国产美| 国产剧情一区在线| 尤物在线观看一区| 日韩免费一区二区三区在线播放| 波多野结衣亚洲| 五月综合激情日本mⅴ| 久久久久97国产精华液好用吗| 99国产精品久| 麻豆91精品91久久久的内涵| 国产精品福利一区| 日韩色视频在线观看| 91视频www| 久久99久久精品欧美| 亚洲另类春色国产| 国产视频911| 51精品视频一区二区三区| 国产成人av一区二区三区在线| 亚洲一区二区三区四区在线观看 | 国产欧美一区二区三区鸳鸯浴| 91香蕉视频黄| 黄色日韩网站视频| 亚洲第一精品在线| 国产精品乱码人人做人人爱| 7777精品伊人久久久大香线蕉的| 国产99久久久国产精品潘金| 日本强好片久久久久久aaa| **欧美大码日韩| 26uuu亚洲综合色欧美| 欧美日韩一区视频| 99re热视频精品| 久久99国产精品久久99| 亚洲福利一二三区| 亚洲影视在线观看| 中文字幕欧美一| 久久九九久久九九| 欧美成人官网二区| 欧美一级黄色片| 欧美三级电影一区| 色一情一伦一子一伦一区| 粉嫩一区二区三区性色av| 久久精品噜噜噜成人av农村| 亚洲综合清纯丝袜自拍| 最近日韩中文字幕| 国产精品国产三级国产aⅴ入口 | 欧美精品 国产精品| 97精品国产露脸对白| 国产成人免费av在线| 极品尤物av久久免费看| 久久成人综合网| 爽好久久久欧美精品| 五月综合激情网| 污片在线观看一区二区 | 午夜成人免费视频| 亚洲大尺度视频在线观看| 亚洲自拍偷拍欧美| 亚洲精品成人a在线观看| 亚洲欧美日韩人成在线播放| 中文字幕在线不卡| 中文字幕在线不卡一区二区三区| 国产精品天天看| 国产精品高潮久久久久无| 国产精品网友自拍| 亚洲免费观看高清完整版在线| 亚洲欧美另类小说视频| 一区二区三区日韩欧美| 亚洲综合丁香婷婷六月香| 午夜精品久久久久久不卡8050 | 亚洲大尺度视频在线观看| 午夜精品久久久久久久99樱桃| 日韩精品亚洲一区| 国产在线一区观看| 日韩西西人体444www| 欧美日韩午夜影院| 日韩精品一区二区三区三区免费 | 国产视频一区二区在线观看| 国产精品免费视频观看| 亚洲精选视频免费看| 五月天激情小说综合| 国内外成人在线| 粉嫩一区二区三区性色av| 色狠狠av一区二区三区| 欧美精品三级日韩久久| 久久久久久久久一| 亚洲欧洲中文日韩久久av乱码| 亚洲第四色夜色| 国产精品中文字幕日韩精品 | 亚洲午夜av在线| 免费观看一级特黄欧美大片| 国产成人av一区二区| 色哟哟精品一区| 91精品国产日韩91久久久久久| 久久综合999| 中文字幕一区在线| 久久国产精品99久久人人澡| 99久久免费国产| 91精品免费在线观看| 国产精品三级av在线播放| 亚洲成av人片在线| 国产精品18久久久久| 欧洲另类一二三四区| 久久久久久免费网| 亚洲一区精品在线| 国产乱码精品一区二区三区忘忧草| 97国产一区二区| 精品国产免费视频| 亚洲综合清纯丝袜自拍| 国产69精品久久777的优势| 欧美日韩在线亚洲一区蜜芽| 欧美国产一区在线| 日韩**一区毛片| 91蜜桃视频在线| 久久夜色精品国产欧美乱极品| 亚洲一区二区三区四区的| 成人久久18免费网站麻豆| 欧美精品自拍偷拍| 亚洲情趣在线观看| 国产麻豆精品视频| 91麻豆精品国产91久久久更新时间| 国产精品成人在线观看| 极品少妇xxxx精品少妇| 欧美日韩www| 亚洲欧美日韩久久| 国产91富婆露脸刺激对白| 欧美一级高清片在线观看| 亚洲一区欧美一区| 96av麻豆蜜桃一区二区| 国产日韩欧美在线一区| 热久久久久久久| 欧美精选午夜久久久乱码6080| 亚洲激情自拍偷拍| 波多野结衣在线一区| 26uuu久久综合| 美女一区二区三区在线观看| 欧美精品一卡二卡| 亚洲与欧洲av电影| 91色视频在线| 中文字幕一区二区三| 成人午夜精品一区二区三区| 国产亚洲污的网站| 国产精品一区在线| 亚洲欧洲av另类| 一本色道**综合亚洲精品蜜桃冫| 亚洲123区在线观看| 欧美一区二区黄色| 日韩在线一区二区| 国产欧美视频在线观看| 欧美绝品在线观看成人午夜影视 | 成人开心网精品视频| 久久久久久久免费视频了| 国产清纯美女被跳蛋高潮一区二区久久w | 成人免费视频视频在线观看免费| 国产成人在线电影| 91麻豆国产在线观看| 在线亚洲高清视频| 天天综合天天做天天综合| 国产精品久久久久久久久久免费看| 精品国产一区二区三区四区四| 欧美日韩高清一区二区不卡| 99久久精品国产导航| 奇米精品一区二区三区四区 | 亚洲激情网站免费观看| 色综合视频一区二区三区高清| 国产中文一区二区三区| av一区二区三区在线| 国产一区二区三区不卡在线观看| 视频一区二区欧美| 久久国产综合精品| 韩国女主播一区| 亚洲国产日日夜夜| 一区二区三区蜜桃| 亚洲乱码中文字幕| 国产精品污污网站在线观看| 欧美不卡视频一区| 欧美成人一区二区|