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

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

?? cmxbtree.cpp

?? CMXBTree 的主要作用是在內存中建立一棵B+樹
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
            if( pGreaterThan )
            {
                //if( pSearchDataLeaf->pDataCont[1]->pData )
                if( pSearchDataLeaf->pDataCont[1] )
                    *pGreaterThan =  pSearchDataLeaf->pDataCont[1]->pData;
                else
                {
                    if( pSearchDataLeaf->pNext )
                    {
                        pSearchDataLeaf2 = pSearchDataLeaf->pNext;
                        *pGreaterThan =  pSearchDataLeaf2->pDataCont[0]->pData;
                    }
                    else *pGreaterThan = NULL;
                }
            }
        }
        else
        {
            if( pLessThan ) 
                *pLessThan = pSearchDataLeaf->pDataCont[i-1]->pData;

            if( pGreaterThan )
            {
                if( i+1 < BTREE_DEGREE && pSearchDataLeaf->pDataCont[i+1])
                    *pGreaterThan =  pSearchDataLeaf->pDataCont[i+1]->pData;
                else
                {
                    if( pSearchDataLeaf->pNext )
                    {
                        pSearchDataLeaf2 = pSearchDataLeaf->pNext;
                        *pGreaterThan =  pSearchDataLeaf2->pDataCont[0]->pData;
                    }
                    else *pGreaterThan = NULL;
                }
            }
        }
    }

    pRet =  pSearchResult->pData;
    if( pSK )
        pSK->m_pSearchResult = pSearchResult->pNext;
    return pRet;
}

template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::GetNextKey( SEARCH_KEY *pSK )
{
    if( pSK == NULL )  return NULL;

    if( pSK->m_GetKey.m_pProv == NULL ) return NULL;

    if( pSK->m_GetKey.m_DataCont == NULL) 
    {
        if( (pSK->m_GetKey.m_nDataElemIndex < BTREE_DEGREE) && 
            (pSK->m_GetKey.m_pProv->pDataCont[pSK->m_GetKey.m_nDataElemIndex] != NULL )
            )
        {
            pSK->m_GetKey.m_DataCont = 
                pSK->m_GetKey.m_pProv->pDataCont[pSK->m_GetKey.m_nDataElemIndex];
            return  pSK->m_GetKey.m_DataCont->pData;
        }
        else
        {
            pSK->m_GetKey.m_nDataElemIndex --;
            pSK->m_GetKey.m_DataCont = 
                pSK->m_GetKey.m_pProv->pDataCont[pSK->m_GetKey.m_nDataElemIndex];
            return GetNextKey( &(pSK->m_GetKey) );
            
        }
    }
    else
        return GetNextKey( &(pSK->m_GetKey) );
}

template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::GetPrevKey( SEARCH_KEY *pSK )
{
    if( pSK == NULL )  return NULL;

    if( pSK->m_GetKey.m_pProv == NULL ) return NULL;

    if( pSK->m_GetKey.m_DataCont == NULL) 
    {
        if( pSK->m_GetKey.m_nDataElemIndex > 0) 
        {
            pSK->m_GetKey.m_nDataElemIndex --;
            pSK->m_GetKey.m_DataCont = 
                pSK->m_GetKey.m_pProv->pDataCont[pSK->m_GetKey.m_nDataElemIndex];
            return  pSK->m_GetKey.m_DataCont->pData;
        }
        else
        {
            pSK->m_GetKey.m_DataCont = 
                pSK->m_GetKey.m_pProv->pDataCont[pSK->m_GetKey.m_nDataElemIndex];
            return GetPrevKey( &(pSK->m_GetKey) );
            
        }
    }
    else
        return GetPrevKey( &(pSK->m_GetKey) );
}


template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::SearchNextKey( SEARCH_KEY *pSK )
{
    if( pSK == NULL )  return NULL;

    RECTYPE* pRet;
    if( !pSK->m_pSearchResult ) return NULL;

    pRet = pSK->m_pSearchResult->pData;
    pSK->m_pSearchResult = pSK->m_pSearchResult->pNext;
    return pRet;
}

template <class RECTYPE>
int CMXBTree<RECTYPE>::DeleteKey( SEARCH_KEY *pSK, RECTYPE * pRec )
{
    
    if( pRec == NULL || pSK == NULL ) return 1;

    if( pSK->m_pSearchResultOrig == NULL ) return 1;

    if( pSK->m_pSearchDataLeaf == NULL ) return 1;

    DATA_CONTAINER *p = pSK->m_pSearchResultOrig, *q ;

    while( p && p->pData != pRec )
        p = p->pNext;

    if( p == NULL )  return 1;

    if( p->pProv == NULL && p->pNext == NULL) //只有一個元素
    {
        RECTYPE key = *pRec;
        return DeleteKey( key );
        return 1;
    }
    else
    if( p->pProv == NULL )
    {
/*
        int i;
        for( i = 0; i < BTREE_DEGREE; i++ )
        {
            if( p == pSK->m_pSearchDataLeaf->pDataCont[i] )
                break;
        }
        
        if( i == BTREE_DEGREE ) return 1;
 */      
        if( p != pSK->m_pSearchResultOrig ) return 1;
        
        p = p->pNext;

        *(pSK->m_pSearchResultOrig->pData) = *(p->pData);

        if( p == pSK->m_pSearchResult )
            pSK->m_pSearchResult = pSK->m_pSearchResultOrig;
    }

    q = p->pProv;
    q->pNext = p->pNext;
    q = p->pNext;
    if( q ) q->pProv = p->pProv;
    DeleteRecType( p->pData );
    DeleteDataContainer( p );
    return 0;
}


template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::GetFirstKey( GET_KEY * pGK )
{
    if( pGK == NULL ) return NULL;
    
    memset( pGK, 0, sizeof(GET_KEY) );

    if( MakeDataList() < 0 ) return NULL;
    pGK->m_nDataElemIndex = 0;
    pGK->m_pProv = m_pDataLeafList;
    if( ! pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex] ) return NULL;
    pGK->m_DataCont = pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex];
    RECTYPE* pRet = pGK->m_DataCont->pData;
    pGK->m_DataCont = pGK->m_DataCont->pNext;
    return pRet;
}


template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::GetLastKey( GET_KEY * pGK )
{
    if( pGK == NULL ) return NULL;
    
    memset( pGK, 0, sizeof(GET_KEY) );

    if( MakeDataList() < 0 ) return NULL;
    pGK->m_pProv = m_pDataLeafListTail;
    
    int i;
    for( i = BTREE_DEGREE - 1; i >= 0; i -- )
    {
        if( pGK->m_pProv->pDataCont[i] ) 
           break;
    }
    
    if( i < 0 ) return NULL;

    pGK->m_nDataElemIndex = i;
    
    pGK->m_DataCont = pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex];
    RECTYPE* pRet = pGK->m_DataCont->pData;
    pGK->m_DataCont = pGK->m_DataCont->pNext;
    return pRet;
}


template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::GetNextKey( GET_KEY * pGK, bool bGetDup )
{
    if( m_bMadeList == false ) return NULL;
    if( pGK == NULL ) return NULL;

    if( !pGK->m_pProv ) return NULL;
    if( pGK->m_DataCont && bGetDup )
    {
        RECTYPE* pRet = pGK->m_DataCont->pData;
        pGK->m_DataCont = pGK->m_DataCont->pNext;
        return pRet;
    }

    if( (pGK->m_nDataElemIndex+1 < BTREE_DEGREE) && pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex+1] ) //本數據葉還有元素可返回
    {
        pGK->m_nDataElemIndex++;
        pGK->m_DataCont = pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex];

        RECTYPE* pRet = pGK->m_DataCont->pData;
        pGK->m_DataCont = pGK->m_DataCont->pNext;
        return pRet;
    }
    else
    {
        pGK->m_pProv = pGK->m_pProv->pNext;
        if( pGK->m_pProv )
        {
            pGK->m_nDataElemIndex = 0;
            if( pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex] )
            {
                pGK->m_DataCont = pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex];
                
                RECTYPE* pRet = pGK->m_DataCont->pData;
                pGK->m_DataCont = pGK->m_DataCont->pNext;

                return pRet;
            }
            else
                return NULL;
        }
        else
            return NULL;
    }
}


template <class RECTYPE>
RECTYPE* CMXBTree<RECTYPE>::GetPrevKey( GET_KEY * pGK, bool bGetDup )
{
    if( m_bMadeList == false ) return NULL;
    if( pGK == NULL ) return NULL;

    if( !pGK->m_pProv ) return NULL;
    if( pGK->m_DataCont && bGetDup )
    {
        RECTYPE* pRet = pGK->m_DataCont->pData;
        pGK->m_DataCont = pGK->m_DataCont->pNext;
        return pRet;
    }

    if( pGK->m_nDataElemIndex - 1 >= 0 ) //本數據葉還有元素可返回
    {
        pGK->m_nDataElemIndex --;
        pGK->m_DataCont = pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex];

        RECTYPE* pRet = pGK->m_DataCont->pData;
        pGK->m_DataCont = pGK->m_DataCont->pNext;
        return pRet;
    }
    else
    {
        pGK->m_pProv = pGK->m_pProv->pProv;
        if( pGK->m_pProv )
        {

            int i;
            for( i = BTREE_DEGREE - 1; i >= 0; i -- )
            {
                if( pGK->m_pProv->pDataCont[i] ) 
                    break;
            }

            if( i < 0 ) return NULL;

            pGK->m_nDataElemIndex = i;

            pGK->m_DataCont = pGK->m_pProv->pDataCont[pGK->m_nDataElemIndex];
            
            RECTYPE* pRet = pGK->m_DataCont->pData;
            pGK->m_DataCont = pGK->m_DataCont->pNext;
            return pRet;
        }
        else
            return NULL;
    }
}


template <class RECTYPE>
int CMXBTree<RECTYPE>::SubMakeDataList( BTREE_INDEX_LEAF *pSearchIndexLeaf )
{
    if ( !pSearchIndexLeaf ) return -1; //無效的索引葉指針?BTREE 錯誤

    if( pSearchIndexLeaf->cPointerType == DATA_LEAF_POINTER ) //下面就是數據葉
    {
        if( pSearchIndexLeaf->pLeafLeft ) //最左的指針有效
        {
            if( m_pDataLeafList == NULL) 
            {   //隊列還沒有開始建立
                m_pDataLeafList = (BTREE_DATA_LEAF *) pSearchIndexLeaf->pLeafLeft;
                m_pProv = (BTREE_DATA_LEAF *) pSearchIndexLeaf->pLeafLeft;
                m_pProv->pProv = NULL;
                m_pProv->pNext = NULL;
            }
            else
            {   //隊列已經建立了
                m_pProv->pNext = (BTREE_DATA_LEAF *)pSearchIndexLeaf->pLeafLeft;
                m_pProv->pNext->pProv = m_pProv;
                m_pProv = (BTREE_DATA_LEAF *)pSearchIndexLeaf->pLeafLeft;
                m_pProv->pNext = NULL;
            }
        }

        //一個一個地對索引葉下面的數據葉建立鏈表
        int i;
        for( i = 0; i < BTREE_DEGREE; i ++ )
        {
            if( pSearchIndexLeaf->IndexKeys[i].pKey )
            {
                if( m_pDataLeafList == NULL) 
                {
                    m_pDataLeafList = (BTREE_DATA_LEAF *) pSearchIndexLeaf->IndexKeys[i].pKeyRight;
                    m_pProv = (BTREE_DATA_LEAF *) pSearchIndexLeaf->IndexKeys[i].pKeyRight;
                    m_pProv->pNext = NULL;
                    m_pProv->pProv = NULL;
                }
                else
                {
                    m_pProv->pNext = (BTREE_DATA_LEAF *) pSearchIndexLeaf->IndexKeys[i].pKeyRight;
                    m_pProv->pNext->pProv = m_pProv;
                    m_pProv = (BTREE_DATA_LEAF *) pSearchIndexLeaf->IndexKeys[i].pKeyRight;
                    m_pProv->pNext = NULL;
                }
            }
            else break;
        }
    }
    else
    if( pSearchIndexLeaf->cPointerType == INDEX_LEAF_POINTER ) //下面還是索引葉
    {
        //對最左的兒子第歸
         if( SubMakeDataList((BTREE_INDEX_LEAF *)pSearchIndexLeaf->pLeafLeft) < -1 )
             return -1;
         //對其他兒子第歸
        int i;
        for( i = 0; i < BTREE_DEGREE; i ++ )
        {
            if( pSearchIndexLeaf->IndexKeys[i].pKey )
            {
                 if( SubMakeDataList((BTREE_INDEX_LEAF *)pSearchIndexLeaf->IndexKeys[i].pKeyRight) < -1 )
                     return -1;
            }
            else break;
        }
    }
    else return -1;

    return 0;
}


//把整棵樹鏟除
//也是用第歸
template <class RECTYPE>
int CMXBTree<RECTYPE>::SubDestroyTree( BTREE_INDEX_LEAF *pSearchIndexLeaf )
{
    if ( !pSearchIndexLeaf ) return -1;
    int i,j;
    if( pSearchIndexLeaf->cPointerType == DATA_LEAF_POINTER ) //下面已經是數據葉
    {
        if( pSearchIndexLeaf->pLeafLeft ) //最左的指針有效
        {
            BTREE_DATA_LEAF *pTmp = (BTREE_DATA_LEAF *)pSearchIndexLeaf->pLeafLeft;
            for( i = 0; i < BTREE_DEGREE; i++ )
            {
                if( pTmp->pDataCont[i] )
                    DeleteDataContainerTrain( pTmp->pDataCont[i] );
                else break;
            }
            DeleteDataLeaf( pTmp );
        }
        
        for( i = 0; i < BTREE_DEGREE; i ++ )
        {
            if( pSearchIndexLeaf->IndexKeys[i].pKey )
            {
                BTREE_DATA_LEAF *pTmp = (BTREE_DATA_LEAF *)pSearchIndexLeaf->IndexKeys[i].pKeyRight;
                for( j = 0; j < BTREE_DEGREE; j++ )
                {
                    if( pTmp->pDataCont[j] )
                        DeleteDataContainerTrain( pTmp->pDataCont[j] );
                    else break;
                }
                DeleteDataLeaf( pTmp );
            }
            else break;
        }
        DeleteIndexLeaf( pSearchIndexLeaf );
    }
    else
    if( pSearchIndexLeaf->cPointerType == INDEX_LEAF_POINTER )
    {
         if( SubDestroyTree((BTREE_INDEX_LEAF *)pSearchIndexLeaf->pLeafLeft) < -1 )
             return -1;
        int i;
        for( i = 0; i < BTREE_DEGREE; i ++ )
        {
            if( pSearchIndexLeaf->IndexKeys[i].pKey )
            {
                 if( SubDestroyTree((BTREE_INDEX_LEAF *)pSearchIndexLeaf->IndexKeys[i].pKeyRight) < -1 )
                     return -1;
            }
            else break;
        }
        DeleteIndexLeaf( pSearchIndexLeaf );
    }
    else return -1;

    return 0;
}


#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性做爰猛烈叫床潮| 成人av在线播放网址| 欧美肥胖老妇做爰| 日本视频在线一区| 精品免费视频.| 国产一区二区精品久久99| 国产精品视频一区二区三区不卡| 成人教育av在线| 亚洲成人中文在线| 欧美xxxx老人做受| 99精品久久久久久| 视频一区中文字幕| 国产欧美一区二区精品久导航 | 91精品国产高清一区二区三区| 奇米精品一区二区三区在线观看| 久久综合九色综合97婷婷 | 亚洲欧洲无码一区二区三区| 在线观看精品一区| 久久国产欧美日韩精品| 日本一二三四高清不卡| 精品视频在线免费看| 国产曰批免费观看久久久| 国产精品久久久久久久久果冻传媒| 欧美三区在线视频| 国产在线精品免费| 一区二区三区.www| www国产亚洲精品久久麻豆| 99久久精品免费看| 久久er精品视频| 亚洲欧美日韩中文播放| 精品日韩欧美在线| 在线视频一区二区三| 国产精品一区专区| 日韩国产欧美视频| 亚洲色大成网站www久久九九| 日韩欧美国产精品一区| 91在线精品一区二区三区| 麻豆国产精品官网| 亚洲在线中文字幕| 久久精品视频一区| 欧美一级黄色片| 色婷婷av一区二区三区之一色屋| 国内精品国产三级国产a久久| 亚洲国产精品久久艾草纯爱| 欧美激情一区二区三区蜜桃视频| 日韩欧美一二三区| 欧美色图12p| 色哟哟一区二区| 国产91综合网| 国产精品一区在线| 激情文学综合丁香| 五月综合激情婷婷六月色窝| 亚洲视频在线观看一区| 久久精品视频免费观看| 日韩免费高清av| 欧美日韩国产经典色站一区二区三区| 成人网在线免费视频| 久久99国产精品免费| 午夜精品123| 亚洲一区欧美一区| 国产精品天干天干在观线| 久久久久久久久久久久久女国产乱| 欧美日韩国产综合久久| 99re亚洲国产精品| 国产寡妇亲子伦一区二区| 天天色综合成人网| 亚洲成人av电影在线| 一个色妞综合视频在线观看| 亚洲欧美视频一区| 亚洲视频在线一区二区| 亚洲激情图片qvod| 亚洲欧洲日韩综合一区二区| 中文字幕在线不卡一区二区三区| 国产精品污网站| 国产精品护士白丝一区av| 国产精品视频一二三区| 国产精品久久久久永久免费观看 | 久久99在线观看| 精品一区二区三区香蕉蜜桃| 九色综合狠狠综合久久| 激情五月婷婷综合| 国产91色综合久久免费分享| 国产.精品.日韩.另类.中文.在线.播放| 国产精品888| 成人精品一区二区三区四区 | 五月天中文字幕一区二区| 偷拍与自拍一区| 麻豆精品蜜桃视频网站| 国产又粗又猛又爽又黄91精品| 国产老肥熟一区二区三区| 国产成人免费在线视频| 99精品久久只有精品| 欧美三级电影一区| 日韩欧美高清dvd碟片| 国产三级一区二区三区| 亚洲三级在线免费观看| 日韩影院免费视频| 国产一区不卡在线| 99在线热播精品免费| 欧美在线啊v一区| 欧美一卡二卡在线观看| 国产香蕉久久精品综合网| 1000部国产精品成人观看| 亚洲国产精品影院| 韩国v欧美v亚洲v日本v| aaa欧美大片| 欧美一级一级性生活免费录像| 2021久久国产精品不只是精品| 国产精品二三区| 午夜精品福利在线| 成人动漫中文字幕| 91精品国产色综合久久ai换脸| 久久精品水蜜桃av综合天堂| 亚洲另类在线视频| 国产一区二区三区久久久 | 成人av在线一区二区三区| 欧美日韩在线播放一区| 久久久三级国产网站| 亚洲成人第一页| 成人免费高清视频在线观看| 欧美剧情片在线观看| 中文子幕无线码一区tr| 日韩一区精品视频| 91视频一区二区三区| 日韩欧美国产电影| 亚洲一区免费观看| av福利精品导航| 久久亚洲一区二区三区四区| 亚洲国产日韩av| 成年人午夜久久久| 久久蜜桃av一区二区天堂| 亚洲在线观看免费| 成av人片一区二区| 久久久99精品久久| 久久精品国内一区二区三区| 欧美在线你懂得| 亚洲婷婷在线视频| 成人午夜激情在线| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲va欧美va天堂v国产综合| 成人av在线影院| 久久久久久久久久久久久久久99| 日韩电影免费在线看| 97se亚洲国产综合自在线不卡 | 精品一二线国产| 制服丝袜亚洲色图| 亚洲综合在线免费观看| 国产白丝精品91爽爽久久| 久久综合九色综合欧美就去吻| 午夜成人免费视频| 欧美日韩一区久久| 亚洲男人的天堂网| 91在线丨porny丨国产| 日本一区二区综合亚洲| 精品中文av资源站在线观看| 9191成人精品久久| 午夜av一区二区三区| 欧美色图在线观看| 亚洲高清在线视频| 欧美伊人久久久久久久久影院| 国产精品久久久久久久久免费樱桃 | 亚洲黄色片在线观看| 99久久99久久综合| 亚洲视频一二三区| 91麻豆产精品久久久久久| 一色桃子久久精品亚洲| 97久久精品人人做人人爽| 亚洲毛片av在线| 在线观看www91| 亚洲h精品动漫在线观看| 欧美日韩一区在线观看| 日韩av电影免费观看高清完整版在线观看 | 亚洲网友自拍偷拍| 欧美日韩精品三区| 视频一区二区欧美| 日韩欧美高清dvd碟片| 国内一区二区视频| 亚洲精品一区二区三区福利| 国产一区高清在线| 亚洲国产精品av| 91久久精品日日躁夜夜躁欧美| 亚洲精品伦理在线| 欧美日韩中文另类| 美女在线视频一区| 国产亚洲人成网站| aaa欧美色吧激情视频| 亚洲伦在线观看| 欧美四级电影在线观看| 毛片av一区二区三区| www成人在线观看| 99re成人精品视频| 日韩精品91亚洲二区在线观看| 日韩精品一区二区三区视频在线观看| 国产真实精品久久二三区| 亚洲国产精品二十页| 欧美在线免费观看视频| 久久99精品久久只有精品| 国产精品久久久久久久久免费丝袜 | 国产精品免费视频观看| 欧美丝袜丝交足nylons|