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

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

?? tree.cpp

?? 我學習時候的數據結構程序!都是自己經驗的總結
?? CPP
字號:
//定義類中的成員函數,文件名為tree.cpp
#include<iostream>
#include<string>
#include"tree.h"
using namespace std;
/*
 *前置條件:樹不存在
 *輸    入:無
 *功    能:構造一棵樹
 *輸    出:無
 *后置條件:產生一棵樹 
 */

template<class T>
Tree<T>::Tree( )
{
	const int MaxSize = 100;
    int end = 0;
	int front = 0;
	int rear  = 0;  //采用順序隊列,并假定不會發生上溢
	int j = 0;	
	TNode<T>* queue[MaxSize]; //聲明一個隊列 
	TNode<T>* tempNode;              //聲明指向結點類型的指針  
	TNode<T>* brotherNode;   //工作指針
    TNode<T>* q;
	T ch;
    cout<<"請輸入創建一棵樹的根結點數據"<<endl;
	cin>>ch;
    root = new TNode<T>;
	root->data = ch;
	root->firstchild = NULL;
	root->rightsib = NULL;
    queue[rear++] = root;  
    while (!end)    //若繼續創建樹
	{ 
		T ch1,ch2;
		cout<<"請輸入創建一棵樹的父結點數據和孩子結點數據"<<endl;
		cin>>ch1>>ch2;
		TNode<T>* p = new TNode<T>;       //生成一個結點
		p->data = ch2;
		p->firstchild = NULL;    
		p->rightsib = NULL; 
        queue[rear++] = p;
		tempNode = queue[front];//頭結點出隊,同時對頭元素的標識符后移           			
		while(ch1 != tempNode->data)  		
			tempNode = queue[front++];											
		if(tempNode->firstchild == NULL)	tempNode->firstchild = p;
		else{
			brotherNode = tempNode->firstchild;  //工作指針指向結點的第一個孩子
			while (brotherNode != NULL)          //若第一個孩子有兄弟結點
			{
				q = brotherNode;
				brotherNode = brotherNode->rightsib;//工作指針指向第一個孩子的右兄弟				
			}            
			q->rightsib = p;			        
		}
		cout<<"創建結束? 如果結束請按1否則請按0 "<<endl;
		cin>>end;
	}
}
/*
 *前置條件:樹已存在
 *輸    入:無
 *功    能:釋放樹中各結點的存儲空間
 *輸    出:無
 *后置條件:樹不存在 
 */
template<class T>
Tree<T>::~Tree(void)
{
	Release(root);
}
/*
 *前置條件:樹已存在
 *輸    入:無
 *功    能:獲取指向樹根結點的指針
 *輸    出:指向樹根結點的指針
 *后置條件:樹不變 
 */
template<class T>
TNode<T>* Tree<T>::Getroot( )
{
	return root;
}
/*
 *前置條件:樹已存在
 *輸    入:無
 *功    能:前序遍歷樹
 *輸    出:樹中結點的一個線性排列
 *后置條件:樹不變 
 */
template<class T>
void Tree<T>::PreOrder(TNode<T> *root)      //前序遍歷樹
{
	if (root == NULL)  return;     //遞歸調用的結束條件
	else{		
		cout<<root->data;          //打印根節點
		PreOrder(root->firstchild);    //前序遞歸遍歷root的第一個孩子
		PreOrder(root->rightsib);    //前序遞歸遍歷root的右兄弟  
	}
}
/*
 *前置條件:樹已存在
 *輸    入:無
 *功    能:后序遍歷樹
 *輸    出:樹中結點的一個線性排列
 *后置條件:樹不變 
 */
template<class T>
void Tree<T>::PostOrder(TNode<T> *root)
{ 
	if (root == NULL)  return;     //遞歸調用的結束條件
	else{		
		PostOrder(root->firstchild);    //后序遞歸遍歷root的第一個孩子
        cout<<root->data;               //打印出root結點
		PostOrder(root->rightsib);      //后序遞歸遍歷root的右兄弟        
	}
} 
/*
 *前置條件:樹已存在
 *輸    入:無
 *功    能:層序遍歷樹
 *輸    出:樹中結點的一個線性排列
 *后置條件:樹不變
 */
template<class T>
void Tree<T>::LeverOrder(TNode<T> *root)   
{		
	const int MAX_QUEUE_SIZE = 100;
	int front = 0;
	int rear  = 0;  //采用順序隊列,并假定不會發生上溢		
	TNode<T>* queue[MAX_QUEUE_SIZE]; //聲明一個隊列 
	TNode<T>* tempNode;      //聲明指向結點類型的指針  
	TNode<T>* brotherNode;   //工作指針

	if (root == NULL) return;//循環結束條件
	queue[rear++] = root;    //否則結點入隊
	while (front != rear)    //若隊列中有結點
	{
		tempNode = queue[front++];//頭結點出隊,同時對頭元素的標識符后移
		cout<<tempNode->data;     //打印出頭結點    
		brotherNode = tempNode->firstchild;  //工作指針指向結點的第一個孩子
		while (brotherNode != NULL)          //若第一個孩子有兄弟結點
		{
			queue[rear++] = brotherNode;     //第一個孩子結點入隊
			brotherNode = brotherNode->rightsib;//工作指針指向第一個孩子的右兄弟
		}
	}
}
/*
 *前置條件:樹已經存在
 *輸    入:無
 *功    能:釋放樹的存儲空間,析構函數調用
 *輸    出:無
 *后置條件:樹不存在
 */
template <class T>
void Tree<T>::Release(TNode<T>* root)
{
	if (root != NULL){ 	
		Release (root->firstchild);   //釋放第一個孩子
		Release (root->rightsib);   //釋放右兄弟
        delete root;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日免费三级在线| 欧美色图12p| 欧美日韩黄色影视| 亚洲图片欧美综合| 黄一区二区三区| 欧美精品一卡二卡| 国产目拍亚洲精品99久久精品| 国产一区二区0| 国内精品国产三级国产a久久| 国产盗摄精品一区二区三区在线| 日本一二三不卡| 婷婷夜色潮精品综合在线| 国产成人综合视频| 欧美另类久久久品| 亚洲欧洲精品一区二区三区不卡| 喷白浆一区二区| 在线一区二区视频| 综合精品久久久| 成人免费高清视频| 欧美v亚洲v综合ⅴ国产v| 亚洲成av人片在www色猫咪| 成人97人人超碰人人99| 精品粉嫩超白一线天av| 日本成人在线一区| 欧美片网站yy| 亚洲不卡av一区二区三区| 97久久超碰国产精品电影| 国产日韩欧美a| 国产盗摄精品一区二区三区在线 | 日韩美女视频在线| 亚洲成人av一区二区| 欧美亚洲国产一卡| 亚洲男人的天堂一区二区| 99久久国产免费看| 国产欧美中文在线| 久久综合久久综合亚洲| 日韩欧美在线一区二区三区| 国产sm精品调教视频网站| 日本最新不卡在线| 亚洲国产精品久久久久秋霞影院 | 欧美一区二区三区喷汁尤物| 91麻豆国产在线观看| 五月天欧美精品| 中文字幕亚洲在| 91首页免费视频| 国产乱子轮精品视频| 麻豆国产欧美日韩综合精品二区| 偷窥少妇高潮呻吟av久久免费| 久久综合九色综合97_久久久| 午夜精品123| 91色乱码一区二区三区| 亚洲精品在线三区| 国产盗摄一区二区三区| 自拍视频在线观看一区二区| 日韩美女视频在线| 69精品人人人人| 久久婷婷久久一区二区三区| 日韩欧美资源站| 精品99一区二区| 一区精品在线播放| 亚洲婷婷在线视频| 国产乱理伦片在线观看夜一区| 国产一区二区91| 九九精品视频在线看| 久久久精品国产免大香伊| 成人午夜碰碰视频| 亚洲高清免费视频| 精品久久久久久久久久久久久久久| 国产精品自拍网站| 亚洲精品国产一区二区三区四区在线 | 精品久久99ma| 国产iv一区二区三区| 亚洲成人在线网站| 国产午夜精品一区二区三区视频| 一本大道久久a久久精品综合| 亚洲成av人片在线观看无码| 久久奇米777| 欧美三级一区二区| 高清免费成人av| 五月天一区二区三区| 欧美国产精品一区| 日韩亚洲欧美成人一区| av综合在线播放| 韩国视频一区二区| 五月天一区二区| 中文字幕中文在线不卡住| 日韩一区二区三区在线| 91啪在线观看| 国产高清在线精品| 午夜精品福利久久久| 亚洲视频在线一区| 日本一区二区三区在线不卡| 日韩限制级电影在线观看| 色偷偷久久人人79超碰人人澡| 国产一区二三区| 日韩影院免费视频| 亚洲美女一区二区三区| 国产欧美日韩三级| 精品国产3级a| 日韩视频免费直播| 欧美日韩免费在线视频| 99re这里只有精品6| 国产一区二区h| 精品影视av免费| 青青草国产成人av片免费| 亚洲欧美日韩国产手机在线| 久久久久久亚洲综合影院红桃| 欧美一区二区三区播放老司机| 色婷婷综合久久久久中文| 国产成人午夜99999| 精品综合免费视频观看| 日本不卡高清视频| 日本一区中文字幕| 日韩va欧美va亚洲va久久| 亚洲午夜一区二区| 亚洲午夜av在线| 亚洲一二三四区不卡| 亚洲男同性恋视频| 亚洲男人天堂av网| 樱桃国产成人精品视频| 亚洲欧美电影一区二区| 国产精品毛片久久久久久久| 欧美激情综合在线| 中文字幕av资源一区| 中文文精品字幕一区二区| 中文子幕无线码一区tr| 国产精品乱码妇女bbbb| 国产精品色婷婷久久58| 国产精品电影院| 亚洲三级在线看| 亚洲综合激情网| 日韩激情视频网站| 免费精品视频在线| 久久99九九99精品| 国产精品亚洲专一区二区三区| 国产91清纯白嫩初高中在线观看 | 一区二区三区在线播放| 又紧又大又爽精品一区二区| 亚洲一本大道在线| 久久精品国产99国产精品| 高清国产午夜精品久久久久久| av综合在线播放| 欧美色国产精品| 日韩欧美在线123| 国产日产欧美一区二区视频| 中文字幕一区二区三区四区不卡 | 欧美大胆一级视频| 国产亚洲欧美在线| 一区二区三区电影在线播| 免费看日韩a级影片| 国产激情视频一区二区三区欧美| 99久久精品一区二区| 欧美日韩国产影片| 久久精品一区二区三区不卡牛牛 | 精品成a人在线观看| 国产精品国产三级国产aⅴ中文| 午夜精品成人在线视频| 国产成人av一区二区三区在线观看| 91在线观看一区二区| 欧美丰满嫩嫩电影| 日本一区二区三区高清不卡| 亚洲精品久久7777| 国产最新精品免费| 欧美怡红院视频| 国产亚洲精品bt天堂精选| 亚洲国产wwwccc36天堂| 国产精品99久| 欧美精品亚洲一区二区在线播放| 久久久久99精品一区| 亚洲国产日韩综合久久精品| 国产精品自拍毛片| 欧美精品自拍偷拍| 亚洲人成人一区二区在线观看| 老司机精品视频线观看86| 色噜噜狠狠成人中文综合| 久久久综合视频| 日韩国产高清在线| 91色婷婷久久久久合中文| 久久久综合网站| 蜜臀av性久久久久蜜臀aⅴ四虎| 日本精品裸体写真集在线观看 | 色久优优欧美色久优优| 久久丝袜美腿综合| 美女任你摸久久 | 91在线视频官网| 久久蜜桃一区二区| 免费国产亚洲视频| 欧美高清视频一二三区| 亚洲免费观看在线视频| 粉嫩av一区二区三区| 久久中文字幕电影| 久久国产成人午夜av影院| 欧美精品日韩一本| 亚洲女厕所小便bbb| 成人黄色小视频在线观看| 国产午夜精品一区二区三区视频| 激情成人午夜视频| 久久久午夜电影| 国产一区二区在线视频| 久久只精品国产|