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

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

?? my23tree.java

?? j2se程序
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/*
 * Created on 2005-5-14
 *
 * TODO To change the template for this generated file go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
package treeNode;

/**
 * @author ade
 *
 * TODO To change the template for this generated type comment go to
 * Window - Preferences - Java - Code Style - Code Templates
 */
import java.io.Serializable;
/**
 * <p>Title: class My23Tree</p>
 * <p>Description: 實現一個3階B-樹(2-3樹).</p>
 * <p>Copyright: Copyright (c) 2004</p>
 * @author WLD
 * @version 1.0
 */

public class My23Tree implements Serializable
{
  private My23TreeNode root;   // 根結點

  // public methods
  // 默認構造方法. 構造一個空的B-樹
  public My23Tree() {
    root = null;
  }

  // 插入關鍵字。若成功則返回true,存在相同關鍵字則返回false
  public boolean insertKey( AbstractKey key, Object record )
  {
    if( root == null )  // 如果樹為空,建立新結點
    {
      root = new My23TreeNode(key, record, null);
    }
    else  // 樹非空
    {
      SearchResult result = search( key ); // 先進行查找以確定插入位置
      if( result.isFound() )               // 存在相同結點,插入失敗
        return false;
      else   // 不存在相同結點,且確定插入位置
      {
        My23TreeNode p = result.getNode();  // 插入位置
        My23TreeNode q = null;              // 分裂時新建立的結點
        int index = result.getIndex();
        while( p.insertKeyAt(key, record, index) == false ) // 需進行結點分裂
        {
          if( q != null )
          {
            p.children[index + 1] = q;      // 更新children引用
          }
          q = new My23TreeNode(p.keys[3], p.records[3], p.parent); // 建立新結點
          q.children[0] = p.children[2];    // 更新children引用
          q.children[1] = p.children[3];
          if( q.children[0] != null ) q.children[0].parent = q; // 更新parent的children指針
          if( q.children[1] != null ) q.children[1].parent = q;
          key = p.keys[2];
          record = p.records[2];
          p.keyNum = 1;          // 修改原結點
          p.keys[2] = p.keys[3] = null;
          p.records[2] = p.records[3] = null;
          p.children[2] = p.children[3] = null;
          if( p.parent == null ) // 若p為根結點,則建立新的根結點
          {
            p.parent = new My23TreeNode( key, record, null );
            p.parent.children[0] = p;
            p.parent.children[1] = q;
            root = p.parent;
            q.parent = p.parent;
            q = null;
            break;
          }
          for( index = 0; p.parent.children[index] != p && index < 2; index++ );
          p = p.parent;          // 更新p和index用于繼續向parent插入關鍵字
        }
        if( q != null )
        {
          p.children[index + 1] = q;  // 如有必要,更新children引用
        }
      }
    }
    return true;
  }

  // 刪除關鍵字
  public Object deleteKey( AbstractKey key )
  {
    SearchResult result = search( key ); // 先進行查找以確定插入位置
    if( !result.isFound() )   // 未找到關鍵字,刪除失敗
      return null;
    else    // 找到了關鍵字
    {
      My23TreeNode p = result.getNode();
      int index = result.getIndex();
      deleteKey( p, index );   // 調用私有方法刪除結點p上的第index個關鍵字
      return result.getRecord();
    }
  }

  // 查找關鍵字。找到則返回指向記錄的引用,否則返回null
  public Object searchByKey( AbstractKey key )
  {
    return search(key).getRecord();
  }

  // 以字符串形式輸出樹的信息
  public String toString()
  {
    return root == null? "" : toString(root, "", false);
  }

  // private methods
  // 私有方法deleteKey刪除給定結點p上的第index個關鍵字
  private void deleteKey( My23TreeNode p, int index )
  {
    if( p.children[0] == null )  // p為最下層結點
    {
      if( p.keyNum > 1 ) // 關鍵字大于1或為根結點,直接刪除即可
      {
        p.deleteKeyAt(index);
        p.keys[p.keyNum+1] = null;
        p.records[p.keyNum+1] = null;
        p.children[p.keyNum+1] = null;
      }
      else               // 否則就麻煩些
      {
        if( p == root )  // 整棵樹就一個根結點且就包含一個關鍵字,刪除后即為空樹一棵
        {
          root = null;
          return;
        }
        int indexInParent = 0;
        if( p.parent.children[1] == p ) indexInParent = 1;
        else if( p.parent.children[2] == p ) indexInParent = 2;  // 確定p在其parent中的位置
        // 右邊的兄弟有足夠的關鍵字,就借一個給parent,并把parent中的拿來給自己
        if( indexInParent < p.parent.keyNum && p.parent.children[indexInParent+1].keyNum > 1 )
        {
          p.keys[index] = p.parent.keys[indexInParent + 1];
          p.records[index] = p.parent.records[indexInParent + 1];

          p.parent.keys[indexInParent + 1] =
              p.parent.children[indexInParent + 1].keys[1];
          p.parent.records[indexInParent + 1] =
              p.parent.children[indexInParent + 1].records[1];

          p.parent.children[indexInParent + 1].keys[1] =
              p.parent.children[indexInParent + 1].keys[2];
          p.parent.children[indexInParent + 1].records[1] =
              p.parent.children[indexInParent + 1].records[2];

          p.parent.children[indexInParent + 1].keys[2] = null;
          p.parent.children[indexInParent + 1].records[2] = null;
          p.parent.children[indexInParent + 1].keyNum = 1;
          return;
        }
        // 左邊的兄弟有足夠的關鍵字
        if( indexInParent > 0 && p.parent.children[indexInParent-1].keyNum > 1 )
        {
          p.keys[index] = p.parent.keys[indexInParent];
          p.records[index] = p.parent.records[indexInParent];

          p.parent.keys[indexInParent] =
              p.parent.children[indexInParent - 1].keys[2];
          p.parent.records[indexInParent] =
              p.parent.children[indexInParent - 1].records[2];

          p.parent.children[indexInParent - 1].keys[2] = null;
          p.parent.children[indexInParent - 1].records[2] = null;
          p.parent.children[indexInParent - 1].keyNum = 1;
          return;
        }
        // 所有相鄰兄弟的關鍵字數目均為1...
        if (indexInParent < p.parent.keyNum) { // 右面有兄弟,向右合并
          p.parent.children[indexInParent] = null;
          p.parent.children[indexInParent + 1].insertKeyAt(
              p.parent.keys[indexInParent + 1],
              p.parent.records[indexInParent + 1], 0);
          p.parent.deleteKeyAt(indexInParent + 1);
          p = p.parent.children[indexInParent + 1];
        }
        else { // 右面沒兄弟左面一定有(B-Tree性質,且p不為根結點),向左合并
          p.parent.children[indexInParent] = null;
          p.parent.children[indexInParent - 1].insertKeyAt(
              p.parent.keys[indexInParent],
              p.parent.records[indexInParent], 1);
          p.parent.keys[indexInParent] = null;
          p.parent.records[indexInParent] = null;
          p.parent.keyNum--;
          p = p.parent.children[indexInParent - 1];
        }
        if (p.parent.keyNum > 0)     // parent中還有足夠結點
          return;               // 刪除完成。無需向上合并
        else { // parent已沒有足夠關鍵字,需要向上重復合并
          p.parent.keys[1] = p.keys[1];
          p.parent.keys[2] = p.keys[2];
          p.parent.records[1] = p.records[1];
          p.parent.records[2] = p.records[2];

          p.parent.children[0] = p.parent.children[1] =
              p.parent.children[2] = null;
          p.parent.keyNum = 2;
          p = p.parent;
          merge(p);
        }
      }
    } // if( p.children[0] == null )  // p為最下層結點
    else  // p非最下層結點
    {
      My23TreeNode q = p.children[index];
      while( q.children[0] != null )
        q = q.children[0];           // 找到對應子樹中包含最小關鍵字的結點
      p.keys[index] = q.keys[1];     // 用對應子樹中的最小關鍵字代替
      p.records[index] = q.records[1];
      deleteKey( q, 1 );             // 刪除多余的最小關鍵字
    }
  }

  // 用于刪除結點時“合并”的方法。將srcNode和其parent中的對應關鍵字一起合并到相鄰兄弟結點
  // 此方法中并未刪除任何關鍵字,只是對在deleteKey方法中刪除掉關鍵字的樹進行整理合并
  private void merge( My23TreeNode node )
  {
    if( node == root ) return;

    int indexInParent = 0;
    if (node.parent.children[1] == node) indexInParent = 1;
    else if (node.parent.children[2] == node) indexInParent = 2; // 確定node在其parent中的位置

    while( true )
    {
      if (indexInParent < node.parent.keyNum) { // node右面有兄弟,向右合并

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久久久| 亚洲精品一区二区三区99| 欧美电影在线免费观看| 国产日韩欧美不卡在线| 香蕉久久夜色精品国产使用方法 | 一区二区三区在线视频免费观看| 老司机免费视频一区二区三区| 91在线一区二区三区| 精品福利视频一区二区三区| 亚洲综合在线免费观看| 国产91露脸合集magnet| 精品欧美一区二区久久| 亚洲va韩国va欧美va精品| 一本久久a久久精品亚洲 | 日韩一区二区三区在线观看| 一区二区三区波多野结衣在线观看| 国产精品69毛片高清亚洲| 日韩一区二区在线看片| 亚洲成人午夜电影| 91国偷自产一区二区三区成为亚洲经典| 精品sm在线观看| 久久国产精品色| 欧美成人女星排名| 精品在线观看免费| 久久这里只精品最新地址| 免费成人在线观看| 538prom精品视频线放| 亚洲一区二区视频| 欧美在线观看视频一区二区| 亚洲精品美腿丝袜| 96av麻豆蜜桃一区二区| 亚洲免费观看高清| 在线影院国内精品| 一区二区三区在线高清| 欧美亚洲一区二区在线| 亚洲国产精品人人做人人爽| 在线观看一区不卡| 亚洲狠狠爱一区二区三区| 欧美图片一区二区三区| 五月婷婷激情综合| 日韩精品一区二区三区在线观看| 欧美aaa在线| 国产色综合一区| 成人激情免费电影网址| 国产精品国产a级| 色欧美日韩亚洲| 婷婷久久综合九色国产成人| 欧美夫妻性生活| 国产精品资源在线看| 国产精品日产欧美久久久久| 色婷婷av一区二区| 日韩av在线发布| 国产喂奶挤奶一区二区三区| 成人国产电影网| 亚洲一区二区五区| 精品三级在线看| 成年人国产精品| 性感美女极品91精品| 精品国产一二三区| 91免费视频观看| 午夜精品福利一区二区三区av | 久久精品国产亚洲高清剧情介绍 | 精品国一区二区三区| 国产成人99久久亚洲综合精品| 首页综合国产亚洲丝袜| 精品国产乱码久久久久久蜜臀| www.欧美色图| 天堂一区二区在线| 国产情人综合久久777777| 在线视频你懂得一区二区三区| 蜜桃一区二区三区在线观看| 综合欧美一区二区三区| 精品入口麻豆88视频| 99久久国产综合精品女不卡| 日韩av电影天堂| 亚洲欧美在线视频| 欧美成人aa大片| 色婷婷精品大视频在线蜜桃视频 | 99re66热这里只有精品3直播| 日韩激情视频网站| 国产精品高清亚洲| 337p粉嫩大胆噜噜噜噜噜91av| 在线观看成人小视频| 国产精品主播直播| 美国三级日本三级久久99| 亚洲人成人一区二区在线观看| 日韩免费高清电影| 欧美电影在线免费观看| 91九色最新地址| av网站免费线看精品| 国产真实精品久久二三区| 亚洲一二三级电影| 亚洲麻豆国产自偷在线| 国产欧美视频一区二区| 精品国产三级电影在线观看| 欧美精品在线视频| 91九色02白丝porn| 色婷婷激情一区二区三区| www.爱久久.com| 丁香另类激情小说| 国产一区视频在线看| 免费成人av在线| 午夜不卡av在线| 亚洲国产综合91精品麻豆| 一卡二卡欧美日韩| 最新热久久免费视频| 国产精品五月天| 国产精品久久毛片av大全日韩| 日本一区二区高清| 最新不卡av在线| 亚洲日本成人在线观看| 亚洲欧洲日韩在线| 国产精品久久精品日日| 国产精品盗摄一区二区三区| 中文字幕欧美激情一区| 国产三级一区二区三区| 久久在线免费观看| 中文字幕av一区二区三区高| 国产精品嫩草影院av蜜臀| 中文字幕一区二区三区色视频| 国产精品久线在线观看| 亚洲精品视频在线看| 一区二区三区在线观看动漫| 亚洲国产毛片aaaaa无费看 | 欧美天堂一区二区三区| 在线视频你懂得一区二区三区| 91国产福利在线| 欧美日韩一区二区在线观看| 欧美一区二区三区在| 日韩精品一区二区三区视频播放 | 成人免费小视频| 国产精品激情偷乱一区二区∴| 国产欧美精品区一区二区三区| 国产午夜亚洲精品不卡| 国产精品久久久久精k8 | 亚洲嫩草精品久久| 午夜成人免费电影| 国产麻豆午夜三级精品| gogo大胆日本视频一区| 欧美最新大片在线看| 日韩欧美中文一区二区| 久久婷婷综合激情| 亚洲视频一二三| 亚洲精品乱码久久久久久久久 | 精品电影一区二区三区| 欧美激情一区二区三区在线| 日本一区二区成人| 亚洲一区二区三区四区在线免费观看 | 色偷偷成人一区二区三区91| 成人av网站在线观看免费| 97国产精品videossex| 欧美丰满嫩嫩电影| 欧美大度的电影原声| 国产视频不卡一区| 亚洲三级免费观看| 国产资源精品在线观看| 成人午夜精品在线| 欧美在线视频不卡| 精品噜噜噜噜久久久久久久久试看| 在线观看视频91| 国产午夜三级一区二区三| 怡红院av一区二区三区| 久草精品在线观看| 在线视频国产一区| 久久在线观看免费| 亚洲精品老司机| 经典一区二区三区| 欧美在线视频日韩| 国产欧美日韩另类一区| 亚洲一级二级三级在线免费观看| 久久99国产精品尤物| 欧美中文字幕一二三区视频| 日韩欧美国产一区在线观看| 国产精品久久久久影院| 男女男精品视频网| 国产成人免费在线视频| 欧美mv日韩mv国产网站app| 亚洲视频中文字幕| 精品一区二区在线看| 99精品久久久久久| 国产精品久久久久毛片软件| 免费成人在线观看视频| 色综合天天狠狠| 精品国产乱码91久久久久久网站| 日日摸夜夜添夜夜添精品视频 | 成人黄色av电影| 久久久久国产精品人| 亚洲成av人在线观看| 99久久精品国产观看| 久久亚洲精品小早川怜子| 日韩激情一区二区| 91日韩在线专区| 日本一区二区久久| 久久99久国产精品黄毛片色诱| 欧美人体做爰大胆视频| 一区二区在线观看视频在线观看| 国产黑丝在线一区二区三区| 欧美三级在线看| 午夜影院久久久| 欧美亚洲国产一区二区三区|