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

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

?? rbtrees.cpp

?? 四個小算法。紅黑樹
?? CPP
字號:
#include "stdlib.h"
#include "stdio.h"
#include "time.h"
#define BLACK 0
#define RED 1

struct node{
	int low;
	int high;
	int max;
	node *left;
	node *right;
	node *parent;
	int color;
};
node * left_rotate(node *root,node *z);
node * right_rotate(node *root,node *z);
node * RB_insert(node *root,node *z);
node * insert_fixup(node *root,node *z);
node *RB_delete(node *root,node *z);
node *delete_fixup(node *root,node *z);
node *tree_successor(node *z);
node *tree_minimun(node *z);
node *interval_search(node *root,int low ,int high);
int adjustmax(node *root);
void display(node *root);
node *search(node *root,int value);
node *NIL,*root;
FILE *outfile;
node * left_rotate(node *root,node *x){
	node *y;
	y=x->right;
	x->right=y->left;
	y->left->parent=x;
	y->parent=x->parent;
	if(x->parent==NIL){
		root=y;
	}
	else if(x==x->parent->left){
		x->parent->left=y;
	}
	else 
		x->parent->right=y;
	y->left=x;
	x->parent=y;
	return root;
}
node * right_rotate(node *root,node *x){
	node *y=x->left;
	x->left=y->right;
	y->right->parent=x;
	if(x->parent==NIL){
		root=y;
	}
	else if(x==x->parent->left){
		x->parent->left=y;
	}
	else x->parent->right=y;
	y->right=x;
	x->parent=y;
	return root;
}
node *RB_insert(node *root, node *z){
	node *x,*y;
	y=NIL;
	x=root;
	while(x!=NIL){
		y=x;
		if(x!=root){
			fprintf(outfile,"(%d %d) parent %d ",x->low,x->high,x->parent->low);			
		}
		else{
			fprintf(outfile,"(%d %d) root ",x->low,x->high);
		}
		if(x->color==BLACK){
			fprintf(outfile," black\n");
		}
		else{
			fprintf(outfile," red\n");
		}
		if(z->low<x->low){
			fprintf(outfile,"go left:");
			x=x->left;
		}
		else{
			fprintf(outfile,"go right:");
			x=x->right;
		}
	}
	z->parent=y;
	if(y==NIL){
		fprintf(outfile,"(%d %d) root\n",z->low,z->high);
		root=z;
	}
	else {
		fprintf(outfile,"insert(%d %d)\n",z->low,z->high);
		if(z->low<y->low){
		y->left=z;
		}
		else{
			y->right=z;
		}
	}
	root=insert_fixup(root,z);
	return root;
}
node * insert_fixup(node *root,node *z){
	fprintf(outfile,"insert fix up\n");
	while(z->parent!=NIL&&z->parent->color==RED){
		node *parent,*grand,*uncle;
		parent=z->parent;
	    grand=parent->parent;
		fprintf(outfile,"(%d %d) parent %d\n ",z->low,z->high,z->parent->low);
		if(parent==grand->left){
			uncle=grand->right;
			if(uncle->color==RED){
				parent->color=BLACK;
				uncle->color=BLACK;
				grand->color=RED;
				z=grand;
			//	printf("case 1\n");
			}
			else if(z==parent->right){
				z=parent;
			//	printf("case 2\n");
				root=left_rotate(root,z);
			}
			else{
				parent->color=BLACK;
				grand->color=RED;
				root=right_rotate(root,grand);
			//	printf("case 3\n");
			}
		}
		else{
			uncle=grand->left;
			if(uncle->color==RED){
		//		printf("case 1\n");
				parent->color=BLACK;
				uncle->color=BLACK;
				grand->color=RED;
				z=grand;
			}
			
			else if(z==parent->left){
		//		printf("case 2\n");
				z=parent;
				right_rotate(root,z);
			}
			else{
		//		printf("case 3\n");
				parent->color=BLACK;
				grand->color=RED;
				left_rotate(root,grand);
			}
		}
	}
	root->color=BLACK;
	return root;
}
void display(node *root){
	printf("the node information of the tree is\n");
	node *z;
	int len=0;
	node *queue[10];
	queue[0]=root;
	if(root!=NIL){
		len=1;
	}
	while(len>=1){
		int i=0;
		z=queue[0];
		len--;
		for(i=0;i<len;i++){
			queue[i]=queue[i+1];
		}
		if(z!=root){ 
			if(z->color==BLACK)
				printf("(%d %d) black max is %d parent's low is %d\n",z->low ,z->high,z->max,z->parent->low);
			else
				printf("(%d %d) red max is %d parent's low is %d\n",z->low ,z->high,z->max,z->parent->low);
		}
		else{
			if(z->color==BLACK)
				printf("(%d %d) black max is %d root\n",z->low ,z->high,z->max);
			else
				printf("(%d %d) red max is %d root\n",z->low ,z->high,z->max);
		}
		if(z->left!=NIL){
			queue[len]=z->left;
			len++;
		}
		if(z->right!=NIL){
			queue[len]=z->right;
			len++;
		}
	}
}
node *search(node *root,int value){

	while(root!=NIL&&root->low!=value){
		if(root->low<value){
			root=root->right;
		}
		else{
			root=root->left;
		}
	}
	return root;
}
int adjustmax(node *root){
	node *x=root;
	int max_left(0),max_right(0),max(0);
	if(x!=NIL){
		if(x->left!=NIL){
			max_left=x->left->max;
			if(max_left<0){
				max_left=adjustmax(x->left);
			}
		}
		if(x->right!=NIL){
			max_right=x->right->max;
			if(max_right<0){
				max_right=adjustmax(x->right);
			}
		}
		max=root->high;
		if(max_left>max){
			max=max_left;
		}
		if(max_right>max)
			max=max_right;
	}
	root->max=max;
	return max;
}
node *tree_successor(node *z){
	if(z->right!=NIL){
		return tree_minimun(z->right);
	}
	node *y;
	y=z->parent;
	while(y!=NIL&&z==y->right){
		z=y;
		if(z!=root){ 
			if(z->color==BLACK)
				fprintf(outfile,"(%d %d) black max is %d parent's low is %d\n",z->low ,z->high,z->max,z->parent->low);
			else
				fprintf(outfile,"(%d %d) red max is %d parent's low is %d\n",z->low ,z->high,z->max,z->parent->low);
		}
		else{
			if(z->color==BLACK)
				fprintf(outfile,"(%d %d) black max is %d root\n",z->low ,z->high,z->max);
			else
				fprintf(outfile,"(%d %d) red max is %d root\n",z->low ,z->high,z->max);
		}
		y=y->parent;
	}
	return y;
}
node *tree_minimun(node *z){
	while(z->left!=NIL){
		z=z->left;
	}
	return z;
}
node *RB_delete(node *root,node *z){
	node *y,*x;
	fprintf(outfile,"\ndelete node (%d %d)\n",z->low ,z->high);
	if(z!=root){ 
		if(z->color==BLACK)
			fprintf(outfile,"(%d %d) black  parent %d\n",z->low ,z->high,z->parent->low);
		else
			fprintf(outfile,"(%d %d) red  parent %d\n",z->low ,z->high,z->parent->low);
	}
	else{
		if(z->color==BLACK)
			fprintf(outfile,"(%d %d) black max is %d root\n",z->low ,z->high,z->max);
		else
			fprintf(outfile,"(%d %d) red max is %d root\n",z->low ,z->high,z->max);
	}
	if(z->left==NIL||z->right==NIL){
		y=z;
	}
	else y=tree_successor(z);
	if(y->left!=NIL){
		x=y->left;
	}
	else {
		x=y->right;
	}
	x->parent=y->parent;
	if(y->parent==NIL){
		root=x;
	}
	else if(y==y->parent->left){
		y->parent->left=x;
	}
	else{
		y->parent->right=x;
	}
	if(y!=z){
		z->low=y->low;
		z->high=y->high;
	}
	if(y->color==BLACK){
		root=delete_fixup(root,x);
	}
	else{
		fprintf(outfile,"it dosn't need to fix up\n");
	}
	return root;
}
node *delete_fixup(node *root,node *x){
	node *w;
	fprintf(outfile,"delete fix up\n");
	while(x!=root&&x->color==BLACK){
		if(x==x->parent->left){
			w=x->parent->right;
			if(w->color==RED){
				w->color=BLACK;
				x->parent->color=RED;
				root=left_rotate(root,x->parent);
			}
			if(w->left->color==BLACK&&w->right->color==BLACK){
				w->color=RED;
				x=x->parent;
			}
			else if(w->right->color==BLACK){
				w->left->color=BLACK;
				w->color=RED;
				root=right_rotate(root,w);
				w=x->parent->right;
			}
			else{
				w->color=x->parent->color;
				x->parent->color=BLACK;
				w->right->color=BLACK;
				root=left_rotate(root,x->parent);
				x=root;
			}
		}
		else if(x=x->parent->right){
			w=x->parent->left;
			if(w->color==RED)
			{
				w->color=BLACK;
				x->parent->color=RED;
				root=right_rotate(root,x->parent);
				w=x->parent->left;
			}
			if((w->right->color==BLACK)&(w->left->color==BLACK))
			{
				w->color=RED;
				x=x->parent;
			}
			else if(w->left->color==BLACK)
			{
				w->right->color=BLACK;
				w->color=RED;
				root=left_rotate(root,w);
				w=x->parent->left;
			}
			else
			{
				w->color=x->parent->color;
				x->parent->color=BLACK;
				w->left->color=BLACK;
				root=right_rotate(root,x->parent);
				x=root;
			}
		}
		fprintf(outfile,"(%d %d) black parent %d\n",x->low,x->high,x->parent->low);
		if(w->color==BLACK){
			fprintf(outfile,"(%d %d) black parent %d\n ",w->low,w->high,w->parent->low);
		}
		else {
			fprintf(outfile,"(%d %d) red parent %d\n ",w->low,w->high,w->parent->low);
		}
	}
	x->color=BLACK;
	return root;
}

node* interval_search(node *root ,int low ,int high){
	node *x=root;
	bool overlap=false;
	if(x->low<high&&x->high>low){
		overlap=true;
	}
	while(x!=NIL&&overlap==false){
		if(x->left!=NIL&&x->left->max>=low){
			x=x->left;
		}
		else{
			x=x->right;
		}
		if(x->low<high&&x->high>low){
			overlap=true;
		}
	}
	if(x!=NIL){
	fprintf(outfile,"the node (%d %d) of the tree overlap the interval (%d %d)\n",x->low,x->high,low,high);
	}
	else{
		fprintf(outfile,"there isn't a node in the tree overlap the interval (%d %d)\n",low,high);
	}
	return x;
}

int main(){
	int i,j,num(0);
	node *z;
	NIL=(node *)malloc(sizeof(node));
	NIL->color=BLACK;
	NIL->low=0;
	NIL->high=0;
	NIL->max=0;
	NIL->left=NIL;
	NIL->right=NIL;
	NIL->parent=NIL;
	root=NIL;
	outfile=fopen("1073.out","wb");
    int interval[10][2]={{16,21},{8,9},{25,30},{5,8},{15,23},{17,19}, {26,26},{0,3},{6,10},{19,20}};
//	int interval[10][2]={{16,21},{8,9},{5,8},{15,23},{25,30}, {26,26},{0,3},{17,19}};
	fprintf(outfile,"%s\n","all the operation are based on the follow intervals");
	for(i=0;i<10;i++){
		if(interval[i][0]!=0||interval[i][1]!=0){
			num++;
			fprintf(outfile,"(%d %d)  ",interval[i][0],interval[i][1]);
		}
	}
	fprintf(outfile,"%c",'\n');
	for(i=0;i<num;i++){
		fprintf(outfile,"\ninsert node (%d %d)\n",interval[i][0],interval[i][1]);
		z=(node *)malloc(sizeof(node));
		z->color=RED;
		z->low=interval[i][0];
		z->high=interval[i][1];
		z->max=-1;
		z->left=NIL;
		z->right=NIL;
		z->parent=NIL;
		root=RB_insert(root,z);
	//	printf("root is (%d %d)\n",root->low,root->high);
	}
	adjustmax(root);
	printf("after insertion, ");
	display(root);
	srand(time(0));
	i=j=0;
	while(i==j){
		i=rand()%num;
		j=rand()%num;
	}
//	printf("%d %d\n",i,j);
//	fprintf(outfile,"\nsearch the node (%d %d)\n",interval[i][0],interval[i][1]);
	z=search(root,interval[i][0]);
    printf("\n\ndelete node (%d %d)\n",z->low,z->high);
	root=RB_delete(root,z);
	z=search(root,interval[j][0]);
	printf("delete node (%d %d)\n",z->low,z->high);
	root=RB_delete(root,z);
	adjustmax(root);
	printf("after deletion, ");
	display(root);
	fprintf(outfile,"\nsearch interval (8 25)\n");
	interval_search(root,8,25);
	printf("\nthe more information has been writen into a text file\n");
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品夜色噜噜亚洲aⅴ| 亚洲成a人片在线观看中文| 亚洲乱码一区二区三区在线观看| 五月综合激情婷婷六月色窝| proumb性欧美在线观看| 欧美草草影院在线视频| 一区二区在线观看视频在线观看| 国产一区二区三区高清播放| 欧美一区二区三区视频在线| 亚洲一区中文在线| av在线不卡观看免费观看| 久久先锋资源网| 蜜桃精品在线观看| 欧美精品aⅴ在线视频| 一区二区三区免费观看| av资源网一区| 中文字幕中文在线不卡住| 国产a精品视频| www国产成人| 国产在线播放一区| 日韩欧美一二三| 日韩av一区二区在线影视| 欧美色国产精品| 亚洲国产精品久久人人爱蜜臀| 91在线云播放| 亚洲免费观看高清完整版在线观看熊 | 亚洲妇女屁股眼交7| 一本在线高清不卡dvd| 国产精品毛片久久久久久| 懂色av一区二区三区免费看| 久久综合精品国产一区二区三区| 狠狠色2019综合网| 久久综合九色综合97婷婷女人| 精品在线视频一区| 久久久国产一区二区三区四区小说 | 日韩一级片在线观看| 天堂久久久久va久久久久| 91精品国产综合久久精品图片| 日韩在线一区二区| 69堂亚洲精品首页| 精品一区二区日韩| 久久久国产一区二区三区四区小说| 国产原创一区二区| 国产精品青草综合久久久久99| 99久免费精品视频在线观看| 亚洲夂夂婷婷色拍ww47| 51精品视频一区二区三区| 久久精品国产亚洲5555| 久久精品亚洲一区二区三区浴池| 福利电影一区二区三区| 亚洲综合在线电影| 欧美一区二区三区的| 久久99精品久久久久久| 国产精品女主播av| 91黄色免费网站| 蜜臂av日日欢夜夜爽一区| 国产亚洲欧美日韩在线一区| 91麻豆精品在线观看| 日本欧美加勒比视频| 国产亚洲综合av| 欧美亚洲一区二区在线观看| 久久99精品国产麻豆不卡| 国产精品天干天干在线综合| 欧美色图激情小说| 国产精品一二三在| 亚洲电影在线播放| 亚洲国产成人自拍| 欧美精品一卡两卡| 成人免费毛片高清视频| 亚洲成人激情av| 国产精品视频线看| 欧美一区2区视频在线观看| 成人自拍视频在线观看| 日日夜夜免费精品| 亚洲人成小说网站色在线 | 美女mm1313爽爽久久久蜜臀| 国产精品久久久久天堂| 日韩免费一区二区| 91免费视频观看| 国产精品综合久久| 亚洲1区2区3区视频| 国产欧美一区二区精品久导航 | 精品国产乱码久久久久久图片| 91色porny在线视频| 国产一区999| 免费观看91视频大全| 亚洲精选一二三| 国产精品欧美精品| 久久夜色精品国产噜噜av | 色先锋aa成人| 丁香婷婷综合色啪| 精品一区二区三区在线播放视频| 亚洲bdsm女犯bdsm网站| 亚洲天堂免费在线观看视频| 久久久久久日产精品| 欧美一级视频精品观看| 欧美日韩久久不卡| 色美美综合视频| 成人精品国产免费网站| 国产精品一级黄| 激情图片小说一区| 裸体歌舞表演一区二区| 日韩中文字幕一区二区三区| 亚洲一区二区影院| 一区二区三区日韩精品视频| 亚洲少妇30p| 亚洲美女少妇撒尿| 亚洲精品第一国产综合野| 中文字幕在线观看不卡| 国产精品网站在线观看| 亚洲国产电影在线观看| 国产精品乱码妇女bbbb| 国产精品素人一区二区| 国产精品免费av| 国产精品久久网站| 亚洲欧洲av在线| 亚洲卡通欧美制服中文| 亚洲高清免费观看| 日韩精品福利网| 久久www免费人成看片高清| 另类小说图片综合网| 国内成人免费视频| 国产福利91精品| 9人人澡人人爽人人精品| 99riav久久精品riav| 欧美中文字幕一二三区视频| 欧美三级日韩三级国产三级| 91麻豆精品国产91久久久久久 | 亚洲色图.com| 日韩欧美一级二级三级| 久久夜色精品一区| 中文字幕在线一区免费| 伊人色综合久久天天人手人婷| 亚洲超碰97人人做人人爱| 全国精品久久少妇| 国产精品66部| 91在线国产福利| 欧美片网站yy| 国产视频一区二区在线| 亚洲欧美成aⅴ人在线观看 | 欧美日韩免费一区二区三区视频| 欧美日韩亚洲综合在线 | 91精品国产综合久久久久久| 久久综合久久综合九色| 亚洲人成人一区二区在线观看 | 欧美www视频| 国产精品国产三级国产aⅴ中文| 亚洲电影欧美电影有声小说| 国产一区二区网址| 在线这里只有精品| 久久久久久久久岛国免费| 一区二区三区日韩精品视频| 精油按摩中文字幕久久| 91黄视频在线| 国产欧美一区二区三区在线看蜜臀 | 欧美午夜精品久久久| 精品国产免费人成电影在线观看四季| 国产精品卡一卡二| 免费欧美高清视频| 色婷婷综合中文久久一本| 欧美精品一区二区三区四区| 一区二区三区四区五区视频在线观看| 黄色成人免费在线| 欧美日韩一区 二区 三区 久久精品| 久久久久九九视频| 日韩高清国产一区在线| 91在线丨porny丨国产| 精品久久久久久久人人人人传媒| 亚洲婷婷综合色高清在线| 久久99日本精品| 欧美精品xxxxbbbb| 亚洲免费在线观看视频| 国产精品原创巨作av| 6080yy午夜一二三区久久| 亚洲精品v日韩精品| 国产成人av电影| 欧美zozo另类异族| 日韩av一二三| 欧美日韩精品欧美日韩精品一 | 91极品视觉盛宴| 日本一区二区成人| 国产在线看一区| 日韩一区二区三区电影在线观看| 亚洲综合视频在线观看| 色婷婷综合久久久久中文一区二区| 欧美经典一区二区三区| 精品亚洲成a人| 欧美videos中文字幕| 天天射综合影视| 欧美人妇做爰xxxⅹ性高电影| 一级女性全黄久久生活片免费| 成人av免费在线| 国产精品日韩成人| 成人午夜av在线| 国产精品国产馆在线真实露脸| 国产精品88av| 国产精品天美传媒| 99久久国产综合色|国产精品| 国产精品免费免费| 色综合中文综合网|