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

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

?? bpmain.cpp

?? 數(shù)據(jù)結(jié)構(gòu)與算法分析(C++)(版第二版)源碼
?? CPP
字號:
// WARNING: This is NOT a complete implementation for B+-trees.
// The sole purpose of this code is to do a syntactic check on the book
// pseudocode.  You can probably create a complete B+-tree implementation
// by implementing the missing functions, but I make no guarentees.
// The purpose of the book pseudocode is not to present an implementation,
// but only to illustrate how the B+-tree works.

#include <iostream.h>
#include <stdlib.h>
#include <string.h>

#include "book.h"
#include "compare.h"

#define MAXREC 10
#define THRESHOLD 6

template <class Key>
class PAIR {
public:
  void* ptr; // Elem* for leaves, BPNode* for internals
  Key key;
};

template <class Key>
class BPNode {
public:
  PAIR<Key> recs[MAXREC];
  int numrec;
  BPNode* leftptr;  BPNode* rightptr; // Link the levels
  bool isLeaf() const;  // True if the node is a leaf
  bool isFull() const;  // True if the node is full
};

template <class Key>
bool BPNode<Key>::isLeaf() const { return false; } // Dummy return

template <class Key>
bool BPNode<Key>::isFull() const { return false; } // Dummy return

template <class Key, class Elem, class KKcomp>
class BPTree {
private:
  BPNode<Key>* root;
  int reccount;
  bool findhelp(BPNode<Key>* root, const Key& K, Elem*& e) const;
  bool inserthelp(BPNode<Key>* root, const Key& K, Elem* e,
                  Key& retval, void*& retptr);
  bool removehelp(BPNode<Key>* root, const Key& K, Elem*& e);
public:
  BPTree() { root = NULL; reccount = 0; }
  ~BPTree() {};
  bool insert(const Key& K, Elem* e) { // Insert node with value val
    Elem retval;               // Smallest value in newly created node
    void* retptr = NULL; // Newly created node
    bool inssucc = inserthelp(root, K, e, retval, retptr);
    if (retptr != NULL) {      // Root overflowed: make new root
      BPNode<Key>* temp = new BPNode<Key>;
      temp->recs[0].key = root->recs[0].key;
      temp->recs[0].ptr = root;
      temp->recs[1].key = retval;
      temp->recs[1].ptr = retptr;
      root = temp;
    }
    if (inssucc) reccount++;
    return inssucc;
  }
  bool remove(const Key& K, Elem*& e) {
    e = NULL;
    removehelp(root, K, e);
    return e != NULL;
  }
  bool find(const Key& K, Elem*& e) const { findhelp(root, K, e); }
};


template <class Key, class Elem, class KKcomp>
bool BPTree<Key, Elem, KKcomp>::
findhelp(BPNode<Key>* root, const Key& K, Elem*& e) const {
  // function binaryle(A, n, K) returns the greatest value
  //   less than or equal to K in array A of length n.
  int currec = binaryle(root->recs, root->numrec, K);
  if (root->isLeaf())
    if (KKcomp::eq(root->recs[currec].key, K)) {
      e = (Elem*) root->recs[currec].ptr;
      return true;
    }
    else return false;
  else return findhelp((BPNode<Key>*)
                       root->recs[currec].ptr, K, e);
}

template <class Key>
int binaryle(PAIR<Key>* array, int numrec, Key K) { return 0; }

template <class Key>
void putinarray(PAIR<Key>* array, int currec, Key retval, void* retptr) {}

template <class Key>
void* splitnode(BPNode<Key>* root, int currect, Key& myretv,
		void*& myretp) { return NULL; } // Dummy return

// B+-tree pseudocode: insert
// binaryle(A, n, K) returns the greatest value less
// than or equal to K in array A of length n.
// putinarray(A, pos, k, p) places in array A at
// position pos the key/pointer pair k and p.
// splitnode(rt, pos, k, p) places in node rt at
// position pos the key/pointer pair k/p.  In the process,
// the node is split into two, each taking half of the
// records, and the new node is returned.
template <class Key, class Elem, class KKcomp>
bool BPTree<Key, Elem, KKcomp>::
inserthelp(BPNode<Key>* subroot, const Key& K, Elem* e,
           Key& retval, void*& retptr) {
  Key myretv;  // Least key in new node if current is split
  void* myretp = NULL; // Pointer to new node on split

  int currec = binaryle(subroot->recs, subroot->numrec, K);
  if (subroot->isLeaf()) { // Leaf node: set insert values
    myretv = K;
    myretp = e;
  }
  else { // internal node
    inserthelp((BPNode<Key>*)subroot->recs[currec].ptr,
               K, e,  myretv, myretp);
    if (myretp == NULL) return true; // Child did not split,
  }                     // no need to insert to current node

  // Do insert to the current node.  Split if necessary
  if (subroot->isLeaf() &&
      KKcomp::eq(subroot->recs[currec].key, myretv))
    return false; // Duplicate
  if (!subroot->isFull())
    putinarray<Key>(subroot->recs, currec, myretv, myretp);
  else {
    retptr = splitnode<Key>(subroot, currec, myretv,myretp);
    retval = ((BPNode<Key>*)retptr)->recs[0].key;
  }
  return true;
}

template <class Key>
void removerec(BPNode<Key>* root, int currec) {}

template <class Key>
void merge_nodes(BPNode<Key>* root, BPNode<Key>* right) {}

template <class Key>
void shuffle_nodes(BPNode<Key>* root, BPNode<Key>* right) {}

// removehelp returns TRUE if a child has been removed.
//   If so, adjustment to the current node is required.
// binaryle(A, n, K) returns the greatest value less than
//   or equal to K in array A of length n.
// removerec(A, n, c) removes record at position c from
//   array A with n records.
// merge_nodes(N1, N2) merges together the record arrays of
//   BPNodes N1 and N2.
// shuffle_nodes(N1, N2) copies execess records from BPNode
//   N2 to BPNode N1, so that both have equal # of records. 
template <class Key, class Elem, class KKcomp>
bool BPTree<Key, Elem, KKcomp>::
removehelp(BPNode<Key>* subroot, const Key& K,
           Elem*& retval) {
  int currec;  bool delchild;

  currec = binaryle(root->recs, root->numrec, K);
  if (root->isLeaf())
    if (!KKcomp::eq(K, root->recs[currec].key))
      return false;
    else retval = (Elem*)root->recs[currec].ptr;
  else // Delete from child
    if (!removehelp((BPNode<Key>*) root->recs[currec].ptr,
                          K, retval))
       return false; // Child did not collapse
  // Now, remove record at position currec
  removerec(root, currec);
  if (root->numrec > THRESHOLD) return false;
  else                           // Underflow
    if (root->leftptr == NULL)   // No left neighbor
      if (root->numrec + root->rightptr->numrec <= MAXREC) {
        merge_nodes(root, root->rightptr);
        return true;
      }
      else {                     // Key value has changed
        shuffle_nodes(root, root->rightptr);
        retval = (Elem*)root->rightptr->recs[0].ptr;
        return false;
      }
    else if (root->numrec+root->leftptr->numrec <= MAXREC) {
      merge_nodes(root->leftptr, root);
      return true;
    }
    else {
      shuffle_nodes(root, root->leftptr);
      retval = (Elem*)root->recs[0].ptr;
      return false;
    }
}

int main()
{
  BPTree<int,int,intintCompare> tree;

  int* val;
  tree.find(5, val);
  tree.insert(5, val);
  tree.remove(5, val);
  return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91网站最新地址| 久久99精品一区二区三区 | 亚洲欧美一区二区在线观看| 国产露脸91国语对白| 久久久精品tv| 99久久777色| 亚洲国产精品久久人人爱蜜臀| 欧美天堂一区二区三区| 午夜欧美大尺度福利影院在线看| 制服视频三区第一页精品| 老司机精品视频一区二区三区| 久久久久久黄色| 色综合久久中文综合久久97| 日一区二区三区| 精品少妇一区二区三区日产乱码| 成人妖精视频yjsp地址| 亚洲影院理伦片| 日韩美女一区二区三区四区| www.视频一区| 日本sm残虐另类| 国产清纯在线一区二区www| 91麻豆123| 精品伊人久久久久7777人| 国产精品久久久久精k8| 欧美久久久久免费| 国产成人精品在线看| 亚洲成在线观看| 日本一区二区三区dvd视频在线| 91黄色激情网站| 国产乱淫av一区二区三区| 亚洲国产精品尤物yw在线观看| 精品国产乱码久久久久久夜甘婷婷| www.日本不卡| 麻豆精品在线观看| 亚洲一区二区黄色| 国产日韩av一区| 日韩三级精品电影久久久| 97久久精品人人做人人爽| 久久99热这里只有精品| 一区二区三区免费在线观看| 久久综合色天天久久综合图片| 91黄视频在线观看| 成人网在线播放| 国内精品嫩模私拍在线| 亚洲午夜影视影院在线观看| 国产精品天干天干在观线| 欧美sm美女调教| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲自拍偷拍麻豆| 国产视频911| 精品日韩一区二区三区| 欧美日韩色一区| 色综合天天做天天爱| 成人在线视频首页| 激情久久久久久久久久久久久久久久 | 欧美人成免费网站| 91福利在线播放| 99re这里只有精品视频首页| 国产最新精品免费| 精品一区二区在线看| 日韩成人av影视| 日精品一区二区三区| 亚洲一区二区偷拍精品| 亚洲精品网站在线观看| 中文字幕一区二区视频| 国产日产欧美精品一区二区三区| 久久综合九色综合欧美98| 欧美一区二区日韩| 欧美一区二区高清| 欧美一级夜夜爽| 日韩精品中文字幕在线一区| 欧美精品日日鲁夜夜添| 欧美写真视频网站| 91丨porny丨户外露出| 色综合天天天天做夜夜夜夜做| 成人国产精品免费观看| 丰满白嫩尤物一区二区| 成人黄色在线看| 99re8在线精品视频免费播放| 99久久国产综合精品色伊| 成人黄色a**站在线观看| 91视视频在线观看入口直接观看www| av电影在线观看不卡| 色综合天天综合网天天狠天天 | 欧洲视频一区二区| 色视频成人在线观看免| 欧美视频一区二区| 6080亚洲精品一区二区| 久久伊99综合婷婷久久伊| 国产欧美日韩另类一区| 中文字幕在线不卡视频| 一区二区三区四区在线播放| 亚洲国产一区视频| 蜜桃视频第一区免费观看| 国产制服丝袜一区| 99精品视频中文字幕| 在线视频国内自拍亚洲视频| 欧美日韩精品一区二区三区| 日韩精品一区二区三区老鸭窝| 久久综合狠狠综合久久综合88| 国产网红主播福利一区二区| 亚洲欧美日韩小说| 毛片一区二区三区| 国产**成人网毛片九色 | 日产国产高清一区二区三区 | 成熟亚洲日本毛茸茸凸凹| 97久久超碰精品国产| 7777精品伊人久久久大香线蕉完整版| 精品蜜桃在线看| 自拍偷拍国产精品| 麻豆精品久久精品色综合| 国产91清纯白嫩初高中在线观看| 日本高清视频一区二区| 日韩欧美在线观看一区二区三区| 国产精品视频第一区| 首页欧美精品中文字幕| 成人va在线观看| 欧美一区二区三区在线看| 日韩一区中文字幕| 激情综合亚洲精品| 色呦呦日韩精品| 久久午夜羞羞影院免费观看| 亚洲电影激情视频网站| 国产福利电影一区二区三区| 欧美精品一二三四| 亚洲天堂网中文字| 国产盗摄视频一区二区三区| 精品视频全国免费看| 国产精品久久二区二区| 另类小说色综合网站| 91福利在线观看| 国产精品毛片a∨一区二区三区| 蜜桃一区二区三区四区| 在线观看日韩电影| 国产精品激情偷乱一区二区∴| 裸体歌舞表演一区二区| 欧美体内she精高潮| 最新日韩av在线| 成人一级视频在线观看| 精品国内二区三区| 午夜久久久久久| 欧美无乱码久久久免费午夜一区| 国产精品久久久久三级| 国产麻豆9l精品三级站| 精品欧美久久久| 亚洲v中文字幕| 欧美视频你懂的| 一区二区在线观看免费视频播放| 成人激情黄色小说| 国产校园另类小说区| 狠狠网亚洲精品| 欧美成人精精品一区二区频| 免费在线观看精品| 欧美一区二区性放荡片| 欧美aaaaaa午夜精品| 91精品国产综合久久久久| 亚洲成av人片一区二区| 欧美日韩黄色影视| 亚洲国产一区二区在线播放| 欧美伊人精品成人久久综合97| 日韩美女精品在线| 91在线无精精品入口| 国产精品不卡在线观看| 91美女视频网站| 一区二区三区美女| 欧美区视频在线观看| 日韩电影在线一区| 精品久久久久一区二区国产| 九色综合狠狠综合久久| 久久网这里都是精品| 成人性视频免费网站| 综合久久久久综合| 欧美午夜精品久久久久久孕妇| 亚洲一区二区成人在线观看| 欧美年轻男男videosbes| 日韩福利电影在线| 久久色成人在线| 国产91丝袜在线播放九色| 亚洲欧美一区二区三区极速播放| 91网上在线视频| 午夜精品久久久久久久蜜桃app| 欧美精品一二三| 国产一区二区三区免费播放| 国产精品乱人伦中文| 色一区在线观看| 日本欧美在线观看| 久久精品人人做| 色偷偷一区二区三区| 日本三级亚洲精品| 国产日韩精品一区二区三区| 色婷婷国产精品| 麻豆国产欧美日韩综合精品二区| 国产色婷婷亚洲99精品小说| 色哟哟日韩精品| 蜜臀久久久久久久| 国产精品毛片久久久久久| 欧美三级中文字幕| 国产一区在线观看视频| 亚洲乱码国产乱码精品精可以看| 制服丝袜日韩国产|