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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? p248.cpp

?? 清華大學(xué)-數(shù)據(jù)結(jié)構(gòu) 清華大學(xué)-數(shù)據(jù)結(jié)構(gòu) 清華大學(xué)-數(shù)據(jù)結(jié)構(gòu)
?? CPP
字號:
#include "iostream.h"

	template <class Type> class AVLTree 
	{					//平衡的二叉搜索樹(AVL)類定義

	public:
	   struct AVLNode {							//AVL樹結(jié)點的類定義  
		 Type data;  AVLNode *left, *right;  int balance;
		 AVLNode ( ) : left (NULL), right (NULL), balance (0) { }
		 AVLNode ( Type d, AVLNode *l=NULL, AVLNode *r=NULL ) :
	           data (d), left (l), right (r), balance (0) { }
	   };
	
	protected:
	   Type RefValue;										//插入結(jié)束的標志
	   AVLNode *root;										//根結(jié)點的指針
	   int Insert ( AVLNode* &tree, Type x, int & taller );				//插入
	   void RotateLeft ( AVLNode *Tree, AVLNode* &NewTree );			//左單旋轉(zhuǎn)
	   void RotateRight ( AVLNode *Tree, AVLNode* &NewTree );			//右單旋轉(zhuǎn)
	   void LeftBalance ( AVLNode* &Tree, int & taller );				//左平衡化
	   void RightBalance ( AVLNode* &Tree, int & taller );				//右平衡化
	   int Depth ( AVLNode *t ) const;							//求高度
	   void Traverse ( AVLNode *ptr, ostream & out )const ;
	public:
	   AVLTree ( ) : root (NULL) { }								//構(gòu)造函數(shù):構(gòu)造一棵空AVL樹
	   AVLTree ( Type Ref ) : RefValue (Ref), root (NULL) { }				//構(gòu)造函數(shù):構(gòu)造非空AVL樹
	   int Insert ( Type x ) { int taller; return Insert ( root, x, taller ); }
	   friend istream& operator >> ( istream& in, AVLTree<Type>& Tree );
	   friend ostream& operator << ( ostream& out, const AVLTree<Type>& Tree );
	   int Depth ( ) const;
	};

		template <class Type> void AVLTree<Type>::RotateLeft ( AVLNode * Tree, AVLNode* &NewTree )
		{
		//右子樹比左子樹高: 對以Tree為根的AVL樹做左單旋轉(zhuǎn)(左折), 旋轉(zhuǎn)后新根在NewTree。
		   NewTree = Tree->right;					//新的根為C
		   Tree->right = NewTree->left;				//結(jié)點C的左子女轉(zhuǎn)為結(jié)點A的右子女
		   NewTree->left = Tree;					//結(jié)點A成為C的左子女
		};
		template <class Type> void AVLTree<Type>::RotateRight ( AVLNode *Tree, AVLNode* &NewTree )
		{
		//左子樹比右子樹高: 對以Tree為根的AVL樹做右單旋轉(zhuǎn)(右折), 旋轉(zhuǎn)后新根在NewTree。
		   NewTree = Tree->left;					//新的根在B
		   Tree->left = NewTree->right;				//結(jié)點B的右子女轉(zhuǎn)為A的左子女
		   NewTree->right = Tree;					//結(jié)點A成為B的右子女
		};

	 
		template <class Type> void AVLTree<Type>::LeftBalance ( AVLNode * &Tree, int & taller ) {
		   AVLNode *leftsub = Tree->left,  *rightsub;
		   switch ( leftsub->balance ) {							//判斷左子樹的平衡因子
			 case -1 :	Tree->balance = leftsub->balance = 0;		//左高,修改平衡因子
					RotateRight ( Tree, Tree );	taller = 0;  break;	//做右單旋轉(zhuǎn)
			 case 0 :	cout << "LeftBalance error: Tree already balanded.\n";  
				        break;	//沒有發(fā)生不平衡
			 case 1 :	rightsub = leftsub->right;					//右高, 取左子樹的右子樹
					switch ( rightsub->balance ) {				//判斷該右子樹的平衡因子
					   case -1: Tree->balance = 1;  
								leftsub->balance = 0;  break;
					   case 0 : Tree->balance = leftsub->balance = 0;  
								break;
					   case 1 : Tree->balance = 0;  
						        leftsub->balance = -1;  
								break;
					}								//調(diào)整旋轉(zhuǎn)后各結(jié)點的平衡因子
					rightsub->balance = 0;	
					RotateLeft ( leftsub, Tree->left );				//左單旋轉(zhuǎn)
					RotateRight ( Tree, Tree );	taller = 0;			//右單旋轉(zhuǎn)
				}
	}

		template <class Type> void AVLTree<Type>::RightBalance ( AVLNode * &Tree, int & taller ) {
		   AVLNode *rightsub = Tree->right,  *leftsub;
		   switch ( rightsub->balance ) {						//判斷右子樹的平衡因子
			 case 1 :	Tree->balance = rightsub->balance = 0;		//右高
					RotateLeft ( Tree, Tree );  
					taller = 0;  break;		//做左單旋轉(zhuǎn)
			 case 0 :	cout << "RightBalance error:Tree already balanded.\n";  
				        break;
			 case -1 :	leftsub = rightsub->left;					//左高, 取右子樹的左子樹
					switch ( leftsub->balance ) {				//判斷該左子樹的平衡因子
					   case 1 : Tree->balance = -1; 
						        rightsub->balance = 0;  
								break;
					   case 0 : Tree->balance = rightsub->balance = 0;  
						        break;
					   case -1 : Tree->balance = 0;  
						         rightsub->balance = 1;  
								 break;
					}
					leftsub->balance = 0;
					RotateRight ( rightsub, Tree->right );			//右單旋轉(zhuǎn)
					RotateLeft ( Tree, Tree );  taller = 0;			//左單旋轉(zhuǎn)
	   }
	}

		template <class Type> int AVLTree<Type>::Insert ( AVLNode* &tree, Type x, int &taller ) {
		//在以tree為根的AVL樹中插入新元素x, 如果插入成功, taller返回1, 否則返回0。 
		   int success;
		   if ( tree == NULL ) {								//原為空樹, 或某結(jié)點的空鏈域
			 tree = new AVLNode (x);							//創(chuàng)建新結(jié)點并插入
			 success = tree != NULL ? 1 : 0;						//成功標志: 存儲分配成功為1
			 if ( success )
				 taller = 1;
		   }
		   else if ( x < tree->data ) {							//判斷是向左插入還是向右插入
			 success = Insert ( tree->left, x, taller );					//插入到左子樹
			 if ( taller )									//插入成功 
			   switch ( tree->balance ) {						//判斷平衡因子
				 case -1 :	LeftBalance ( tree, taller );  
					        break;		//原左子樹高,不平衡,調(diào)整
				 case 0 :	tree->balance = -1;  
					        break;			//原兩子樹等高,僅改平衡因子
				 case 1 :	tree->balance = 0;  
					        taller = 0;  
					        break;	//原右子樹高,僅改平衡因子
			   }      
		   }
	        else {
			   success = Insert ( tree->right, x, taller );				//插入到右子樹
			   if ( taller )								//插入成功
				 switch ( tree->balance ) {					//判斷平衡因子
				 case -1 :	tree->balance = 0;
							taller = 0;  
							break;	//原左子樹高, 僅改平衡因子
				 case 0 :	tree->balance = 1;  
							break;			//原兩子樹等高, 僅改平衡因子
				 case 1 :	
					        RightBalance ( tree, taller );  
							break;		//原右子樹高,不平衡,調(diào)整
			   }
				}
		return success;									//向上層傳送插入成功信息
		}

		template <class Type> istream & operator >> ( istream & in, AVLTree<Type> & Tree ) {
		//輸入一系列的值, 建立AVL樹。約定Tree中的RefValue是終止輸入的標記。
		   Type item;									//輸入暫存單元
		   cout << "Construct AVL tree :\n";						//提示:構(gòu)造AVL樹
		   cout << "Input Data (end with " << Tree.RefValue << "): ";		//提示:輸入數(shù)據(jù)(以RefValue結(jié)束
		   in >> item;									//輸入
		   while ( item != Tree.RefValue ) {						//當輸入不等于RefValue時
		      Tree.Insert (item);								//插入到樹中			 
		      cout << "Input Data (end with " << Tree.RefValue << "): ";		//提示:輸入數(shù)據(jù)(以RefValue結(jié)束
		      in >> item;									//輸入
		   }
		   return in;
		}

		template <class Type> ostream & operator << ( ostream & out, const AVLTree<Type> & Tree ) {
		   out << "Inorder traversal of AVL tree.\n";					//提示:AVL樹的中序遍歷
		   Tree.Traverse ( Tree.root, out );						//以中序次序輸出樹中各結(jié)點的數(shù)據(jù)
		   out << endl;
		   return out;									//返回輸出對象
		}

		template <class Type> void AVLTree <Type>::Traverse ( AVLNode *ptr, ostream & out ) const {
		   if ( ptr != NULL ) {								//樹非空
		      Traverse ( ptr->left, out );						//中序遍歷左子樹
		      out << ptr->data << ' ';							//輸出根的數(shù)據(jù)
		      Traverse ( ptr->right, out );						//中序遍歷右子樹			  
		   }
		}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡一区二区三区四区| 在线观看不卡视频| 91网址在线看| 精品电影一区二区| 亚洲午夜一二三区视频| 国产一区二区三区观看| 欧美色视频在线观看| 国产亚洲欧美日韩在线一区| 午夜精品久久久久| 99在线精品观看| 久久久九九九九| 免费日韩伦理电影| 欧美日韩亚洲综合一区 | 日韩精品最新网址| 亚洲理论在线观看| 成人福利在线看| 国产亚洲综合av| 久久精品国产一区二区三区免费看| 99re热这里只有精品免费视频| 亚洲精品一区二区三区蜜桃下载 | 国产69精品久久777的优势| 9191国产精品| 亚洲 欧美综合在线网络| 一本到一区二区三区| 亚洲国产经典视频| 国产高清在线观看免费不卡| 精品国产欧美一区二区| 免费成人在线观看视频| 欧美高清性hdvideosex| 亚洲一区二区3| 欧美视频一区二区三区四区 | 91精品久久久久久久99蜜桃| 综合激情成人伊人| 97久久精品人人做人人爽50路 | 制服丝袜亚洲色图| 在线观看91av| 亚洲国产毛片aaaaa无费看| 91免费视频网| 亚洲欧美一区二区三区国产精品| 不卡的av电影| 亚洲欧美日韩国产综合| 在线这里只有精品| 亚洲一区二区三区影院| 欧美日韩国产影片| 视频一区视频二区中文| 欧美一卡2卡三卡4卡5免费| 乱一区二区av| 国产日韩欧美a| 不卡一区二区中文字幕| 亚洲一区二区三区四区在线 | 欧美在线免费播放| 午夜电影网亚洲视频| 日韩一二三四区| 激情六月婷婷久久| 国产精品视频第一区| 色爱区综合激月婷婷| 香蕉加勒比综合久久| 日韩欧美在线影院| 懂色av一区二区夜夜嗨| 一级做a爱片久久| 91精品国产91热久久久做人人| 精品亚洲成a人| 自拍视频在线观看一区二区| 在线日韩国产精品| 美国十次综合导航| 国产精品女主播av| 制服.丝袜.亚洲.另类.中文| 国产一区二区伦理片| 亚洲视频在线一区二区| 91精品国产91久久久久久最新毛片| 国产一区二三区| 一区二区三区四区视频精品免费| 日韩一区二区免费高清| www.欧美.com| 久久精品国产在热久久| 亚洲美女在线国产| 精品日韩欧美在线| 91久久精品午夜一区二区| 久久成人久久鬼色| 亚洲综合图片区| 久久久久久免费网| 在线播放一区二区三区| 成人动漫精品一区二区| 美女在线视频一区| 有坂深雪av一区二区精品| 精品成人一区二区三区四区| 欧美在线色视频| jiyouzz国产精品久久| 日韩福利电影在线| **欧美大码日韩| 久久蜜桃一区二区| 欧美久久一区二区| 色爱区综合激月婷婷| 成人av高清在线| 九九在线精品视频| 天天亚洲美女在线视频| 亚洲蜜臀av乱码久久精品| 国产三级欧美三级日产三级99| 这里只有精品99re| 91黄色小视频| 99视频精品在线| 成人在线视频一区二区| 另类小说视频一区二区| 日本va欧美va瓶| 日韩国产欧美在线观看| 亚洲一区二区四区蜜桃| 一区二区三区欧美激情| 亚洲视频一二三区| 国产精品不卡一区二区三区| 国产欧美一区二区三区在线老狼| 日韩欧美一级二级三级久久久| 欧美日韩1234| 欧美日韩黄色影视| 欧美日本乱大交xxxxx| 欧美午夜在线一二页| 91麻豆国产在线观看| www.久久精品| 91免费看视频| 在线中文字幕一区二区| 91福利在线免费观看| 色视频一区二区| 欧美制服丝袜第一页| 91成人免费网站| 欧美日韩一区二区不卡| 欧美日韩成人激情| 日韩手机在线导航| 精品粉嫩超白一线天av| 久久九九国产精品| 欧美国产视频在线| 亚洲三级在线播放| 亚洲综合色视频| 日本va欧美va欧美va精品| 蜜桃av一区二区在线观看| 精品中文av资源站在线观看| 国精产品一区一区三区mba视频| 国产美女精品在线| 成人激情文学综合网| 色综合久久天天综合网| 欧美狂野另类xxxxoooo| 精品国产免费一区二区三区四区| 国产色一区二区| 伊人一区二区三区| 麻豆精品一区二区综合av| 国产精品资源站在线| 色综合久久综合网97色综合| 911精品产国品一二三产区| 久久先锋资源网| 亚洲欧美日韩国产手机在线 | 精品视频一区二区三区免费| 欧美一区二区三区免费大片| 久久精品日韩一区二区三区| 亚洲男人的天堂一区二区| 日韩国产欧美在线播放| 国产成人av自拍| 欧美日韩成人综合天天影院| 久久久精品tv| 亚洲高清中文字幕| 国产一区不卡视频| 日本乱码高清不卡字幕| 欧美电影免费提供在线观看| 亚洲视频一区在线观看| 美女视频一区在线观看| 91免费视频网| 久久精品一二三| 三级影片在线观看欧美日韩一区二区| 国产在线精品视频| 欧美日韩欧美一区二区| 中文无字幕一区二区三区| 午夜欧美一区二区三区在线播放| 国产成人午夜高潮毛片| 欧美久久一区二区| 亚洲欧美日韩一区| 国产iv一区二区三区| 日韩视频一区二区三区在线播放| 国产精品素人视频| 狠狠色丁香久久婷婷综合_中| 欧美伊人久久大香线蕉综合69 | 色诱亚洲精品久久久久久| 精品国产区一区| 三级久久三级久久| 色伊人久久综合中文字幕| 久久精品夜色噜噜亚洲aⅴ| 日本成人超碰在线观看| 色婷婷久久一区二区三区麻豆| 国产亚洲一本大道中文在线| 美女视频黄 久久| 欧美日韩极品在线观看一区| 一区二区三区在线视频观看| 成人久久18免费网站麻豆| 日韩精品一区二区三区在线播放| 午夜精品久久久久久久久久久| 99久久婷婷国产综合精品| 国产欧美一区二区精品仙草咪| 蜜臀91精品一区二区三区 | 97成人超碰视| 亚洲欧洲成人精品av97| 成人午夜大片免费观看| 国产日韩欧美高清| 成人一区在线观看| 国产精品天干天干在线综合|