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

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

?? thbitre.h

?? 該源碼實現對二叉樹的線索化
?? H
字號:
//thbitre.h
#include<fstream>
#define MAX 100

using namespace std;


struct BTNode
{
	BTNode * lchild,* rchild;//左右孩子
	char  data;
	int  LTag,RTag;//LTag=1為線索,LTag=0為左子樹
};


class thbitre 
{
private:
	BTNode * root;
	void create(BTNode * & BT,char ch[]);
	void preOrder(BTNode * & BT);
	void inOrder(BTNode * & BT);
	void postOrder(BTNode * & BT);
	void preThreading(BTNode * & BT,BTNode * & pre);
	void inThreading(BTNode * & BT,BTNode * & pre);
	void postThreading(BTNode * & BT,BTNode * & pre);
public:
	thbitre(){BTNode * root=NULL;}
	void create_thbitre(char *filename);
	void preOrderthbitre();//先序遍歷
	void inOrderthbitre(); //中序遍歷
	void postOrderthbitre();//后序遍歷
	void preOrderThreading();//先序線索化二叉樹
	void preOrderTraverse_Thr();//先序遍歷先序線索二叉樹
	void inOrderThreading();//中序線索化二叉樹
	void postOrderThreading();//后序線索化二叉樹
	void inOrderTraverse_Thr();//中序遍歷中序線索二叉樹
	void insert_Pre_Thr(char x);
};


void thbitre::create_thbitre(char *filename)
{
	char a[MAX];
	int m=1,i=0;
	fstream infile(filename,ios::in);
	if(!infile)
	{
		cerr<<"error"<<endl;
		exit(1);
	}
	while(m)
	{
		infile>>a[i];
		cout<<a[i];
		if(a[i]=='#'||a[i]==-9999)
			m=0;
		else
			i++;
	}
	cout<<endl;
	create(root,a);
}

void thbitre::create(BTNode * & BT,char ch[])
{
	static int i=-1;
	i++;
	if(ch[i]=='.')
		BT=NULL;
	else
	{
		BT=new BTNode;
		BT->data=ch[i];
		BT->LTag=0;
		BT->RTag=0;
		create(BT->lchild,ch);
		create(BT->rchild,ch);
	}
	return;
}


void thbitre::inOrderthbitre()
{
	inOrder(root);
	cout<<endl;
}

void thbitre::inOrder(BTNode * & BT)
{
	if(BT!=NULL)
	{
		inOrder(BT->lchild);
		cout<<BT->data<<' ';
		inOrder(BT->rchild);
	}
}

void thbitre::postOrderthbitre()
{
	postOrder(root);
	cout<<endl;
}

void thbitre::postOrder(BTNode * & BT)
{
	if(BT!=NULL)
	{
		postOrder(BT->lchild);
		postOrder(BT->rchild);
		cout<<BT->data<<' ';
	}
}


void thbitre::preOrderThreading()
{
	BTNode * pre=NULL;//*pre指向當前結點前一結點
	preThreading(root,pre);
	pre->rchild=NULL;
}

void thbitre::preOrderthbitre()
{
	preOrder(root);
	cout<<endl;
}

void thbitre::preOrder(BTNode * & BT)
{
	if(BT!=NULL)
	{
		cout<<BT->data<<' ';
		preOrder(BT->lchild);
		preOrder(BT->rchild);
	}
}



void thbitre::preOrderTraverse_Thr()
{
	BTNode * current=root;
	while(current!=NULL)
	{
		cout<<current->data<<" ";
		if(current->LTag==0)
		{current=current->lchild;}
		else
		{current=current->rchild;}
	}
	cout<<endl;
}


void thbitre::inOrderThreading()
{
	BTNode * pre=NULL;//*pre指向當前結點前一結點
	inThreading(root,pre);
	pre->rchild=NULL;
}

void thbitre::inThreading(BTNode * &BT,BTNode *&pre)
{
	if(BT!=NULL)
	{
		if(BT->LTag==0)
			inThreading(BT->lchild,pre);
		if((pre!=NULL)&&(pre->RTag==1))
		{
			pre->rchild=BT;
		}
		if(BT->lchild==NULL)
		{
			BT->LTag=1;
			BT->lchild=pre;
		}
		if(BT->rchild==NULL)
			BT->RTag=1;
		pre=BT;
		if(BT->RTag==0)
			inThreading(BT->rchild,pre);
	}
}

void thbitre::preThreading(BTNode * &BT,BTNode *&pre)
{
	if(BT!=NULL)
	{
		if((pre!=NULL)&&(pre->RTag==1))
		{pre->rchild=BT;}
		if(BT->lchild==NULL)
		{
			BT->LTag=1;
			BT->lchild=pre;
		}
		if(BT->rchild==NULL)
			BT->RTag=1;
		pre=BT;
		if(BT->LTag==0)
			preThreading(BT->lchild,pre);
		if(BT->RTag==0)
			preThreading(BT->rchild,pre);
	}
}


void thbitre::inOrderTraverse_Thr()
{
	BTNode * current=root;
	bool Traversed;
	while(current!=NULL)
	{
		while(current->LTag==0)
			current=current->lchild;
		Traversed=true;
		while(current!=NULL&&Traversed)
		{
			cout<<current->data<<" ";
			current=current->rchild;
			if(current==NULL)
			   Traversed=false;
			else if(current->RTag==0)
		   { 
			   cout<<current->data<<" ";
			   Traversed=false;
			   current=current->rchild;
		   }
		}
	}
	cout<<endl;
}



void thbitre::postOrderThreading()
{
	BTNode * pre=NULL;//*pre指向當前結點前一結點
	postThreading(root,pre);
}

void thbitre::postThreading(BTNode * &BT,BTNode *&pre)
{
	if(BT!=NULL)
	{
		if(BT->LTag==0)
			postThreading(BT->lchild,pre);
		if(BT->RTag==0)
			postThreading(BT->rchild,pre);
		if((pre!=NULL)&&(pre->RTag==1))
		{pre->rchild=BT;}
		if(BT->lchild==NULL)
		{
			BT->LTag=1;
			BT->lchild=pre;
		}
		if(BT->rchild==NULL)
			BT->RTag=1;
		pre=BT;
	}
}


void thbitre::insert_Pre_Thr(char x)
{
	BTNode * ptr=new BTNode;
	ptr->data=x;
	ptr->LTag=1;
	ptr->RTag=1;
	BTNode * current=root->lchild;
	if(root==NULL)
	{
		cerr<<"error"<<endl;
		return;
	}
	else
	{
		while(current->rchild!=root->rchild&&current->rchild!=NULL)
		{
			if(current->LTag==0)
				current=current->lchild;
			else
				current=current->rchild;
		}
		ptr->lchild=current;
		ptr->rchild=current->rchild;
		current->rchild=ptr;
		current->RTag=0;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品视频在线看| 26uuu精品一区二区三区四区在线| 欧美伊人久久久久久午夜久久久久| 欧美日韩免费不卡视频一区二区三区| 日韩区在线观看| **欧美大码日韩| 日韩一区在线播放| 麻豆成人久久精品二区三区红| 99久久99久久免费精品蜜臀| 日韩三级高清在线| 亚洲午夜精品网| 99免费精品视频| 国产日韩欧美综合一区| 日本美女一区二区三区视频| 日本久久电影网| 亚洲色图视频网站| 国产精品亚洲午夜一区二区三区| 91精品国产高清一区二区三区蜜臀| 国产精品久久久久影视| 国产一区二区日韩精品| 日韩欧美在线综合网| 香蕉久久夜色精品国产使用方法| 精品三级在线观看| 天天综合色天天综合| 色琪琪一区二区三区亚洲区| 国产精品久久久99| 不卡一二三区首页| 中文字幕乱码亚洲精品一区| 国产一区二区毛片| 久久久久久久av麻豆果冻| 国产原创一区二区| 久久精品一二三| 国产成a人无v码亚洲福利| 久久日一线二线三线suv| 国产乱子轮精品视频| 精品对白一区国产伦| 国模大尺度一区二区三区| 欧美大片拔萝卜| 韩国精品免费视频| 国产午夜亚洲精品理论片色戒 | 免费av网站大全久久| 欧美日韩国产一区| 奇米四色…亚洲| 亚洲精品一区二区三区香蕉| 经典三级在线一区| 国产精品丝袜久久久久久app| 波多野结衣中文字幕一区二区三区| 国产精品天天看| 色中色一区二区| 亚洲成av人在线观看| 91精品国产麻豆| 国产一区二区在线视频| 国产精品激情偷乱一区二区∴| 不卡在线观看av| 亚洲mv在线观看| 精品噜噜噜噜久久久久久久久试看| 国产九色sp调教91| 亚洲激情中文1区| 欧美一区二区三区啪啪| 国产米奇在线777精品观看| 中文字幕一区二区三区四区不卡 | 久久99精品国产.久久久久久| 欧美变态tickling挠脚心| 国产成人av电影在线| 亚洲蜜桃精久久久久久久| 777亚洲妇女| 成人小视频免费在线观看| 一区二区三区蜜桃| 精品三级av在线| 一本色道久久加勒比精品| 日本欧美大码aⅴ在线播放| 欧美国产激情二区三区| 欧美日韩精品高清| 国产suv精品一区二区三区| 亚洲国产精品综合小说图片区| 精品成人一区二区| 国产色一区二区| 91国产精品成人| 国产成人综合自拍| 日韩精品色哟哟| 国产精品久久久久久久浪潮网站| 欧美丰满少妇xxxxx高潮对白| 国产不卡视频在线播放| 日韩有码一区二区三区| 中文一区二区在线观看| 日韩一级片在线观看| 色婷婷综合久久久中文一区二区 | 粉嫩13p一区二区三区| 亚洲一区在线视频| 中文av一区特黄| 精品国产一区二区三区久久久蜜月 | 欧美精品色一区二区三区| 不卡的电影网站| 久久电影网站中文字幕| 亚洲va国产天堂va久久en| 国产精品久久久久毛片软件| 久久综合九色综合97婷婷女人| 欧美日本一区二区在线观看| 99精品在线免费| 高清国产一区二区| 精品中文字幕一区二区| 日本成人在线网站| 亚洲国产中文字幕在线视频综合| 中文字幕视频一区| 亚洲国产激情av| 久久久激情视频| 久久免费电影网| 久久一日本道色综合| 日韩精品一区二区三区视频在线观看| 欧美日韩另类一区| 日韩一区欧美一区| 久久精品国产澳门| 午夜免费久久看| 亚洲国产wwwccc36天堂| 综合在线观看色| 亚洲欧美日韩国产综合在线| 中文av一区特黄| 国产精品二三区| 亚洲免费视频成人| 亚洲视频一区在线| 亚洲综合一区在线| 午夜av电影一区| 久久精品国产秦先生| 另类欧美日韩国产在线| 九色porny丨国产精品| 韩国欧美一区二区| 成人在线视频一区| 99国产精品视频免费观看| 91免费国产在线观看| 欧美午夜精品电影| 欧美一区二区三级| 久久综合色综合88| 国产精品视频在线看| 亚洲欧美日韩国产成人精品影院| 亚洲欧美色图小说| 午夜精品久久久久久久99水蜜桃| 蜜臀av性久久久久蜜臀aⅴ四虎| 精品制服美女久久| a亚洲天堂av| 国产日韩欧美综合在线| 亚洲欧洲精品一区二区三区| 一区二区三区在线视频观看58| 视频在线观看91| 国产成人高清在线| 欧美亚洲动漫另类| 久久嫩草精品久久久精品一| 中文字幕一区二区在线播放| 亚洲第一激情av| 国产福利一区二区三区视频| 91麻豆自制传媒国产之光| 91精品婷婷国产综合久久性色 | 久久久久久久综合狠狠综合| 国产精品成人一区二区三区夜夜夜| 亚洲精品成人少妇| 理论片日本一区| 色综合色狠狠综合色| 日韩一区二区免费在线观看| 国产精品午夜在线观看| 秋霞电影网一区二区| 成人激情图片网| 日韩一区二区在线播放| 最新日韩av在线| 激情国产一区二区 | 国产乱码字幕精品高清av| 日本道在线观看一区二区| 日韩精品中文字幕在线一区| 日韩美女视频一区二区| 国产一区在线精品| 精品视频色一区| 中文字幕日韩av资源站| 精品一区二区三区久久| 欧美日韩在线观看一区二区| 久久久91精品国产一区二区精品| 午夜在线成人av| 色综合久久久久| 国产精品情趣视频| 精品一区二区三区在线播放视频| 91麻豆国产在线观看| 国产欧美日韩亚州综合| 免费高清成人在线| 欧美日韩国产小视频在线观看| 国产精品超碰97尤物18| 黄色精品一二区| 欧美成人午夜电影| 日韩精品亚洲一区| 欧美日韩一卡二卡三卡| 又紧又大又爽精品一区二区| 成人免费视频caoporn| 亚洲精品在线免费播放| 久久99精品国产麻豆婷婷| 在线综合+亚洲+欧美中文字幕| 一片黄亚洲嫩模| 欧美在线影院一区二区| 亚洲免费在线观看视频| 日本韩国欧美在线| 一区二区三区四区高清精品免费观看 | 欧美成人猛片aaaaaaa| 日韩高清中文字幕一区| 欧美日韩精品免费| 天堂午夜影视日韩欧美一区二区|