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

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

?? tvnode.c

?? TV-tree的c實現源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*                    COPYRIGHT NOTICE This material was developed by Christos Faloutsos and King-Ip Linat the University of Maryland, College Park, Department of Computer Science.Permission is granted to copy this software, to redistribute iton a nonprofit basis, and to use it for any purpose, subject tothe following restrictions and understandings. 1. Any copy made of this software must include this copyright noticein full. 2. All materials developed as a consequence of the use of thissoftware shall duly acknowledge such use, in accordance with the usualstandards of acknowledging credit in academic research. 3. The authors have made no warranty or representation that theoperation of this software will be error-free or suitable for anyapplication, and they are under under no obligation to provide anyservices, by way of maintenance, update, or otherwise.  The softwareis an experimental prototype offered on an as-is basis. 4. Redistribution for profit requires the express, written permissionof the authors. */// Author : $Author$// Date : $Date$// Id : $Id$// $Id: node.C,v 1.3 1996/04/18 21:50:24 kilin Exp kilin $ // Please change sig_dim to active_dim#include <iostream.h>#include <assert.h>#include <stdlib.h>#include <fstream.h>#include "TVdefine.h"#include "TVconstants.h"#include "TVvector.h"#include "TVrectangle.h"//#include "TVrectangle.h"#include "TVelement.h"#include "TVsimbuf.h"#include "TVnode.h"#include "TVutil.h"#include "TVsplit.h"#include "TVreinsert.h"extern Storage *globstorage;TVNodehandle::TVNodehandle(){   ptr = NULL;   pagenum = -1;}TVNodehandle::TVNodehandle(Internal_TVNode& n){  ptr = (TVNode *)&n;  pagenum = globstorage->newpage();}TVNodehandle::TVNodehandle(TVNode* n){  ptr = n;  pagenum = globstorage->newpage();}TVNodehandle::TVNodehandle(Leaf_TVNode& n){  ptr = (TVNode *)&n;  pagenum = globstorage->newpage();}TVNodehandle::TVNodehandle(const TVNodehandle& nh){  ptr = nh.ptr;  pagenum = nh.pagenum;}TVNodehandle& TVNodehandle::operator=(const TVNodehandle& nh){  ptr = nh.ptr;  pagenum = nh.pagenum;  return *this;}// return the size of the handle (not the node)// Assume all pointer have the same sizeint TVNodehandle::bytes() const{   return sizeof(TVNode *);}TVNode* TVNodehandle::fetch() const{   globstorage->fetch(pagenum);   return ptr;}// return FALSE when write failint TVNodehandle::write() const{   if (pagenum > -1)      globstorage->writepage(pagenum);   return TRUE;}TVNodehandle& TVNodehandle::assign(Internal_TVNode& n){   ptr = (TVNode *)&n;   pagenum = globstorage->newpage();   return *this;}TVNodehandle& TVNodehandle::assign(Leaf_TVNode& d){   ptr = (TVNode *)&d;   pagenum = globstorage->newpage();   return *this;}TVNodehandle& TVNodehandle::assign(TVNode* d){   ptr = d;   pagenum = globstorage->newpage();   return *this;}int TVNodehandle::null() const{   return !ptr;}TVNodehandle& TVNodehandle::setnull(){  ptr = NULL;  if (pagenum > 0)     {       globstorage->clearpage(pagenum);       pagenum = -1;     }  return *this;}void TVNodehandle::clearpage(){  globstorage->clearpage(pagenum);}ostream& operator<<(ostream& os, const TVNodehandle& nh){   if (nh.ptr)      os <<  "TVNode ptr : " << nh.ptr;   os << "  Page number : " << nh.pagenum;   return os;}TVNode::TVNode(){   count = 0;   max_count = 0;}TVNode::TVNode(int maxc){   count = 0;   max_count = maxc;}TVNode::TVNode(const TVNode &n){   count = n.count;   max_count = n.max_count;}TVNode::~TVNode(){}TVNode& TVNode::operator=(const TVNode& n){   count = n.count;   max_count = n.max_count;   return *this;}int TVNode::MaxCount(){   return max_count;}int TVNode::GetCount(){   return count;}void TVNode::WriteToDisk(){  // increase statistics}Internal_TVNode::Internal_TVNode(){   level = -1;   entry = NULL;}Internal_TVNode::Internal_TVNode(int l, int maxc) : TVNode(maxc){   level = l;   entry = NULL;   entry = new TVBranch[maxc];}Internal_TVNode::Internal_TVNode(const Internal_TVNode &n){   count = n.count;   max_count = n.max_count;   level = n.level;   entry = new TVBranch[n.max_count];   for (int i = 0; i < n.count; i++)     entry[i] = n.entry[i];}Internal_TVNode::~Internal_TVNode(){   if (max_count > 0)      {         for (int j = 0; j < count ; j++)             entry[j].TVBranch::~TVBranch();         delete [] entry;      }}Internal_TVNode& Internal_TVNode::Reinit(){   if (max_count > 0)      {         for (int j = 0; j < count ; j++)             entry[j].TVBranch::~TVBranch();         delete [] entry;      }   entry = new TVBranch[max_count];   count = 0;   return *this;}Internal_TVNode& Internal_TVNode::operator=(const Internal_TVNode& n){   if (max_count > 0)      {         for (int j = 0; j < count ; j++)             entry[j].TVBranch::~TVBranch();         delete [] entry;      }   count = n.count;   max_count = n.max_count;   level = n.level;   entry = new TVBranch[n.max_count];   for (int i = 0; i < n.count; i++)     entry[i] = n.entry[i];   return *this;}int Internal_TVNode::TVNodeType() const{  return INTERNAL_NODE;}int Internal_TVNode::Size() const{  int bsize=0;  for (int i=0; i < count; i++)      bsize += entry[i].Size();  return sizeof(count) + sizeof(max_count) + sizeof(level) + bsize;}int Internal_TVNode::GetLevel(){  return level;}int Internal_TVNode::ParentOfLeaf(){   return level == PARENT_OF_LEAF;}TVNodeEntry Internal_TVNode::Fetch(int i) const{  assert (i < max_count);  TVNodeEntry f(entry[i]);  return f;}int Internal_TVNode::Put(const TVBranch& b, int pagesize){   int result;// cout << "B.size, Size : " << b.Size() << ", " << Size() << "\n";   if (b.Size() + Size() <= pagesize)      {         if (count >= max_count)            {               // current array not big enough, create new one               TVBranch *newentry = new TVBranch[max_count * 2];               max_count = max_count * 2;               for (int i = 0; i < count ; i++)                   newentry[i] = entry[i];               newentry[count++] = b;               delete [] entry;               entry = newentry;            }         else            {              entry[count++] = b;              result = NODE_NOT_FULL;            }      }   else      result = NODE_FULL;   return result;}int Internal_TVNode::Remove(int bno, float min_fill_percent){   assert((bno < count) && (bno >= 0));   assert(min_fill_percent > 0);   entry[bno] = entry[count - 1];   if (--(count) < min_fill_percent * max_count / 100.0)      return(NODE_EMPTY);   else      return(NODE_NOT_EMPTY);}TVRectangle Internal_TVNode::MinBound(int sig_dim){   TVRectangle *darray = new TVRectangle[count];   for (int i = 0; i < count; i++)       darray[i] = entry[i].GetBound();   delete [] darray;   return (MinBoundTVRectangle(darray, count, sig_dim));}int Internal_TVNode::FixSize(){   return sizeof(int) * 3;}// Redistribute the nodes from the split return entriesInternal_TVNode& Internal_TVNode::ReDistribute(SplitReturn& sret, TVBranch *barray, int pagesize){  Reinit();    if (sret.newnode)    delete [] sret.newnode;  if (sret.parts > 1)     sret.newnode = new TVNode*[sret.parts - 1];  for (int i = 0; i < sret.parts - 1; i++)     sret.newnode[i] = new Internal_TVNode(level, max(max_count, CONSERVE_MAX_BRANCH_FACTOR));  for (int j = 0; j < sret.entrycount; j++)     {	if (sret.distribute[j])	    sret.newnode[sret.distribute[j] - 1]->Put(barray[j], pagesize);        else	   Put(barray[j], pagesize);     }  return *this;      }SplitReturn Internal_TVNode::Split(const TVBranch &b, const TVNodehandle& thishandle, int pagesize, float min_fill_percent, int sig_dim){ // cout << "----------\n";// cout << "Splitting :\n";// for (int xyy = 0; xyy < count; xyy++)//    cout << xyy << "  " << entry[xyy].GetBound() << endl;//cout << "new   " << b << endl;   SplitReturn sret(count + 1);   TVBranch *barray = new TVBranch[count + 1];   int i = 0;   for (; i < count; i++)          barray[i] = entry[i];   barray[count] = b;   // The splitting algorithm   SplitTVBranchAlg(sret, barray, FixSize(), pagesize, min_fill_percent, sig_dim);               // Rebuilt the nodes   ReDistribute(sret, barray, pagesize);//cout << "SplitReturn : " << sret.bound[0] << "  " << sret.bound[1] << endl;   thishandle.write();   delete [] barray;   return sret;}SplitReturn Internal_TVNode::Split(const Leaf_Element &e, const TVNodehandle& nh, VCOM_TYPE (*gfeat)(int, char*), int pagesize, float min_fill_percent, int sig_dim){  assert(0);  SplitReturn srt(1);  return srt;}void Internal_TVNode::SetReInsert(const Leaf_Element& b, ReInsertClass& ric, const TVNodehandle& nh, float reinsert_percent, int pagesize, float min_fill_percent, int sig_dim){  assert(0);}int sort_ricarray(const void *ric1, const void *ric2){   int out1;   float d1, d2;   TVector v1, v2;   d1 =  ((ReInsertCal *)ric1)->distance;   d2 =  ((ReInsertCal *)ric2)->distance;   out1 = (abs(d1 - d2) < abs(PRECISION * d1)) && (abs(d1 - d2) < abs(PRECISION * d2));   if (!(out1))      {      if ((d1 - d2) > 0)         return(1);      else         return(-1);      }   v1 =  ((ReInsertCal *)ric1)->ne.GetTVector();   v2 =  ((ReInsertCal *)ric2)->ne.GetTVector();   if (v1 < v2)      out1 = -1 ;   else      out1 = (v1 > v2);   return out1;}void Internal_TVNode::SetReInsert(const TVBranch& b, ReInsertClass& ric, const TVNodehandle& thishandle, float reinsert_percent, int pagesize, float min_fill_percent, int sig_dim){   TVNodeEntry *narray = new TVNodeEntry[count + 1];   TVBranch *barray = new TVBranch[count + 1];   TVRectangle *darray = new TVRectangle[count + 1];   ReInsertCal *ricarray = new ReInsertCal[count + 1];   ReInsertCal swap;   int total_branch = count + 1;   int cursize, requiresize;   TVRectangle bound;   int i;   for (i = 0; i < count; i++)      {         // need to do this, because TVNodeEntry have only pointers         barray[i] = entry[i];         ricarray[i].ne.Put(barray[i]);         darray[i] = barray[i].GetBound();      }   bound = MinBoundTVRectangle(darray, count, sig_dim);   barray[count] = b;   ricarray[count].ne.Put(barray[count]);   for (i = 0;  i < count; i++)      {        ricarray[i].distance = bound.GetCenter().Distance(barray[i].GetBound().GetCenter().ProjectFront(bound.GetCenter().GetDim()));      }   ricarray[count].distance = bound.GetCenter().Distance(b.GetBound().GetCenter().ProjectFront(bound.GetCenter().GetDim()));   qsort(ricarray, total_branch, sizeof(ReInsertCal), sort_ricarray);   int reinsert_size = 0;   int flag = TRUE;   i = count;   cursize = Size() + b.Size();   requiresize = (int)(pagesize * (100 - reinsert_percent) / 100);   while (cursize > requiresize)     {       cursize -= ricarray[i--].ne.u.b->Size();     }   if (cursize < (pagesize * min_fill_percent) / 100)      {        cursize +=  ricarray[++i].ne.u.b->Size();        if (cursize > pagesize)           {             // encounter a large element             swap = ricarray[i];             ricarray[i] = ricarray[0];             ricarray[0] = swap;             cursize = Size() + b.Size();             while (cursize > requiresize)               {                  cursize -= ricarray[i--].ne.u.b->Size();               }           }      }  // 0..i is to keep, reinsert others  int j;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲日穴在线视频| 99精品视频在线免费观看| 久久精品亚洲精品国产欧美kt∨ | 亚洲中国最大av网站| 国产精品三级久久久久三级| 欧美韩国日本不卡| 中文字幕+乱码+中文字幕一区| 精品国产伦一区二区三区观看方式| 日韩一区二区三区在线| 日韩欧美一二区| 欧美电影免费观看完整版| 欧美mv日韩mv| 久久久影视传媒| 国产精品护士白丝一区av| 国产精品久久久久婷婷二区次| 国产精品久久国产精麻豆99网站 | 一区二区三区 在线观看视频| 亚洲欧美福利一区二区| 亚洲国产aⅴ天堂久久| 日韩中文字幕麻豆| 久久99精品久久久久婷婷| 国产一区二区三区av电影 | 亚洲欧美综合另类在线卡通| 亚洲乱码中文字幕综合| 亚洲国产另类精品专区| 青青草精品视频| 成人免费毛片嘿嘿连载视频| 91啪在线观看| 欧美大片一区二区| 国产欧美一区二区精品仙草咪| 亚洲三级视频在线观看| 日韩精品色哟哟| 成人免费观看av| 欧美欧美午夜aⅴ在线观看| 日韩免费高清电影| ...xxx性欧美| 免费成人在线观看视频| 成人免费看视频| 欧美精品久久一区二区三区| 国产女人aaa级久久久级| 一区二区三区丝袜| 国产专区综合网| 欧美在线短视频| 久久这里只有精品6| 亚洲精品免费电影| 国产一二三精品| 欧美日韩视频一区二区| 中文字幕欧美激情一区| 青青国产91久久久久久| 一本色道久久加勒比精品| 日韩精品一区二区三区在线观看| 亚洲精品国产无天堂网2021| 紧缚捆绑精品一区二区| 欧美日韩一区在线观看| 国产精品麻豆网站| 国产精品一区二区果冻传媒| 欧美视频一区在线| 国产精品第四页| 黑人巨大精品欧美一区| 91精品国产综合久久久久久久久久| 国产精品国产自产拍高清av| 激情综合色综合久久综合| 欧美肥妇bbw| 亚洲啪啪综合av一区二区三区| 国产成人av电影在线| 日韩欧美国产电影| 日韩精品五月天| 91精品免费在线| 午夜精品久久久久影视| 91久久精品一区二区三| 亚洲猫色日本管| 91视频一区二区| 亚洲少妇最新在线视频| 成人av免费在线观看| 欧美国产欧美综合| 国产激情视频一区二区三区欧美| 日韩三级在线观看| 秋霞国产午夜精品免费视频| 日韩一区二区视频| 久久国产三级精品| 久久综合精品国产一区二区三区| 久久国产成人午夜av影院| 日韩一级二级三级精品视频| 日本一不卡视频| 欧美电影精品一区二区| 欧美aaa在线| 欧美精品一区二区三区一线天视频| 蜜臀精品久久久久久蜜臀| 日韩三级免费观看| 韩国三级在线一区| 中文字幕欧美日韩一区| 99久久er热在这里只有精品15 | 亚洲欧美另类图片小说| 91黄色免费网站| 午夜欧美在线一二页| 欧美第一区第二区| 成人在线视频一区| 亚洲六月丁香色婷婷综合久久 | 日韩欧美123| 国产在线播精品第三| 国产精品久久久久久久久免费相片 | 99精品偷自拍| 日韩国产成人精品| 久久免费午夜影院| 成人美女视频在线观看18| 一区二区三区在线观看欧美| 欧美另类高清zo欧美| 国产福利91精品| 一区二区三区蜜桃网| 日韩三级视频中文字幕| 成人精品视频网站| 亚洲一级电影视频| 91精品国模一区二区三区| 成人久久久精品乱码一区二区三区 | 久久久久久久久久看片| 91福利区一区二区三区| 裸体健美xxxx欧美裸体表演| 国产精品久久久久久久久搜平片 | 亚洲一线二线三线视频| 欧美成人一区二区三区在线观看| 99久久精品免费| 激情图片小说一区| 亚洲制服丝袜在线| 中文字幕av在线一区二区三区| 欧美日韩黄色一区二区| 成人蜜臀av电影| 精品综合久久久久久8888| 亚洲特级片在线| 国产日韩精品一区| 日韩一区二区三区四区| 欧美亚一区二区| 99久久精品国产导航| 国产成人一区在线| 青青草国产精品亚洲专区无| 亚洲一区在线免费观看| 国产精品美女久久久久久| 亚洲精品一线二线三线无人区| 欧美日韩综合不卡| 色偷偷88欧美精品久久久| 成人午夜精品在线| 国产精品影视天天线| 蜜臀91精品一区二区三区| 亚洲国产中文字幕在线视频综合| 国产精品高清亚洲| 欧美国产国产综合| 国产日产精品一区| 久久精品亚洲一区二区三区浴池| 亚洲精品一区二区精华| 精品久久久久久久人人人人传媒 | 久久精品视频在线免费观看| 日韩一区二区精品| 日韩视频一区二区三区在线播放| 911国产精品| 欧美日本一区二区| 欧美绝品在线观看成人午夜影视| 欧美一级久久久久久久大片| 精品污污网站免费看| 欧美亚洲自拍偷拍| 欧美性大战久久久| 69堂精品视频| 日韩午夜中文字幕| 日韩欧美另类在线| 久久久美女艺术照精彩视频福利播放| 日韩一区二区三区免费观看| 精品久久久久久久一区二区蜜臀| 精品国产一区二区在线观看| 久久蜜桃av一区精品变态类天堂| 亚洲精品一区二区三区蜜桃下载| 国产日产欧美精品一区二区三区| 中文字幕 久热精品 视频在线| 亚洲日本免费电影| 亚洲国产日韩精品| 青娱乐精品视频在线| 成人亚洲精品久久久久软件| 99久久伊人精品| 欧美日韩亚洲综合一区二区三区 | 91麻豆精品91久久久久久清纯| 91精品久久久久久久久99蜜臂| 26uuu色噜噜精品一区| 亚洲国产精品国自产拍av| 自拍av一区二区三区| 午夜成人在线视频| 国产剧情一区二区| 欧美亚洲一区二区在线| 日韩欧美一区在线观看| 亚洲欧美一区二区视频| 日韩av网站免费在线| 国产成人精品免费| 欧美美女黄视频| 国产精品你懂的在线欣赏| 亚洲成人激情av| 国产麻豆一精品一av一免费| 色婷婷国产精品综合在线观看| 日韩一区二区在线看| 亚洲欧美激情视频在线观看一区二区三区| 天涯成人国产亚洲精品一区av| 国产精品一区二区不卡| 欧美日韩在线免费视频| 国产欧美日韩不卡免费| 秋霞午夜av一区二区三区|