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

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

?? leaf.java

?? 一個java實現的R樹
?? JAVA
字號:
package rtree;import java.util.*;/** * A Leaf node. Containts pointers to the real data. * <p> * Created: Tue May 18 13:04:08 1999 * <p> * @author Hadjieleftheriou Marios * @version 1.002 */public class Leaf extends AbstractNode {        protected Leaf(RTree tree, int parent, int pageNumber) {	// Leaf nodes belong by default to level 0.	super(tree, parent, pageNumber, 0);    }    protected Leaf(RTree tree, int parent) {	// Leaf nodes belong by default to level 0.	super(tree, parent, -1, 0);    }    protected Leaf chooseLeaf(HyperCube h) {	return this;    }    protected Leaf findLeaf(HyperCube h) {	for (int i = 0; i < usedSpace; i++) {	    if (data[i].enclosure(h)) {		return this;	    }	}	return null;    }    /**     * Inserts a new HyperCube into the Leaf. If there is space left, then the insertion is straightforward and     * adjustTree must be called. Otherwise, a split must occur and two new leaves must be created.     *     * @param h The HyperCube that represents the MBB of the data.     * @param page The page number where the real data resides.     * @return The page number of the Leaf where the hypercube was inserted.     */    protected int insert(HyperCube h, int page) {	if (usedSpace < tree.getNodeCapacity()) {	    data[usedSpace] = h;	    branches[usedSpace] = page;	    usedSpace++;	    tree.file.writeNode(this);	    Index p = (Index) getParent();	    if (p != null) {		p.adjustTree(this, null);	    }	    return pageNumber;	} else {	    Leaf[] a = splitLeaf(h, page);	    Leaf l = a[0];	    Leaf ll = a[1];	    if (isRoot()) {		// root is full, so we must split it. From now on root will be		// an Index and not a Leaf.		l.parent = 0;		l.pageNumber = -1;		ll.parent = 0;		ll.pageNumber = -1;		tree.file.writeNode(l);		tree.file.writeNode(ll);		// create the new root node. It belongs to pageNumber 0 and level 1.		Index r = new Index(tree, RTree.NIL, 0, 1);		r.addData(l.getNodeMbb(), l.pageNumber);		r.addData(ll.getNodeMbb(), ll.pageNumber);		tree.file.writeNode(r);	    } else {		// use old page number for left child, a new page number for the right child.		l.pageNumber = pageNumber;		ll.pageNumber = -1;		tree.file.writeNode(l);		tree.file.writeNode(ll);		Index p = (Index) getParent();		p.adjustTree(l, ll);	    }	    // Find which is the parent Leaf of the inserted hypercube and return it's page number.	    for (int i = 0; i < l.usedSpace; i++) {		if (l.branches[i] == page) {		    return l.pageNumber;		}	    }	    for (int i = 0; i < ll.usedSpace; i++) {		if (ll.branches[i] == page) {		    return ll.pageNumber;		}	    }	    return -1;	}    }    /**     * Deletes an entry for the leaf.     * [A. Guttman 'R-trees a dynamic index structure for spatial searching']     * 3.3. Deletion     *     * @param h  The hypercube that corresponds to the entry to be deleted.     * @return The data pointer of the deleted entry.     **/    protected int delete(HyperCube h) {	for (int i = 0; i < usedSpace; i++) {	    if (data[i].equals(h)) {		int pointer = branches[i];		deleteData(i);		tree.file.writeNode(this);		Vector q = new Vector();		condenseTree(q);		// reinsert eliminated leaves.		for (int l = 0; l < q.size(); l++) {		    AbstractNode n = (AbstractNode) q.elementAt(l);		    if (n.isLeaf()) {			for (int j = 0; j < n.usedSpace; j++) {			    tree.insert(n.data[j], n.branches[j]);			}		    } else {			// this is not what Gutman says, but it will work anyway...			Vector v = tree.traversePostOrder(n);			for (int j = 0; j < v.size(); j++) {			    AbstractNode m = (AbstractNode) v.elementAt(j);			    if (m.isLeaf()) {				for (int k = 0; k < m.usedSpace; k++) {				    tree.insert(m.data[k], m.branches[k]);				}			    }			    tree.file.deletePage(m.pageNumber);			}		    }		    tree.file.deletePage(n.pageNumber);		}		return pointer;	    }	}	return RTree.NIL;    }    private Leaf[] splitLeaf(HyperCube h, int page) {	int[][] group = null;	switch (tree.getTreeType()) {	case tree.RTREE_LINEAR:	    break;	case tree.RTREE_QUADRATIC:	    group = quadraticSplit(h, page);	    break;	case tree.RTREE_EXPONENTIAL:	    break;	case tree.RSTAR:	    break;	default:	    throw new IllegalStateException("Invalid tree type.");	}	Leaf l = new Leaf(tree, parent);	Leaf ll = new Leaf(tree, parent);	int[] g1 = group[0];	int[] g2 = group[1];	for (int i = 0; i < g1.length; i++) {	    l.addData(data[g1[i]], branches[g1[i]]);	}	    	for (int i = 0; i < g2.length; i++) {	    ll.addData(data[g2[i]], branches[g2[i]]);	}	return new Leaf[] {l, ll};    }    /**     * Returns the pointer of the <i>i-th</i> data entry.     *     * @param  i The index of the child in the data array.     * @return The pointer of the <i>i-th</i> child.     */    public int getDataPointer(int i) {	if (i < 0 || i >= usedSpace) {	    throw new IndexOutOfBoundsException("" + i);	}	return branches[i];    }} // Leaf

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久亚洲毛片| 欧美一级欧美三级在线观看| 日韩国产在线一| 久久久综合视频| 欧美午夜精品电影| 成人高清视频在线| 国模少妇一区二区三区| 日本视频一区二区三区| 国产精品福利在线播放| 青青草视频一区| 在线免费观看日韩欧美| 国产福利91精品一区| 午夜婷婷国产麻豆精品| 亚洲欧美福利一区二区| 欧美激情一区二区在线| 亚洲精品在线观看网站| 欧美精品电影在线播放| 欧美日韩亚洲综合一区| 91在线视频网址| 99久久免费精品| 白白色 亚洲乱淫| 99久久精品国产导航| 91免费在线播放| 色婷婷狠狠综合| 日本道精品一区二区三区| 色偷偷久久人人79超碰人人澡| 国产一区二区三区蝌蚪| 国产乱人伦偷精品视频不卡 | 日韩一级完整毛片| 日韩一区二区三区在线视频| 51精品视频一区二区三区| 91精品婷婷国产综合久久竹菊| 欧美视频一区二区在线观看| 欧美剧情电影在线观看完整版免费励志电影 | 欧美日韩久久一区| 69精品人人人人| 久久精品免费在线观看| 国产精品免费免费| 一区二区三区欧美日| 日韩国产精品久久| 国产乱一区二区| 日本韩国欧美在线| 日韩欧美高清一区| 国产精品久久久久久亚洲伦| 亚洲一级在线观看| 国产综合久久久久影院| 不卡高清视频专区| 日韩久久精品一区| 亚洲情趣在线观看| 老汉av免费一区二区三区| 99v久久综合狠狠综合久久| 在线播放视频一区| 亚洲欧洲制服丝袜| 久久国产成人午夜av影院| 91亚洲大成网污www| 2020国产精品自拍| 婷婷丁香久久五月婷婷| 99久久精品久久久久久清纯| 久久久久久99久久久精品网站| 亚洲国产日韩a在线播放 | 成人午夜免费av| 日韩一级片在线观看| 亚洲成a人片在线观看中文| 国产成人免费在线| 欧美成人乱码一区二区三区| 亚洲一区二区精品久久av| 91在线看国产| 国产精品久久久久久福利一牛影视| 精品制服美女久久| 精品久久久三级丝袜| 视频一区二区中文字幕| 欧美专区日韩专区| 亚洲激情在线激情| 色婷婷av久久久久久久| 伊人开心综合网| 欧美日韩亚洲国产综合| 午夜伦理一区二区| 日韩视频免费观看高清在线视频| 天堂蜜桃91精品| 欧美肥妇bbw| 日韩精品视频网| 久久久久久久久久久电影| 国产成人小视频| 中文字幕在线一区| 91久久国产最好的精华液| 亚洲小说欧美激情另类| 91精品婷婷国产综合久久性色| 日本欧美一区二区在线观看| www欧美成人18+| a4yy欧美一区二区三区| 亚洲国产欧美在线人成| 91精品国产麻豆国产自产在线 | 免费黄网站欧美| 国产亚洲欧美日韩日本| 在线观看亚洲a| 日韩精品免费专区| 欧美激情综合网| 欧美年轻男男videosbes| 国产69精品久久777的优势| 亚洲福利一二三区| 国产亚洲精品aa| 欧美人体做爰大胆视频| 丁香五精品蜜臀久久久久99网站| 亚洲精品亚洲人成人网| 亚洲精品在线观| 这里只有精品电影| 色婷婷久久久综合中文字幕| 国产二区国产一区在线观看| 亚洲成人av中文| 亚洲麻豆国产自偷在线| 国产亚洲综合色| 日韩免费观看2025年上映的电影 | 成人动漫中文字幕| 精品伊人久久久久7777人| 亚洲电影你懂得| 亚洲日本欧美天堂| 国产欧美日韩综合精品一区二区| 91麻豆精品国产无毒不卡在线观看 | 麻豆专区一区二区三区四区五区| 亚洲另类色综合网站| 日韩毛片一二三区| 国产精品久久久一区麻豆最新章节| 欧美日韩精品一区二区三区| 色婷婷综合久久久久中文| 成人av午夜电影| 91原创在线视频| 色婷婷狠狠综合| 欧美性三三影院| 欧美少妇xxx| 欧美一区二区人人喊爽| 91精品国产高清一区二区三区蜜臀| 欧美男生操女生| 日韩三级精品电影久久久| 久久久综合网站| 成人免费小视频| 亚洲国产一二三| 精品午夜一区二区三区在线观看 | 麻豆精品视频在线观看视频| 国产在线视频不卡二| 成人福利在线看| 欧美三级视频在线播放| 日韩欧美高清一区| 日韩欧美第一区| 国产成人av电影在线观看| 亚洲一区在线观看免费观看电影高清| 久久久五月婷婷| 1024精品合集| 日日噜噜夜夜狠狠视频欧美人| 免费在线一区观看| 99视频超级精品| 日韩精品中午字幕| 日韩毛片高清在线播放| 丝袜美腿亚洲一区| 色综合中文字幕| 久久午夜老司机| 天天操天天色综合| 成人精品小蝌蚪| 日韩欧美色电影| 亚洲成人精品影院| 成人污污视频在线观看| 日韩午夜中文字幕| 亚洲国产日韩在线一区模特| 国产成人av资源| 日韩一区二区视频| 亚洲小说欧美激情另类| 91丝袜国产在线播放| 国产欧美日韩久久| 国产精品一二三| 日韩亚洲欧美在线观看| 午夜精品在线视频一区| 日本道免费精品一区二区三区| 久久综合国产精品| 奇米亚洲午夜久久精品| 欧美日韩另类国产亚洲欧美一级| 国产精品第一页第二页第三页| 国产真实乱偷精品视频免| 91精品国产综合久久久久久久久久| 亚洲男人的天堂在线aⅴ视频| 国产成人在线视频播放| 国产精品国产精品国产专区不片| 国产伦精品一区二区三区视频青涩| 欧美一区二区日韩一区二区| 麻豆一区二区99久久久久| 欧美一区二区免费视频| 精品一区二区三区在线视频| 2020国产精品自拍| www.日韩在线| 亚洲高清免费视频| 91精品国产91久久久久久一区二区 | 亚洲一区二区3| 日韩一级片在线观看| 国产乱色国产精品免费视频| 中文字幕一区二区三区不卡在线| 99久久精品国产导航| 亚洲国产毛片aaaaa无费看 | 欧美一区午夜精品| 国产精品亚洲第一区在线暖暖韩国| 国产精品伦理一区二区| 欧美视频在线不卡| 粉嫩高潮美女一区二区三区 |