91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

二叉樹的前序、中序和后序線索化

發布時間:2020-07-03 17:02:27 來源:網絡 閱讀:4591 作者:威尼斯小艇 欄目:編程語言

    二叉樹是一種非線性結構,遍歷二叉樹需要通過遞歸或者用棧輔助實現非遞歸的遍歷。

    用二叉樹作為壓縮存儲結構時,取到一個結點,只能獲取節點的左孩子和右孩子,不能直接得到結點的任一遍歷序列的前驅或者后繼。為了實現這種遍歷,偶們利用二叉樹中指向左右子樹的空指針來存放結點的前驅和后繼。

線索化二叉樹思路:

    當某一結點的左結點或結右點存在NULL時,則該結點的為空的子結點需要線索化。

    在進行線索化時,結點的前驅指向前一個訪問過的結點,故定義一個指針prev來保存前一個結點;結點的后繼偶們并不知道,則對于未來的事情并不知道,偶們可以在未來對該結點的后繼進行線索化,使prev的后繼指向cur。

前序遍歷二叉樹------根->左->右(1,2,3,4,5,6)

二叉樹的前序、中序和后序線索化

template<class T>
void BinaryTreeThd<T>::PrevOrderThreading()//前序線索化二叉樹
{
	Node* prev = NULL;
	_PrevOrderThreading(_root, prev);
}
template<class T>
void BinaryTreeThd<T>::_PrevOrderThreading(Node* cur, Node*& prev)//前序線索化二叉樹
{
	if (cur == NULL)
	{
		return;
	}
	if (cur->_left == NULL)
	{
		cur->_leftTag = THREAD;
		cur->_left = prev;
	}
	if (prev && prev->_right == NULL)//到未來的結點進行先前結點后繼的線索化
	{
		prev->_rightTag = THREAD;
		prev->_right = cur;
	}
	prev = cur;
	if (cur->_leftTag == LINK)//線索化左結點
	{
		_PrevOrderThreading(cur->_left, prev);
	}
	if (cur->_rightTag == LINK)//線索化右結點
	{
		_PrevOrderThreading(cur->_right, prev);
	}
}

中序遍歷二叉樹------左->根->右(3,2,4,1,6,5)

二叉樹的前序、中序和后序線索化遞歸實現:

template<class T>
void BinaryTreeThd<T>::InOrderThreading()//中序線索化二叉樹
{
	//遞歸實現中序線索化
	Node* prev = NULL;//線索化的前一個結點
	_InOrederThreading(_root, prev);
}
template<class T>
void BinaryTreeThd<T>::_InOrederThreading(Node* cur,Node*& prev)//中序線索化二叉樹
{
	if (cur == NULL)
	{
		return;
	}
	_InOrederThreading(cur->_left, prev);//遞歸出cur->_left為空
	if (cur->_left == NULL)
	{
		cur->_leftTag = THREAD;
		cur->_left = prev;//當前結點的前驅指向前一個結點
	}
	//對先前的結點后繼進行線索化,在cur指向下一個結點即后繼時,將先前節點的后繼指向cur
	//到未來的結點進行先前結點后繼的線索化
	if (prev && prev->_right == NULL)
	{
		cur->_rightTag = THREAD;
		prev->_right = cur;
	}
	prev = cur;
	_InOrederThreading(cur->_right, prev);//遞歸出cur->_right為空
}

非遞歸實現(利用棧):

template<class T>
void BinaryTreeThd<T>::InOrderThreading_NonR()//中序線索化二叉樹--非遞歸
{
	//棧實現中序線索化
	stack<Node*> s;
	Node* prev = NULL;
	Node* cur = _root;
	if (cur == NULL)
	{
		return;
	}
	while (cur || !s.empty())
	{
		while(cur)//找到最左結點,入棧
		{
			s.push(cur);
			cur = cur->_left;
		}//cur不為空進棧,cur為空說明cur已經線索化了
		cur = s.top();//循環進入使cur為棧頂元素并判斷是否需要線索化
		if (cur->_left == NULL)
		{
			cur->_leftTag = THREAD;
			cur->_left = prev;
		}
		s.pop();//彈出棧頂元素,使棧頂保存需要線索化的cur的后繼
		prev = cur;
		if (cur->_right == NULL && !s.empty())
		{
			cur->_rightTag = THREAD;
			cur->_right = s.top();
			cur = NULL;//設置cur為空,防止死循環(2)
		}
		else
		{
			cur = cur->_right;//線索化跳到右子樹進行
		}
	}
}

后序遍歷二叉樹------左->右->根(3,4,2,6,5,1)

二叉樹的前序、中序和后序線索化

template<class T>
void BinaryTreeThd<T>::PastOrderThreading()//后序線索化二叉樹
{
	Node* prev = NULL;
	_PastOrderThreading(_root, prev);
}
template<class T>
void BinaryTreeThd<T>::_PastOrderThreading(Node* cur, Node*& prev)//后序線索化二叉樹
{
	if (cur == NULL)
	{
		return;
	}
	_PastOrderThreading(cur->_left, prev);//最左結點
	_PastOrderThreading(cur->_right, prev);//最右結點
	if (cur->_left == NULL)//線索化前驅
	{
		cur->_leftTag = THREAD;
		cur->_left = prev;
	}
	if (prev && prev->_right == NULL)//線索化后繼
	{
		prev->_rightTag = THREAD;
		prev->_right = cur;
	}
	prev = cur;
}
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肃南| 金川县| 伊川县| 陇川县| 高陵县| 延长县| 仲巴县| 五大连池市| 巨野县| 武宁县| 邯郸市| 塔城市| 大方县| 海城市| 普宁市| 安平县| 庐江县| 白玉县| 万全县| 鱼台县| 进贤县| 渝北区| 泾川县| 昌都县| 临洮县| 榕江县| 连平县| 松滋市| 闽侯县| 红桥区| 紫阳县| 利川市| 农安县| 平塘县| 张家港市| 周宁县| 平乡县| 施甸县| 砀山县| 莎车县| 垦利县|