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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? bptree.java

?? 詳細(xì)介紹了Btree的特性以及如何實(shí)現(xiàn) 適合初學(xué)者參考
?? JAVA
?? 第 1 頁 / 共 2 頁
字號(hào):
package BpTree;


class Elem
{
	Comparable key;
	Object obj;
	
	public Elem(Comparable k, Object o)
	{
		key = k;
		obj = 0;
	}

	public String toString()
	{
		return ""+key;
	}
}
class Pair
{
	Comparable key;
	Object pointer;
	
	public Pair(Comparable k, Object p)
	{
		key = k;
		pointer = p;
	}
	public String toString()
	{
		return "["+ key+", "+pointer+"]";
	}

}
class BpNode
{
	private boolean isLeaf;
	
	public static boolean LEAF = true;
	public static boolean NONLEAF = false;

	
	private final int MAXREC;

	public int count;
	Pair[] recArray;
	public BpNode leftSibling, rightSibling;
	
	
	public BpNode(boolean leaf, int max)	//	leaf == 1:leaf node ; leaf == 0:non_leaf node
	{
		MAXREC = max;
		recArray = new Pair[MAXREC];
		recArray[0] = new Pair(Integer.MIN_VALUE, null);
		count = 1;
		leftSibling = rightSibling = null;	
		
		if(leaf == LEAF)
		{
			isLeaf = true;			
		}
		else
		{
			isLeaf = false;
		}
		
		
	}

	
	public int maxLE(Comparable tar)
	{
		int result;
		for(result=1; result<count; result++)
		{
			if(recArray[result].key.compareTo(tar) > 0)
				break;			
		}
		return result-1;		
	}
	public void merge(BpNode other)
	{
		if(isLeaf)
		{
		for(int i=0; i<other.count-1; i++)
		{
			this.recArray[count+i] = other.recArray[i+1];
			
		}
		this.count = this.count + other.count-1;
		other.count = 1;		
		this.rightSibling = other.rightSibling;
		if(other.rightSibling != null)
			other.rightSibling.leftSibling = this;
		}		
		
		else
		{
			BpNode first = (BpNode)other.recArray[0].pointer;
			BpNode current = first;
			while(!current.isLeaf)	//	找到other節(jié)點(diǎn)一下最小的key值
				current = (BpNode)current.recArray[0].pointer;
			
			Pair tmp = new Pair(current.recArray[1].key, first);
			this.recArray[count] = tmp;
			for(int i=0; i<other.count-1; i++)
			{
				this.recArray[count +i +1] = other.recArray[i+1];
			}
			this.count = this.count + other.count;
			other.count = 1;	
			this.rightSibling = other.rightSibling;
			if(other.rightSibling != null)
				other.rightSibling.leftSibling = this;
		}
	}
	
	public void shuffle(BpNode other)
	{
		if(isLeaf)
		{
			Pair[] bigArr = new Pair[2*MAXREC];
			int i;
			for(i=0; i<this.count-1; i++)
				bigArr[i] = this.recArray[i+1];
			for(int j=0;j<other.count-1; j++)
			{
				bigArr[j+i] = other.recArray[j+1];
			}
			int max = this.count + other.count-2;
			
			BpNode new1 = new BpNode(this.isLeaf,this.MAXREC);
			BpNode new2 = new BpNode(this.isLeaf,this.MAXREC);
			
			int k;
			for(k = 0; k< (max+1)/2; k++)
			{
				new1.recArray[k+1] = bigArr[k];
				new1.count++;
			}
			for(int l=0; l<max/2; l++)
			{
				new2.recArray[l+1] = bigArr[l+k];
				new2.count++;
			}
			
			this.count = new1.count;
			this.recArray = new1.recArray;
			other.count = new2.count;
			other.recArray = new2.recArray;
		}
		
		else
		{	
			Pair[] bigArr = new Pair[2*MAXREC];
			
			for(int i=0; i<this.count; i++)
				bigArr[i] = this.recArray[i];
			
			BpNode first = (BpNode)other.recArray[0].pointer;
			BpNode current = first;
			while(!current.isLeaf)
				current = (BpNode)current.recArray[0].pointer;
			Pair tmp = new Pair(current.recArray[1].key, first);
					
			bigArr[this.count] = tmp;
			
			for(int i=0; i<other.count-1; i++)
			{
				bigArr[this.count +1+i] = other.recArray[i+1];
			}
			
			int max = this.count + other.count;
			
			BpNode new1 = new BpNode(this.isLeaf,this.MAXREC);
			BpNode new2 = new BpNode(this.isLeaf,this.MAXREC);
			
			
			int i;
			new1.count--;
			for(i=0; i< (max+1)/2; i++)
			{
				new1.recArray[i] = bigArr[i];
				new1.count++;
			}
			for(int l=0; l<max/2; l++)
			{
				new2.recArray[l+1] = bigArr[l+i];
				new2.count++;
			}
			

			Pair temp = new1.recArray[--new1.count];
			new1.recArray[new1.count] = null;
			new2.recArray[0].pointer = temp.pointer;

			this.count = new1.count;
			this.recArray = new1.recArray;
			other.count = new2.count;
			other.recArray = new2.recArray;			
		}		
	}
	public void addAfter(int currec, Pair p)
	{
		for(int i = count; i>currec+1; i--)
			recArray[i] = recArray[i-1];
		recArray[currec+1] = p;
		count++;
	}
	//	刪除recArray在index位置的元素,count--
	//	目標(biāo)后元素順序前移
	public void deleteAt(int index)
	{
		for(int i=index; i<count-1; i++)
			recArray[i] = recArray[i+1];
		recArray[--count] = null;
	}
	
	
	//	函數(shù)split(index, tar)將tar加入到當(dāng)前節(jié)點(diǎn),index是tar在recArray中的位置
	//	過程中,當(dāng)前節(jié)點(diǎn)分裂為兩個(gè)節(jié)點(diǎn),分別接受原節(jié)點(diǎn)一半元素,新的節(jié)點(diǎn)被返回
	
	public BpNode split(int index, Pair tar)
	{
		Pair[] bigArr = new Pair[2 * MAXREC];
		
		int i;
		for(i=0;i<count-1;i++)
		{
			if(i==index)
				break;
			else
			{
				bigArr[i] = recArray[i+1];
			}
		}
		bigArr[i] = tar;
		for(int j=i+1; j< recArray.length; j++)
		{
			bigArr[j] = recArray[j];
		}
		
		BpNode new1 = new BpNode(this.isLeaf,this.MAXREC);	
		BpNode new2 = new BpNode(this.isLeaf,this.MAXREC);
		
		int k;
		for(k=0; k< MAXREC/2; k++)
		{
			new1.recArray[k+1] = bigArr[k];
			new1.count++;
		}
		for(int l=k; l<MAXREC; l++)
		{
			new2.recArray[l-k+1] = bigArr[l];
			new2.count++;
		}
		new1.recArray[0].pointer = this.recArray[0].pointer;
		
		new2.leftSibling = this;
		new2.rightSibling = this.rightSibling;
		if(this.rightSibling != null)
			this.rightSibling.leftSibling = new2;
		this.rightSibling = new2;
		
		
		//	當(dāng)前葉節(jié)點(diǎn)更新
		this.count = new1.count;
		this.recArray = new1.recArray;
		
		return new2;	
	}

	public String toString()
	{
		String res = "";
		
		for(int i=1; i<count; i++)
			res += recArray[i].key +",";

		return "『"+ res.substring(0, res.lastIndexOf(',')) +"』";
	}
	
	
	public boolean canMerge(BpNode other)
	{
		if(isLeaf)
		{
			return (this.count + other.count -1) <= MAXREC;
		}
		else
		{
			return (this.count + other.count) <= MAXREC;
		}
	}
	
	public boolean isLeaf()
	{
		return isLeaf;
	}
	public boolean isFull()
	{
		return count == MAXREC;
	}

	public boolean isBigEnough()
	{
		if(isLeaf)
		{
			return ((count-1) >= MAXREC/2);
		}
		else
		{
			return (count >= (MAXREC+1)/2);			
		}
	}
}

public class BpTree
{
	private BpNode root;
	final int DEGREE;
	
	
	public BpTree()
	{		
		root = null;
		DEGREE=4;
	}
	public BpTree(int degree)
	{
		root = null;
		DEGREE = degree;
	}
	
	
	public void insert(Comparable key)
	{
//		System.out.println("Inserting "+ key+"...");
		Elem tmp = new Elem(key,null);
		insert(tmp);
	}
	
	public void insert(Elem rec)
	{
		if(root == null)
		{
			root = new BpNode(BpNode.LEAF,DEGREE);
			Pair newP = new Pair(rec.key, rec);
			root.recArray[1] = newP;
			root.count++;
		}
		else
		{
			Pair p = insertHelp(root, rec);
			if(p != null)
			{
				BpNode tmp = new BpNode(BpNode.NONLEAF,DEGREE);
				tmp.recArray[0].pointer = root;
				tmp.recArray[1] = p;
				tmp.count++;
				root = tmp;				
			}			
		}
	}
	
	
	public void remove(Comparable k)
	{
//		System.out.println("Removing "+ k +"...");
		int currec = root.maxLE(k);
		if(root.isLeaf())
		{
			if(root.recArray[currec].key.equals(k))
				root.deleteAt(currec);
			if(root.count == 1)
				root = null;
		}            
		else                                                             
		{
			currec = removeHelp( (BpNode)root.recArray[currec].pointer, k, currec);
			
			if(currec == -1)
				return;
			else if(((BpNode)root.recArray[currec].pointer).count > 1)
			{	//	子結(jié)點(diǎn)重組了,更新相關(guān)節(jié)點(diǎn)
/*				root.recArray[currec].key = 
					((BpNode)root.recArray[currec].pointer).recArray[1].key;
*/				
				BpNode current = (BpNode)root.recArray[currec].pointer;
				
				while(!current.isLeaf())
				{
					current = (BpNode)current.recArray[0].pointer;
				}
				root.recArray[currec].key =
					current.recArray[1].key;
				
				return;				
			}
			
			root.deleteAt(currec);
			
			if(root.count >1)
				return;
			else		//	可能有問題
			{
				root = (BpNode)root.recArray[0].pointer;
				return;
			}
			
		}
		
	}
	
	private int removeHelp(BpNode node, Comparable k, int thispos)
	{
		int currec = node.maxLE(k);
		
		if(node.isLeaf())
		{
			if(!node.recArray[currec].key.equals(k))
				return -1;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲电影激情视频网站| 亚洲免费三区一区二区| 99re热这里只有精品视频| 天堂成人免费av电影一区| 日本一区二区视频在线观看| 欧美精品一二三| 99国产精品99久久久久久| 激情久久五月天| 五月激情丁香一区二区三区| 亚洲欧美综合网| 26uuu精品一区二区三区四区在线| 日本高清成人免费播放| 成人性色生活片| 国产一区啦啦啦在线观看| 香蕉成人伊视频在线观看| 亚洲欧洲精品成人久久奇米网| 精品三级av在线| 制服.丝袜.亚洲.中文.综合| 91极品美女在线| 成人午夜视频在线观看| 理论片日本一区| 日日欢夜夜爽一区| 亚洲第一精品在线| 亚洲一区二区三区视频在线播放 | 国产一区亚洲一区| 日日夜夜一区二区| 亚洲国产精品嫩草影院| 一区av在线播放| 亚洲综合免费观看高清完整版| 国产精品色眯眯| 国产精品女主播在线观看| 国产日产欧美一区二区视频| 久久综合久久综合久久| 91精品国产色综合久久不卡蜜臀 | 在线视频你懂得一区| 成人免费av网站| 成人av电影免费观看| 成人国产精品免费| 精品久久久久久久久久久院品网| 欧美精品在欧美一区二区少妇| 日本高清无吗v一区| 在线中文字幕一区二区| 色综合欧美在线视频区| 色综合久久66| 欧美色精品在线视频| 欧美色区777第一页| 欧美日韩一区二区在线观看| 在线不卡的av| 欧美巨大另类极品videosbest| 911精品国产一区二区在线| 欧美剧在线免费观看网站| 欧美一区二区成人6969| 精品播放一区二区| 久久精品一区蜜桃臀影院| 中文字幕乱码一区二区免费| 亚洲三级在线观看| 偷窥国产亚洲免费视频| 精东粉嫩av免费一区二区三区| 国产精品一区在线观看乱码| 成人免费毛片aaaaa**| a美女胸又www黄视频久久| 欧美中文一区二区三区| 91精品国产欧美一区二区18| 欧美电影免费提供在线观看| 中文字幕欧美三区| 亚洲国产视频一区二区| 免费黄网站欧美| 高清不卡一二三区| 欧美日韩精品一区视频| www精品美女久久久tv| 亚洲图片你懂的| 蜜臀国产一区二区三区在线播放| 国产精品一区二区久久精品爱涩| 91麻豆123| 精品欧美一区二区三区精品久久| 国产精品毛片高清在线完整版| 亚洲猫色日本管| 精品午夜久久福利影院 | 国产麻豆视频一区| 99久久er热在这里只有精品66| 欧美日韩国产一级| 国产欧美一区二区三区鸳鸯浴| 亚洲欧美国产高清| 激情综合色综合久久| 91在线小视频| 亚洲精品在线网站| 亚洲午夜精品在线| 高清不卡在线观看| 欧美放荡的少妇| 亚洲欧美在线aaa| 国产一区二区三区国产| 欧美日韩免费高清一区色橹橹| 国产欧美一区二区精品仙草咪| 亚洲第一主播视频| 99国内精品久久| 久久―日本道色综合久久| 性欧美大战久久久久久久久| 福利一区在线观看| 精品乱人伦小说| 亚洲成av人片一区二区梦乃| 99久久99久久免费精品蜜臀| 欧美精品一区二区三区很污很色的| 一区二区视频在线看| 国产成都精品91一区二区三| 日韩小视频在线观看专区| 亚洲一区二区精品久久av| 国产69精品久久久久毛片| 日韩欧美一二三四区| 亚洲与欧洲av电影| 99久久久免费精品国产一区二区| 久久婷婷成人综合色| 日日骚欧美日韩| 欧美三级视频在线| 一区二区三区四区国产精品| 波多野结衣中文字幕一区| 久久毛片高清国产| 黄色日韩三级电影| 欧美一区二区三区白人| 日韩精品91亚洲二区在线观看 | 久久国产人妖系列| 欧美精品久久久久久久久老牛影院 | 91视频国产观看| 国产精品私人自拍| 国产一区中文字幕| 亚洲精品一线二线三线| 美女脱光内衣内裤视频久久影院| 欧美另类videos死尸| 一区二区在线观看视频在线观看| 成人精品电影在线观看| 国产精品色在线| 福利一区二区在线| 欧美高清在线视频| 成人中文字幕合集| 中文字幕在线不卡一区| 成人午夜视频网站| 综合精品久久久| 一本高清dvd不卡在线观看| 国产精品久久久久久久裸模| 不卡的av在线播放| 亚洲欧美色综合| 欧美综合天天夜夜久久| 亚洲一区二区三区四区在线免费观看 | 精品亚洲porn| 久久精品一区四区| 国产v日产∨综合v精品视频| 日本一区二区免费在线观看视频 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 国精产品一区一区三区mba视频 | 亚洲麻豆国产自偷在线| 欧美综合视频在线观看| 日韩激情视频在线观看| 日韩一区二区三| 国产在线播放一区| 国产欧美精品一区二区三区四区| 成人精品视频网站| 一区二区三区在线观看欧美| 欧美猛男超大videosgay| 久久超级碰视频| 国产精品久久福利| 欧美日韩国产免费| 精品制服美女丁香| 中文字幕一区二区不卡| 欧美三日本三级三级在线播放| 蜜臀av一区二区三区| 国产精品色呦呦| 欧美精品日韩精品| 国内精品伊人久久久久av一坑| 国产精品成人网| 欧美日韩一区在线观看| 精品一区二区三区免费视频| 国产精品久久综合| 91.麻豆视频| 成人毛片老司机大片| 天堂久久久久va久久久久| 久久综合中文字幕| 欧洲精品一区二区| 久久福利视频一区二区| 亚洲三级免费观看| 日韩精品一区二区三区中文不卡| 不卡一区二区在线| 麻豆精品久久精品色综合| 欧美国产精品一区二区| 欧美日韩中文另类| 国产精品99久久久久久久vr | 中文字幕亚洲欧美在线不卡| 宅男噜噜噜66一区二区66| 成人avav影音| 久久成人18免费观看| 亚洲人精品午夜| 精品福利一区二区三区| 91福利资源站| 国产99久久久国产精品免费看| 亚洲成a人在线观看| 中文成人综合网| 欧美电视剧在线看免费| 欧美在线啊v一区| 成人夜色视频网站在线观看| 麻豆精品国产传媒mv男同| 一区二区三区四区视频精品免费| 国产亚洲人成网站|