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

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

?? index.c

?? Rtree R樹的C語言實現 ,學習R樹的朋友們共同學習,向你們學習
?? C
字號:

#include <stdio.h>
#include <malloc.h>
#include "assert.h"
#include "index.h"
#include "card.h"


// Make a new index, empty.  Consists of a single node.
//
struct Node * RTreeNewIndex()
{
	struct Node *x;
	x = RTreeNewNode();
	x->level = 0; /* leaf */
	return x;
}



// Search in an index tree or subtree for all data retangles that
// overlap the argument rectangle.
// Return the number of qualifying data rects.
//
int RTreeSearch(struct Node *N, struct Rect *R, SearchHitCallback shcb, void* cbarg)
{
	register struct Node *n = N;
	register struct Rect *r = R; // NOTE: Suspected bug was R sent in as Node* and cast to Rect* here. Fix not yet tested.
	register int hitCount = 0;
	register int i;

	assert(n);
	assert(n->level >= 0);
	assert(r);

	if (n->level > 0) /* this is an internal node in the tree */
	{
		for (i=0; i<NODECARD; i++)
			if (n->branch[i].child &&
			    RTreeOverlap(r,&n->branch[i].rect))
			{
				hitCount += RTreeSearch(n->branch[i].child, R, shcb, cbarg);
			}
	}
	else /* this is a leaf node */
	{
		for (i=0; i<LEAFCARD; i++)
			if (n->branch[i].child &&
			    RTreeOverlap(r,&n->branch[i].rect))
			{
				hitCount++;
				if(shcb) // call the user-provided callback
					if( ! shcb((int)n->branch[i].child, cbarg))
						return hitCount; // callback wants to terminate search early
			}
	}
	return hitCount;
}



// Inserts a new data rectangle into the index structure.
// Recursively descends tree, propagates splits back up.
// Returns 0 if node was not split.  Old node updated.
// If node was split, returns 1 and sets the pointer pointed to by
// new_node to point to the new node.  Old node updated to become one of two.
// The level argument specifies the number of steps up from the leaf
// level to insert; e.g. a data rectangle goes in at level = 0.
//
static int RTreeInsertRect2(struct Rect *r,
		int tid, struct Node *n, struct Node **new_node, int level)
{
/*
	register struct Rect *r = R;
	register int tid = Tid;
	register struct Node *n = N, **new_node = New_node;
	register int level = Level;
*/

	register int i;
	struct Branch b;
	struct Node *n2;

	assert(r && n && new_node);
	assert(level >= 0 && level <= n->level);

	// Still above level for insertion, go down tree recursively
	//
	if (n->level > level)
	{
		i = RTreePickBranch(r, n);
		if (!RTreeInsertRect2(r, tid, n->branch[i].child, &n2, level))
		{
			// child was not split
			//
			n->branch[i].rect =
				RTreeCombineRect(r,&(n->branch[i].rect));
			return 0;
		}
		else    // child was split
		{
			n->branch[i].rect = RTreeNodeCover(n->branch[i].child);
			b.child = n2;
			b.rect = RTreeNodeCover(n2);
			return RTreeAddBranch(&b, n, new_node);
		}
	}

	// Have reached level for insertion. Add rect, split if necessary
	//
	else if (n->level == level)
	{
		b.rect = *r;
		b.child = (struct Node *) tid;
		/* child field of leaves contains tid of data record */
		return RTreeAddBranch(&b, n, new_node);
	}
	else
	{
		/* Not supposed to happen */
		assert (FALSE);
		return 0;
	}
}



// Insert a data rectangle into an index structure.
// RTreeInsertRect provides for splitting the root;
// returns 1 if root was split, 0 if it was not.
// The level argument specifies the number of steps up from the leaf
// level to insert; e.g. a data rectangle goes in at level = 0.
// RTreeInsertRect2 does the recursion.
//
int RTreeInsertRect(struct Rect *R, int Tid, struct Node **Root, int Level)
{
	register struct Rect *r = R;
	register int tid = Tid;
	register struct Node **root = Root;
	register int level = Level;
	register int i;
	register struct Node *newroot;
	struct Node *newnode;
	struct Branch b;
	int result;

	assert(r && root);
	assert(level >= 0 && level <= (*root)->level);
	for (i=0; i<NUMDIMS; i++)
		assert(r->boundary[i] <= r->boundary[NUMDIMS+i]);

	if (RTreeInsertRect2(r, tid, *root, &newnode, level))  /* root split */
	{
		newroot = RTreeNewNode();  /* grow a new root, & tree taller */
		newroot->level = (*root)->level + 1;
		b.rect = RTreeNodeCover(*root);
		b.child = *root;
		RTreeAddBranch(&b, newroot, NULL);
		b.rect = RTreeNodeCover(newnode);
		b.child = newnode;
		RTreeAddBranch(&b, newroot, NULL);
		*root = newroot;
		result = 1;
	}
	else
		result = 0;

	return result;
}




// Allocate space for a node in the list used in DeletRect to
// store Nodes that are too empty.
//
static struct ListNode * RTreeNewListNode()
{
	return (struct ListNode *) malloc(sizeof(struct ListNode));
	//return new ListNode;
}


static void RTreeFreeListNode(struct ListNode *p)
{
	free(p);
	//delete(p);
}



// Add a node to the reinsertion list.  All its branches will later
// be reinserted into the index structure.
//
static void RTreeReInsert(struct Node *n, struct ListNode **ee)
{
	register struct ListNode *l;

	l = RTreeNewListNode();
	l->node = n;
	l->next = *ee;
	*ee = l;
}


// Delete a rectangle from non-root part of an index structure.
// Called by RTreeDeleteRect.  Descends tree recursively,
// merges branches on the way back up.
// Returns 1 if record not found, 0 if success.
//
static int
RTreeDeleteRect2(struct Rect *R, int Tid, struct Node *N, struct ListNode **Ee)
{
	register struct Rect *r = R;
	register int tid = Tid;
	register struct Node *n = N;
	register struct ListNode **ee = Ee;
	register int i;

	assert(r && n && ee);
	assert(tid >= 0);
	assert(n->level >= 0);

	if (n->level > 0)  // not a leaf node
	{
	    for (i = 0; i < NODECARD; i++)
	    {
		if (n->branch[i].child && RTreeOverlap(r, &(n->branch[i].rect)))
		{
			if (!RTreeDeleteRect2(r, tid, n->branch[i].child, ee))
			{
				if (n->branch[i].child->count >= MinNodeFill)
					n->branch[i].rect = RTreeNodeCover(
						n->branch[i].child);
				else
				{
					// not enough entries in child,
					// eliminate child node
					//
					RTreeReInsert(n->branch[i].child, ee);
					RTreeDisconnectBranch(n, i);
				}
				return 0;
			}
		}
	    }
	    return 1;
	}
	else  // a leaf node
	{
		for (i = 0; i < LEAFCARD; i++)
		{
			if (n->branch[i].child &&
			    n->branch[i].child == (struct Node *) tid)
			{
				RTreeDisconnectBranch(n, i);
				return 0;
			}
		}
		return 1;
	}
}



// Delete a data rectangle from an index structure.
// Pass in a pointer to a Rect, the tid of the record, ptr to ptr to root node.
// Returns 1 if record not found, 0 if success.
// RTreeDeleteRect provides for eliminating the root.
//
int RTreeDeleteRect(struct Rect *R, int Tid, struct Node**Nn)
{
	register struct Rect *r = R;
	register int tid = Tid;
	register struct Node **nn = Nn;
	register int i;
	register struct Node *tmp_nptr;
	struct ListNode *reInsertList = NULL;
	register struct ListNode *e;

	assert(r && nn);
	assert(*nn);
	assert(tid >= 0);

	if (!RTreeDeleteRect2(r, tid, *nn, &reInsertList))
	{
		/* found and deleted a data item */

		/* reinsert any branches from eliminated nodes */
		while (reInsertList)
		{
			tmp_nptr = reInsertList->node;
			for (i = 0; i < MAXKIDS(tmp_nptr); i++)
			{
				if (tmp_nptr->branch[i].child)
				{
					RTreeInsertRect(
						&(tmp_nptr->branch[i].rect),
						(int)tmp_nptr->branch[i].child,
						nn,
						tmp_nptr->level);
				}
			}
			e = reInsertList;
			reInsertList = reInsertList->next;
			RTreeFreeNode(e->node);
			RTreeFreeListNode(e);
		}
		
		/* check for redundant root (not leaf, 1 child) and eliminate
		*/
		if ((*nn)->count == 1 && (*nn)->level > 0)
		{
			for (i = 0; i < NODECARD; i++)
			{
				tmp_nptr = (*nn)->branch[i].child;
				if(tmp_nptr)
					break;
			}
			assert(tmp_nptr);
			RTreeFreeNode(*nn);
			*nn = tmp_nptr;
		}
		return 0;
	}
	else
	{
		return 1;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产综合久久久久影院| 亚洲精品老司机| 欧美伦理电影网| 色婷婷综合视频在线观看| 成人性色生活片| 国产乱妇无码大片在线观看| 国产一区二区三区四区在线观看| 日韩福利视频导航| 毛片av一区二区| 久久精品久久99精品久久| 精品一区二区影视| 国产一区二区三区最好精华液| 日韩av中文在线观看| 久久国产精品色婷婷| 国产精品一区二区无线| 成年人网站91| 欧美日韩视频在线一区二区 | 日韩欧美国产三级电影视频| 欧美一区二区黄| 精品99999| 日韩美女视频一区| 亚洲午夜在线电影| 久久成人麻豆午夜电影| 国产精品一二三在| 色香蕉久久蜜桃| 欧美一级免费观看| 亚洲国产精品t66y| 一区二区免费在线播放| 蜜桃91丨九色丨蝌蚪91桃色| 成人不卡免费av| 精品视频1区2区| 久久久亚洲精品石原莉奈| 亚洲色图第一区| 免费高清视频精品| 波多野结衣中文字幕一区二区三区| 色噜噜狠狠一区二区三区果冻| 欧美一区二区成人| 国产精品日韩精品欧美在线| 日韩精品久久久久久| 成人激情av网| 欧美mv日韩mv国产网站app| 亚洲人成电影网站色mp4| 久久99久久99小草精品免视看| yourporn久久国产精品| 欧美成人乱码一区二区三区| 亚洲三级理论片| 国产精品99久久久久久久女警| 日本乱人伦aⅴ精品| 国产午夜精品在线观看| 日本欧美一区二区在线观看| 9人人澡人人爽人人精品| 日韩精品在线看片z| 亚洲国产日韩在线一区模特| 不卡一区在线观看| 久久精品免视看| 久久精品国产秦先生| 欧美日韩你懂得| 亚洲免费观看高清完整版在线观看熊| 极品美女销魂一区二区三区| 欧美浪妇xxxx高跟鞋交| 亚洲猫色日本管| 91麻豆国产福利精品| 国产精品欧美综合在线| 国产精品自在在线| 精品久久一二三区| 麻豆成人免费电影| 日韩视频永久免费| 日本人妖一区二区| 日韩一区二区三区精品视频| 午夜精品福利一区二区蜜股av| 在线免费视频一区二区| 亚洲精品免费一二三区| 99精品黄色片免费大全| 国产精品国产三级国产aⅴ入口| 色吧成人激情小说| 亚洲视频在线观看一区| 99精品国产热久久91蜜凸| 国产精品美女一区二区| 成人爱爱电影网址| 亚洲美女一区二区三区| 欧美中文字幕亚洲一区二区va在线| 中文字幕乱码久久午夜不卡| 粉嫩绯色av一区二区在线观看| 久久婷婷色综合| 国产精品一区二区不卡| 国产亚洲精品资源在线26u| 国产不卡高清在线观看视频| 久久久99精品久久| a亚洲天堂av| 亚洲精品你懂的| 欧美日韩成人综合在线一区二区| 丝袜亚洲另类欧美综合| 91精品婷婷国产综合久久竹菊| 蜜桃传媒麻豆第一区在线观看| 精品日韩在线观看| 成人av免费在线播放| 亚洲另类春色校园小说| 欧美另类videos死尸| 九九精品一区二区| 成人免费在线播放视频| 欧美色精品在线视频| 另类小说欧美激情| 久久久国产精华| 欧美在线不卡一区| 国产毛片精品视频| 一区二区三区高清在线| 欧美成人福利视频| 99久久精品免费观看| 亚洲动漫第一页| 国产欧美久久久精品影院| 99re在线精品| 国产综合色视频| 亚洲精品高清在线观看| 久久一夜天堂av一区二区三区| 91色|porny| 久久激情综合网| 亚洲综合在线免费观看| 欧美mv日韩mv| 欧美日韩国产区一| 不卡av电影在线播放| 麻豆freexxxx性91精品| 亚洲综合一区在线| 亚洲国产精品成人久久综合一区| 91精选在线观看| 色综合久久久网| 国产福利精品导航| 首页亚洲欧美制服丝腿| 亚洲欧美区自拍先锋| 久久精品一区二区三区四区| 在线观看成人免费视频| 不卡的av网站| 国产美女精品一区二区三区| 婷婷久久综合九色综合绿巨人| 国产精品电影院| 国产无人区一区二区三区| 欧美一级淫片007| 欧美日精品一区视频| 91久久线看在观草草青青| 国产激情偷乱视频一区二区三区| 免费xxxx性欧美18vr| 婷婷久久综合九色综合绿巨人 | 91精品在线免费观看| 色综合久久88色综合天天| 国产成人丝袜美腿| 韩国精品免费视频| 久久精品国产99久久6| 男女视频一区二区| 亚洲 欧美综合在线网络| 亚洲国产欧美在线| 亚洲国产wwwccc36天堂| 亚洲国产va精品久久久不卡综合| 亚洲精品亚洲人成人网在线播放| 久久久99久久精品欧美| 欧美极品xxx| 国产精品美女久久久久久2018| 中文字幕欧美日韩一区| 国产精品麻豆久久久| 中文字幕一区在线观看视频| 国产精品免费久久久久| 中文字幕精品—区二区四季| 国产视频一区二区在线观看| 国产欧美日韩精品a在线观看| 欧美激情资源网| 综合av第一页| 亚洲国产另类av| 欧美aⅴ一区二区三区视频| 免费欧美在线视频| 国产精品影视在线观看| av在线不卡电影| 91福利在线导航| 欧美精品自拍偷拍动漫精品| 日韩欧美在线影院| 国产日韩高清在线| 一区二区三区影院| 日本在线不卡一区| 国产成人亚洲精品青草天美| 波波电影院一区二区三区| 在线免费视频一区二区| 欧美一级免费大片| 国产精品女主播av| 午夜精品久久久久久久| 国产一区二区三区免费观看| 99re66热这里只有精品3直播| 欧美日韩一区小说| 久久九九久久九九| 亚洲高清三级视频| 国产乱码精品一区二区三区av| 99久久精品免费观看| 欧美一级国产精品| 亚洲色图19p| 国产一区在线观看视频| 色婷婷久久久亚洲一区二区三区| 欧美一区二区成人| 一区二区三区成人在线视频| 久久超级碰视频| 欧美日韩大陆在线| 亚洲视频中文字幕| 国产一区三区三区| 欧美精品高清视频| 亚洲伦理在线精品|