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

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

?? threadbinarytree.h

?? BinaryTree的定義以及相關函數的實現
?? H
字號:
// ThreadBinaryTree.h: interface for the ThreadBinaryTree class.
//
//////////////////////////////////////////////////////////////////////

#if !defined(AFX_THREADBINARYTREE_H__73E5ADE5_F47C_463B_B199_91EE62DE38D6__INCLUDED_)
#define AFX_THREADBINARYTREE_H__73E5ADE5_F47C_463B_B199_91EE62DE38D6__INCLUDED_

#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000

#include "ThreadBinaryTreeNode.h"

template <class T>
class ThreadBinaryTree  
{
private:
	ThreadBinaryTreeNode<T>* root;						//根結點指針
public:
	ThreadBinaryTree(){	root=NULL;};					//構造函數
	virtual ~ThreadBinaryTree(){DeleteTree(root);};
	ThreadBinaryTreeNode<T>* getRoot(){return root;};	//返回根結點指針
	//以element作為根結點,leftTree作為樹的左子樹,rightTree作為樹的右子樹,構造一棵新的二叉樹
	void CreateTree(const T& elem, ThreadBinaryTree<T>& leftTree, ThreadBinaryTree<T>& rightTree);
	//刪除二叉樹或其子樹
	void DeleteTree(ThreadBinaryTreeNode<T>* root);
	//對稱序線索化二叉樹
	void InThread(ThreadBinaryTreeNode<T>* root);
	//遞歸對稱序線索化二叉樹
	void InThread(ThreadBinaryTreeNode<T>* root,ThreadBinaryTreeNode<T>* &pre);
	//對稱序周游
	void InOrder(ThreadBinaryTreeNode<T>* root);
	//在對稱序穿線樹中找指定結點在前序下的后繼
	ThreadBinaryTreeNode<T>* FindNextinInorderTree(ThreadBinaryTreeNode<T>* pointer);
	//往對稱序穿線樹里插入一個新結點
	void InsertNode(ThreadBinaryTreeNode<T>*pointer,ThreadBinaryTreeNode<T>* newpointer);
};

template <class T>
void ThreadBinaryTree<T>::CreateTree(const T& elem, ThreadBinaryTree<T>& leftTree, ThreadBinaryTree<T>& rightTree)
{
	root=new ThreadBinaryTreeNode<T>(elem,leftTree.root,0,rightTree.root,0);//創建新樹
	leftTree.root=rightTree.root=NULL;							//原來兩棵子樹的根結點指空,避免訪問

}

template <class T>
void ThreadBinaryTree<T>::DeleteTree(ThreadBinaryTreeNode<T>* root)//刪除二叉樹或其子樹
{
	if(root)
	{
		if(root->lTag==0)
			DeleteTree(root->left);
		if(root->rTag==0)
		DeleteTree(root->right);
		delete root;
	}
	else
		delete root;
}

template <class T>
void ThreadBinaryTree<T>::InThread(ThreadBinaryTreeNode<T>* root,ThreadBinaryTreeNode<T>* &pre)
//遞歸對稱序線索化二叉樹
{
	if(root!=NULL)
	{
		//中序線索化左子樹
		InThread(root->leftchild(),pre);
		if(root->leftchild()==NULL)
		{
		//建立前驅線索
			root->left=pre;			
			root->lTag=1;
		}
		if((pre)&&(pre->rightchild()==NULL))
		{
		//建立后繼線索
			pre->right=root;
			pre->rTag=1;
		}
		pre=root;
		//中序線索化右子樹
		InThread(root->rightchild(),pre);
	}
}

template <class T>
void ThreadBinaryTree<T>::InThread(ThreadBinaryTreeNode<T>* root)//對稱序線索化二叉樹
//對稱序線索化二叉樹
{
	//初始化
	using std::stack;
	stack<ThreadBinaryTreeNode<T>*> aStack;
	ThreadBinaryTreeNode<T>* pointer=root;
	ThreadBinaryTreeNode<T>* temppointer=NULL;		//遞歸對稱序線索化二叉樹
	//訪問一個結點,必要時建立線索
	while(1)
	{
		while(NULL!=pointer)
		{
			aStack.push(pointer);
			pointer=pointer->leftchild();			//沿左子樹方向下降
		}
		if(aStack.empty())							//棧空,算法結束
			return;
		else
		{
			pointer=aStack.top();
			aStack.pop();
			if(NULL!=temppointer)
			{
				if(NULL==temppointer->right)
				{
					temppointer->rTag=1;
					temppointer->right=pointer;		//確定中序后繼
				};
				if(NULL==pointer->left)
				{
					pointer->lTag=1;
					pointer->left=temppointer;		//確定中序前驅
				}
			}
			temppointer=pointer;
			pointer=pointer->rightchild();			//轉向二叉樹的右子樹
		}
	}
}

template <class T>
void ThreadBinaryTree<T>::InOrder(ThreadBinaryTreeNode<T>* root)//對稱序周游
{
	ThreadBinaryTreeNode<T>* pointer;
	//是否為空二叉樹
	if(root==NULL)
		return;
	else pointer=root;
	//找“最左下”結點
	while(pointer->leftchild()!=NULL)
		pointer=pointer->leftchild();
	//訪問當前結點并找出當前結點的對稱序后繼
	while(1)
	{
		AfxMessageBox(pointer->value());			//訪問當前結點
		if(pointer->rightchild()==NULL)
			return;
		if(pointer->rTag==1)
			pointer=pointer->rightchild();
		else
		{
			pointer=pointer->rightchild();
			while(pointer->lTag==0)
				pointer=pointer->leftchild();
		}
	}
}

template <class T>
ThreadBinaryTreeNode<T>* ThreadBinaryTree<T>::FindNextinInorderTree(ThreadBinaryTreeNode<T>* pointer)		
//在對稱序穿線樹中找指定結點在前序下的后繼
{
	ThreadBinaryTreeNode<T>* temppointer=NULL;
	if(pointer->lTag==0)
		return pointer->leftchild();
	else
		temppointer=pointer;
	while(temppointer->rTag==1)
		temppointer=temppointer->rightchild();
	temppointer=temppointer->rightchild();
	return temppointer;
}

template <class T>
void ThreadBinaryTree<T>::InsertNode(ThreadBinaryTreeNode<T>*pointer,ThreadBinaryTreeNode<T>* newpointer)
//往對稱序穿線樹里插入一個新結點
{
	ThreadBinaryTreeNode<T>* temppointer=NULL;
	//找指定結點的對稱序后繼
	if(pointer->rightchild()==NULL)
		temppointer=NULL;
	else if(pointer->rTag==1)
			temppointer=pointer->rightchild();
		 else
		 {
			temppointer=pointer->rightchild();
			while(temppointer->lTag==0)
				temppointer=temppointer->leftchild();
		 }
	//temppointer指針指向pointer結點的對稱序后繼
	//建立指定結點的對稱序后繼的左線索
	if((temppointer!=NULL)&&(temppointer->lTag==1))
		temppointer->left=newpointer;
	//建立新結點的右指針或右線索
	newpointer->rTag=pointer->rTag;
	newpointer->right=pointer->rightchild();
	//插入新結點
	pointer->rTag=0;
	pointer->right=newpointer;
	//建立新結點左線索
	newpointer->lTag=1;
	newpointer->left=pointer;
}

#endif // !defined(AFX_THREADBINARYTREE_H__73E5ADE5_F47C_463B_B199_91EE62DE38D6__INCLUDED_)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品人人做人人爽| 成人晚上爱看视频| 日韩欧美中文一区二区| 视频一区视频二区中文字幕| 5858s免费视频成人| 蜜芽一区二区三区| 精品蜜桃在线看| 春色校园综合激情亚洲| 亚洲免费在线看| 欧美福利电影网| 久久精品国产免费看久久精品| 久久久久久久久久久99999| 高清久久久久久| 一区二区三区中文免费| 日韩一区二区三区在线视频| 国产91色综合久久免费分享| 亚洲视频在线观看三级| 在线观看成人免费视频| 久久99热狠狠色一区二区| 亚洲国产精品ⅴa在线观看| 91麻豆精品一区二区三区| 图片区小说区国产精品视频| 欧美成人a∨高清免费观看| 成人黄色软件下载| 日本特黄久久久高潮| 国产精品欧美综合在线| 欧美日韩在线一区二区| 国产激情一区二区三区桃花岛亚洲| 亚洲欧美激情在线| 欧美国产成人精品| 欧美日韩在线播放三区四区| 看片网站欧美日韩| 一区二区三区在线视频免费| 久久美女高清视频 | 国产激情一区二区三区四区| 亚洲激情男女视频| 久久精品人人做人人爽人人| 欧美色精品在线视频| 国产伦精品一区二区三区视频青涩| 中文字幕视频一区二区三区久| 欧美一级二级三级乱码| 欧美中文字幕一区二区三区亚洲| 久久99精品久久只有精品| 亚洲精选视频在线| 久久先锋影音av| 欧美放荡的少妇| 成人高清在线视频| 国产综合色在线| 日韩国产精品久久| 亚洲国产wwwccc36天堂| 中文字幕av资源一区| 欧美一区二区精品久久911| 91老师片黄在线观看| 国产成人丝袜美腿| 老司机精品视频一区二区三区| 亚洲第一成人在线| 亚洲精品久久久久久国产精华液| 国产日韩精品一区| 久久网这里都是精品| 欧美一级理论片| 在线播放一区二区三区| 欧美日韩精品一区二区三区 | 91精彩视频在线| 国产99久久久国产精品免费看| 久久精品国产第一区二区三区| 日韩不卡一区二区| 天堂久久久久va久久久久| 亚洲在线视频免费观看| 亚洲激情在线激情| 一区二区在线观看av| 亚洲色图丝袜美腿| 亚洲视频电影在线| 亚洲人成亚洲人成在线观看图片| 中文字幕欧美区| 国产欧美精品一区二区色综合朱莉| 久久免费的精品国产v∧| 久久综合资源网| 亚洲丝袜美腿综合| 最新日韩av在线| 亚洲视频你懂的| 亚洲丝袜精品丝袜在线| 亚洲伦理在线精品| 亚洲国产一区二区视频| 亚洲3atv精品一区二区三区| 无吗不卡中文字幕| 热久久久久久久| 狂野欧美性猛交blacked| 韩国女主播一区| 成人在线视频一区| 99久久免费国产| 欧美在线free| 777亚洲妇女| 精品理论电影在线观看| 中文字幕精品一区| 亚洲精品国产无天堂网2021| 香蕉久久夜色精品国产使用方法| 天天影视涩香欲综合网| 麻豆91小视频| 成人一级视频在线观看| 在线观看一区二区视频| 欧美一级欧美一级在线播放| 久久久综合视频| 亚洲欧美视频在线观看视频| 五月激情综合婷婷| 国产伦精品一区二区三区免费| av亚洲精华国产精华精| 欧美日产国产精品| 久久网站最新地址| 91偷拍与自偷拍精品| 91精品国产入口| 久久人人爽人人爽| 中文字幕第一区第二区| 亚洲精品视频在线观看免费 | 国产亚洲成年网址在线观看| 欧美一区二区三区在线观看| 日韩欧美专区在线| 国产精品久久久久久亚洲伦| 亚洲第一久久影院| 国产一区日韩二区欧美三区| 91亚洲国产成人精品一区二三| 69精品人人人人| 久久婷婷国产综合精品青草| 亚洲激情男女视频| 国产综合一区二区| 色一情一乱一乱一91av| 日韩一区二区三免费高清| 午夜精品久久久久久久蜜桃app| 国产精品视频第一区| 2023国产精品自拍| 中文字幕一区二区三区不卡| 日韩影院免费视频| 在线视频综合导航| 黄一区二区三区| 日韩精品久久久久久| 亚洲二区视频在线| 青青草国产精品亚洲专区无| 色综合亚洲欧洲| 国产欧美日韩视频一区二区| 丝袜诱惑制服诱惑色一区在线观看| av在线不卡网| 久久久久国产精品麻豆ai换脸| 亚洲国产sm捆绑调教视频 | 国产三级一区二区三区| 日韩vs国产vs欧美| 91豆麻精品91久久久久久| 久久网这里都是精品| 日韩精品亚洲专区| 欧洲国产伦久久久久久久| 国产精品麻豆久久久| 韩国精品一区二区| 欧美www视频| 日本不卡免费在线视频| 欧美日韩午夜影院| 亚洲成年人影院| 日韩三级视频中文字幕| 午夜激情久久久| 欧美日韩成人综合天天影院| 亚洲免费在线视频| 色婷婷久久综合| 亚洲欧洲综合另类在线| www.99精品| 亚洲精品亚洲人成人网在线播放| 成人一区二区视频| 欧美国产精品中文字幕| 国产九色精品成人porny| 国产亚洲一区二区三区四区| 国产精品一线二线三线精华| 久久久综合激的五月天| 国产一区二区福利| 久久久久久久电影| 东方欧美亚洲色图在线| 国产精品白丝在线| 91麻豆国产在线观看| 一卡二卡三卡日韩欧美| 欧美三级蜜桃2在线观看| 亚洲h在线观看| 欧美一区二区成人6969| 久久国产免费看| 国产目拍亚洲精品99久久精品| 成人午夜在线视频| 亚洲精品成人在线| 欧美日韩在线观看一区二区| 男人操女人的视频在线观看欧美| 日韩一级在线观看| 国产精品一色哟哟哟| 中文字幕永久在线不卡| 欧美亚洲一区二区在线观看| 一区二区欧美在线观看| 欧美一区二区精品在线| 国产a视频精品免费观看| 亚洲欧美区自拍先锋| 欧美一区二区在线观看| 午夜精品视频在线观看| 亚洲不卡av一区二区三区| 国产精品免费aⅴ片在线观看| 久久国产麻豆精品| 麻豆freexxxx性91精品| 热久久国产精品| 久久99国产精品免费| 美国三级日本三级久久99|