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

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

?? btnode.java

?? 一個java的LDAP服務器
?? JAVA
字號:
package org.javaldap.btree;

import java.lang.*;

/***********************************************************************
 * Class BTNode
 * The BTNode is nothing else than a Node in the BTree. This nodes can be
 * greater or smaller it depends on the users order.
 **/

class BTNode {
	int order=0;
	int nKey=0;			// number of keys stored in node
	KeyNode kArray[];		// array where keys are stored
	BTNode btnArray[];	// array where references to the next BTNodes is stored
	boolean isLeaf;		// is the btnode a leaf
	BTNode parent;		// link to the parent node

	/**
	   * BTNode(int order, BTNode parent);
	   * Constructor, creats a empty node with the given order and parent
	   **/
	BTNode(int order, BTNode parent) {
		this.order = order;
		this.parent = parent;
		kArray = new KeyNode[2 * order - 1];
		btnArray = new BTNode[2 * order];
		isLeaf = true;
	}
	/**
	   *extractKeyNode(int keyPos)
	   *Moves the key's at and behind the startpos one position right
	   **/
	KeyNode extractKeyNode(int keyIndex) {
		KeyNode tmpKeyNode = getKeyNode(keyIndex);
		for (int i = keyIndex; i < nKey; i++) {
			kArray[i] = kArray[i + 1];
			if (!isLeaf) {
				btnArray[i] = btnArray[i + 1];
			}
		}
		nKey--;
		return tmpKeyNode;
	}
	/**
	 * getBTNode(int keyIndex)
	 * returns the link to the next node at the given index from this node
	 */
	BTNode getBTNode(int keyIndex) {
		return btnArray[keyIndex];
	}
	/**
	 * getKeyNode(int keyIndex)
	 * returns the key and object from this node at the given index
	 */
	KeyNode getKeyNode(int keyIndex) {
		return kArray[keyIndex];
	}
	/**
	   *insert(KeyNode keyNode);
	   *Insert a key in a Node in the right position. (Small to Big)
	   **/
	void insert(KeyNode keyNode) {
		if (nKey == 0) {
			nKey++;
			kArray[0] = keyNode;
		} else {
			int pos = 0;
			while (keyNode.getKey().compareTo(kArray[pos].getKey()) > 0) {
				pos++;
				if (pos == nKey) {
					break;
				}
			}
			if (nKey == order * 2 - 1) {
				BTNode right = split();
				if (pos > order - 1) {
					right.insert(keyNode);
				} else {
					if (pos != nKey) {
						shift(pos);
					} else {
						nKey++;
					}
					kArray[pos] = keyNode;
				}
			} else {
				if (pos != nKey) {
					shift(pos);
				} else {
					nKey++;
				}
				kArray[pos] = keyNode;
			}
		}
	}
	// you may only applie methode to leafs...
	void mergeWithBTNode() {

		BTNode parentBTNode = parent;
		BTNode mergeBTNode;
		int parentIndex = 0;

		while (parentBTNode.getBTNode(parentIndex) != this) {
			parentIndex++;
		}

		if (parentIndex > 1) {
			mergeBTNode = parent.getBTNode(parentIndex - 1);
		} else {
			mergeBTNode = parent.getBTNode(parentIndex + 1);
		}

		if (mergeBTNode != null) {

			//geting node obove
			kArray[nKey - 1] = parentBTNode.getKeyNode(parentIndex);

			//merging leafs
			// neues probelem wenn in allen nodes nur noch ein KeyNode
			// vorhanden ist und man einen l鰏chen m鯿hte bleibt mergeBTNode=null
			// System.out.println(nKey + " | " + mergeBTNode);
			for (int i = nKey, j = 0; j < mergeBTNode.nKey; i++, j++) {
				kArray[i] = mergeBTNode.getKeyNode(j);
				nKey++;
			}

			int i;
			for (i = parentIndex; i < nKey; i++) {
				parentBTNode.kArray[i] = parentBTNode.kArray[i + 1];
				parentBTNode.btnArray[i + 1] = parentBTNode.btnArray[i + 2];
			}

			parentBTNode.kArray[i] = null;
			parentBTNode.btnArray[i + 1] = null;
			parentBTNode.nKey--;
		}
	}
	/**
	   *shift(int startPos)
	   *Moves the key's at, and behind the startpos one position right
	   **/
	void shift(int startPos) {
		for (int i = nKey; i > startPos; i--) {
			kArray[i] = kArray[i - 1];
			if (!isLeaf)
				btnArray[i + 1] = btnArray[i];
		}
		nKey++;
	}
	/**
	   *split()
	   *Splits a node into to nodes. This can only be done, if the node is full
	   *The midlest key go up into the parent, the left ones of them rest in
	   *this node, and the right ones go into a new node.
	   **/
	BTNode split() {
		if (nKey == order * 2 - 1) {
			BTNode right = null;
			if (parent == null) { // algo for the root-node
				BTNode left = new BTNode(order, this);
				right = new BTNode(order, this);
				for (int i = 0; i < order - 1; i++) {
					left.kArray[i] = kArray[i];
					right.kArray[i] = kArray[order + i];
				}
				if (!isLeaf) {
					for (int i = 0; i < order; i++) {
						left.btnArray[i] = btnArray[i];
						left.btnArray[i].parent = left;
						right.btnArray[i] = btnArray[order + i];
						right.btnArray[i].parent = right;
					}
					left.isLeaf = false;
					right.isLeaf = false;
				} else
					isLeaf = false;
				kArray[0] = kArray[order - 1];
				nKey = 1;
				left.nKey = order - 1;
				right.nKey = order - 1;
				for (int i = 1; i < order * 2 - 1; i++) {
					kArray[i] = null;
					btnArray[i + 1] = null;
				}
				btnArray[0] = left;
				btnArray[1] = right;
			} else { // algo for non-root-nodes
				if (parent.nKey == order * 2 - 1)
					parent.split();
				int pos = 0;
				while (kArray[order - 1].getKey().compareTo(parent.kArray[pos].getKey()) > 0) {
					pos++;
					if (pos == parent.nKey)
						break;
				}
				parent.shift(pos);
				parent.kArray[pos] = kArray[order - 1];
				right = new BTNode(order, parent);
				for (int i = 0; i < order - 1; i++)
					right.kArray[i] = kArray[order + i];
				if (!isLeaf) {
					for (int i = 0; i < order; i++) {
						right.btnArray[i] = btnArray[order + i];
						right.btnArray[i].parent = right;
					}
					right.isLeaf = false;
				}
				right.nKey = order - 1;
				nKey = order - 1;
				for (int u = 0; u < order - 1; u++) {
					kArray[order - 1 + u] = null;
					btnArray[order + u] = null;
				}
				parent.btnArray[pos] = this;
				parent.btnArray[pos + 1] = right;
			}
			return right;
		} else
			return null;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区三区四区| 亚洲三级在线免费观看| av欧美精品.com| 麻豆精品一区二区三区| 亚洲日本青草视频在线怡红院| 91麻豆精品国产91久久久久 | 久久99久久久久| 亚洲精品视频一区| 国产亚洲欧美日韩日本| 51久久夜色精品国产麻豆| 99精品一区二区| 国产精品99久久久久久久vr | 99热这里都是精品| 韩国成人福利片在线播放| 亚洲成人中文在线| 中文字幕一区二区三区不卡| 精品国产91乱码一区二区三区 | 日韩一区二区三区视频在线观看| 91麻豆福利精品推荐| 欧美伦理视频网站| 在线视频亚洲一区| 成人v精品蜜桃久久一区| 国产原创一区二区三区| 久久99久久精品| 美日韩一区二区| 日韩精品欧美成人高清一区二区| 亚洲女爱视频在线| 亚洲欧美日韩精品久久久久| 中文字幕免费不卡在线| 国产亚洲制服色| 久久人人爽人人爽| 久久婷婷一区二区三区| 久久综合成人精品亚洲另类欧美| 日韩一区二区免费高清| 日韩久久精品一区| 日韩免费观看高清完整版在线观看| 91精品久久久久久久久99蜜臂| 欧美日韩视频第一区| 欧美日韩国产高清一区二区 | 国产精品一区2区| 韩国一区二区三区| 国产一区不卡在线| 国产一区二区三区久久久 | 国产成人av资源| 福利一区福利二区| 99久久伊人精品| 色婷婷久久久久swag精品| 91丨porny丨国产| 欧美日韩中文字幕一区二区| 精品视频在线免费| 欧美一区二区三区在线看| 日韩三级在线观看| 精品少妇一区二区三区在线播放| 久久女同性恋中文字幕| 国产精品天干天干在线综合| 国产精品福利影院| 尤物在线观看一区| 免费在线视频一区| 激情久久久久久久久久久久久久久久| 国产成人综合视频| 99热国产精品| 欧美日韩亚洲高清一区二区| 欧美日韩国产综合视频在线观看| 日韩欧美一级二级| 国产精品久久久久久久久免费樱桃 | 午夜不卡av免费| 久久国产成人午夜av影院| 国产精品一二三四| 国产午夜久久久久| 亚洲欧美另类在线| 日韩成人av影视| 丰满亚洲少妇av| 欧美日韩一区高清| 久久久噜噜噜久噜久久综合| 国产精品成人在线观看| 日韩成人免费电影| 北条麻妃国产九九精品视频| 欧美三区在线观看| 久久综合久久久久88| 亚洲精品免费在线观看| 美女在线视频一区| 91在线视频免费91| 日韩免费高清视频| 一区二区三区四区五区视频在线观看| 日韩高清不卡一区| 99久久99精品久久久久久| 欧美一区午夜视频在线观看| ㊣最新国产の精品bt伙计久久| 天堂va蜜桃一区二区三区| 高清在线成人网| 555夜色666亚洲国产免| 亚洲欧美日韩中文播放| 黄色小说综合网站| 欧美日韩国产大片| 国产精品福利av | 91在线无精精品入口| 日韩免费性生活视频播放| 亚洲啪啪综合av一区二区三区| 日韩高清电影一区| 欧洲av在线精品| 国产日本欧洲亚洲| 久草中文综合在线| 欧美三级电影在线看| 欧美国产欧美综合| 精品一区二区三区视频在线观看| 色老头久久综合| 国产精品家庭影院| 国产精品一级在线| 欧美xxx久久| 天天操天天综合网| 91官网在线免费观看| 国产精品欧美久久久久无广告| 久久国产麻豆精品| 7777女厕盗摄久久久| 亚洲午夜激情av| 99riav久久精品riav| 亚洲国产精品精华液2区45| 蜜桃av一区二区| 宅男在线国产精品| 天天爽夜夜爽夜夜爽精品视频| 色婷婷亚洲精品| 中文字幕佐山爱一区二区免费| 激情亚洲综合在线| 精品久久久久久无| 美美哒免费高清在线观看视频一区二区 | 国产精品电影院| 精品国产乱码久久久久久老虎| 午夜激情一区二区三区| 欧美色偷偷大香| 亚洲午夜精品网| 欧美日本在线播放| 午夜精品久久久久影视| 欧美丝袜自拍制服另类| 亚洲久草在线视频| 91久久国产最好的精华液| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 国产99久久久国产精品潘金| 久久久777精品电影网影网 | 国产一区二区三区四| 久久久综合网站| 国产盗摄精品一区二区三区在线 | 91丨porny丨户外露出| 亚洲人成网站影音先锋播放| 99国产精品99久久久久久| 亚洲品质自拍视频网站| 欧美综合在线视频| 午夜影院在线观看欧美| 日韩精品一区国产麻豆| 韩国精品免费视频| 中文在线资源观看网站视频免费不卡 | 成人毛片视频在线观看| 国产精品免费看片| 91老师片黄在线观看| 亚洲资源在线观看| 91精品国产综合久久久久久| 久久99国产精品尤物| 国产欧美一区二区精品久导航| 成人动漫一区二区三区| 亚洲国产精品一区二区尤物区| 欧美精品日韩精品| 国产一区二区不卡在线| 国产精品乱子久久久久| 欧美怡红院视频| 免费看黄色91| 国产精品毛片久久久久久久| 欧美视频一区二区三区| 麻豆一区二区在线| 国产精品国产三级国产普通话三级| 91麻豆福利精品推荐| 免费人成网站在线观看欧美高清| 国产亚洲成av人在线观看导航| 91论坛在线播放| 日本少妇一区二区| 国产精品免费看片| 欧美人狂配大交3d怪物一区| 国产伦精品一区二区三区免费| 自拍偷在线精品自拍偷无码专区| 3atv一区二区三区| 成人黄色av网站在线| 亚洲成av人影院| 日本一区二区三区dvd视频在线| 色国产综合视频| 国产一区二区在线观看免费| 亚洲精品中文字幕在线观看| 日韩一区二区不卡| 一本色道久久综合亚洲91| 欧美日韩视频一区二区| 国产成人精品影视| 亚洲成人av资源| 国产精品福利在线播放| 欧美电影精品一区二区| 色94色欧美sute亚洲线路二| 国产精品一区不卡| 日本欧美大码aⅴ在线播放| 自拍偷拍亚洲综合| 久久久久国产精品厨房| 欧美日韩国产电影| 91老师片黄在线观看| 国产成人亚洲综合a∨婷婷| 蜜臀久久久99精品久久久久久|