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

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

?? treeinfo.cpp

?? Resource editor base speadrum Chinese mobile
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// FileName: TreeInfo.cpp
// Author:   Anli.wei
// Date:     2005-2-22
// Comment:  定義樹的屬性結構,并實現屬性結構操作的封裝,使用時:
//           1. 應派生CTreeNode類,添加自己需要的屬性。
//           2. 派生CTreeInfo類,重新實現MallocNode和ZeroNode兩個函數
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "TreeInfo.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CTreeInfo::CTreeInfo()
{
    m_pRoot = NULL;
}

CTreeInfo::~CTreeInfo()
{
    if(m_pRoot != NULL)
    {
        RemoveAll();
    }
}

// 在進行操作前,必須首先調用此函數(形成虛擬的根節點),否則其余的操作不會有效。
// 成功,返回TRUE;失敗,返回FALSE。
BOOL CTreeInfo::InitRoot()  
{
    if(m_pRoot == NULL)
    {
        m_pRoot = MallocNode();
        if(m_pRoot == NULL)
        {
            return FALSE;
        }
        ZeroNode(m_pRoot);
    }
   
    return TRUE;
}

// 獲取當前節點的父節點
// pcNode, 當前節點
// 成功 非NULL, 失敗或沒有 NULL
PTREENODE CTreeInfo::GetParent( PCTREENODE pcNode )const
{
    if( pcNode != NULL )
    {
        return pcNode->pParent;
    }
    else
    {
        return NULL;
    }
}

void CTreeInfo::SetParent( PTREENODE pCur, PCTREENODE pParent) const
{
    _ASSERTE( pCur != NULL);
    
    pCur->pParent = (PTREENODE)pParent;
}

// 獲取當前節點的子節點
// pcNode, 給定的節點; nIndex, 給定的節點的第幾個子節點,缺省為第一個(從0計起)
// 成功 非NULL; 失敗 NULL
PTREENODE CTreeInfo::GetChild( PCTREENODE pcNode, int nIdx /* = 0 */ ) const
{
    _ASSERTE( pcNode != NULL );
	_ASSERTE( nIdx >= 0 );

    if( nIdx >= GetChildCount(pcNode) )
    {
        // 子節點為空的情況已經考慮到,以下處理時不必再考慮
        return NULL;
    }

	PTREENODE pCur = pcNode->pChild;
    // 此時pCur肯定不為NULL,所以不必再次判斷
    for( int i = 0; i < nIdx; ++i )
    {
        pCur = pCur->pNext;
    }

    return pCur;
}

// 置當前節點的子節點
void CTreeInfo::SetChild( PTREENODE pCur, PCTREENODE pChild ) const
{
    _ASSERTE( pCur != NULL);

    pCur->pChild = (PTREENODE)pChild;
}

// 獲取當前節點子節點的數量(不包含孫子節點)
// pcNode, 給定節點
// 返回給定節點的子節點個數 >= 0
int CTreeInfo::GetChildCount( PCTREENODE pcNode ) const
{
    _ASSERTE(pcNode != NULL);

    int nCount = 0;
    for(pcNode = pcNode->pChild; pcNode != NULL; pcNode = pcNode->pNext)
    {
        nCount++;
    }  

    return nCount;
}

// 獲取當前節點的上一個兄弟節點
// 成功 非NULL; 失敗或無 NULL
PTREENODE CTreeInfo::GetPrev( PCTREENODE pcNode )const 
{
    if(pcNode != NULL)
    {
        return pcNode->pPrev;
    }
    else
    {
        return NULL;
    }
}

// 置當前節點的上一個兄弟節點
void CTreeInfo::SetPrev( PTREENODE pCur, PCTREENODE pcPrev ) const
{
    _ASSERTE( pCur != NULL);

    pCur->pPrev = (PTREENODE)pcPrev;
}

// 獲取當前節點的下一個兄弟節點
// 成功 非NULL; 失敗或無 NULL
PTREENODE CTreeInfo::GetNext( PCTREENODE pcNode ) const
{
    if(pcNode != NULL)
    {
        return pcNode->pNext;
    }
    else
    {
        return NULL;
    }
}

// 置當前節點的下一個兄弟節點
void CTreeInfo::SetNext( PTREENODE pCur, PCTREENODE pcNext) const
{
    _ASSERTE( pCur != NULL);

    pCur->pNext = (PTREENODE)pcNext;
}

// 為當前節點添加子節點   
// bLast 如果父節點已經有子節點,用此來表示該子節點是作為父節點的最后一個
// 子節點(TRUE),還是作為第一個子節點(FALSE),缺省為TRUE。 
// 成功  TRUE; 失敗 FALSE
BOOL CTreeInfo::AddChild(PTREENODE pParent, PTREENODE pChild, BOOL bLast /* = TRUE */) const
{
    _ASSERTE(pParent != NULL);
    _ASSERTE(pChild != NULL);
    
    // 將子節點的連接節點初始化
    pChild->pParent = pParent;
        
    // 當前節點(pParent)還沒有子節點,此時為它添加第一個子節點
    if(pParent->pChild == NULL)
    {
        pParent->pChild = pChild;
      
        return TRUE;
    }

    // 當前節點(pParent)已經有子節點,此時以標志bLast來判斷是將子節點
    // (pChild)作為pParent的最后一個子節點,還是第一個子節點.
    if(bLast)
    {
        PTREENODE pLast = pParent->pChild;
        while( pLast->pNext != NULL )
		{
			pLast = pLast->pNext;
		}

		pLast->pNext    = pChild;
        pChild->pPrev   = pLast;
    }
    else
    {
        PTREENODE pFirst = pParent->pChild;
        pParent->pChild  = pChild;
        pChild->pNext    = pFirst;
    }

    return TRUE;
}

// 以當前選中節點為基準插入兄弟節點
// pBase:基準節點(在菜單中已經存在的);pBrother:被插入的節點;
// bBefore:被插入的節點的位置(基準節點的前面:TRUE或后面:FALSE)
// 返回:成功 TRUE;失敗 FALSE
BOOL CTreeInfo::InsertInBrothers(PTREENODE pBase, PTREENODE pBrother, BOOL bBefore /* = TRUE */)
{
    _ASSERTE(pBase != NULL);
    _ASSERTE(pBrother != NULL);
    
    // 將子節點的連接節點初始化
    pBrother->pParent = pBase->pParent;
    pBrother->pNext   = NULL;
    pBrother->pPrev   = NULL;

    if(bBefore)
    {
        PTREENODE pOldBefore = pBase->pPrev;
        if(pOldBefore != NULL)
        {
            pOldBefore->pNext = pBrother;
        }
        else
        {
            pBase->pParent->pChild = pBrother;
        }
        pBrother->pPrev = pOldBefore;
        pBrother->pNext = pBase;
        pBase->pPrev    = pBrother;
    }
    else
    {
        PTREENODE pOldAfter = pBase->pNext;
        pBase->pNext        = pBrother;
        pBrother->pPrev     = pBase;
        pBrother->pNext     = pOldAfter;

        if(pOldAfter != NULL)
        {
            pOldAfter->pPrev = pBrother;
        }
    }

    return TRUE;
}

// 在兄弟節點中移動當前節點(改變當前節點在兄弟節點中的順序)
// 當前選中節點,// 移動方向  TRUE 向下;FALSE 向上
// TRUE 成功;FALSE 失敗
BOOL CTreeInfo::MoveInBrothers(PTREENODE pNode, BOOL bDown /* = TRUE */)
{
    _ASSERTE(pNode != NULL);

    PTREENODE pPrev = NULL;
    PTREENODE pNext = NULL;
    if(bDown)
    {
        if(pNode->pNext == NULL)
        {
            // 當前節點無下一個兄弟節點
            return FALSE;
        }

        // 當前節點的上一個兄弟節點(可能為NULL)
        pPrev = pNode->pPrev;
        // 當前節點的下一個兄弟節點(可能為NULL)
        pNext = pNode->pNext;

        pNode->pPrev = pNext;
        pNode->pNext = pNext->pNext;

        if(pNext->pNext != NULL)
        {
            pNext->pNext->pPrev = pNode;
        }

        pNext->pNext  = pNode;
        pNext->pPrev  = pPrev;

        if(pPrev == NULL)
        {
            pNode->pParent->pChild = pNext;      
        }
        else
        {
            pPrev->pNext = pNext;
        }
    }
    else
    {
        if(pNode->pPrev == NULL)
        {
            // 當前節點無上一個兄弟節點
            return FALSE;
        }

        pPrev = pNode->pPrev;
        pNext = pNode->pNext;

        // 當前節點的上一個兄弟節點(可能為NULL)
        pNode->pPrev = pPrev->pPrev;
        // 當前節點的下一個兄弟節點(可能為NULL)
        pNode->pNext = pPrev;
                
        if(pNext != NULL)
        {
            pNext->pPrev = pPrev;
        }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧洲精品天堂一级| 成人激情校园春色| av成人动漫在线观看| 日韩女优视频免费观看| 一区二区三区在线影院| 国产高清精品网站| 日韩一级大片在线观看| 五月天激情综合网| 欧美日韩免费在线视频| 亚洲最大的成人av| 色94色欧美sute亚洲线路一久| 国产午夜亚洲精品午夜鲁丝片 | 青草av.久久免费一区| 3d动漫精品啪啪1区2区免费| 亚洲国产一二三| 欧美日韩国产高清一区二区三区 | 欧美日韩国产系列| 亚洲午夜精品17c| 欧美成人精精品一区二区频| 婷婷一区二区三区| 欧美一区二区三区成人| 极品少妇xxxx精品少妇| 亚洲国产高清aⅴ视频| 99这里只有久久精品视频| 亚洲视频一二区| 欧美片在线播放| 国产精品一区在线| 亚洲欧美日韩成人高清在线一区| 一本一道波多野结衣一区二区| 亚洲一区电影777| 欧美电视剧免费观看| 99精品国产视频| 三级久久三级久久| 国产精品久久久久aaaa| 欧美日韩不卡一区| 成人免费视频免费观看| 亚洲高清免费观看高清完整版在线观看| 欧美日韩午夜影院| 国产91精品露脸国语对白| 亚洲成人福利片| 中文字幕的久久| 日韩网站在线看片你懂的| 91免费看视频| 国产91在线观看丝袜| 午夜一区二区三区在线观看| 26uuu国产日韩综合| 欧美日韩激情一区| 在线中文字幕一区| 岛国一区二区在线观看| 久久99精品国产91久久来源| 五月婷婷激情综合网| 亚洲另类一区二区| 中文字幕在线视频一区| 欧美激情一区三区| 国产精品免费人成网站| 精品国免费一区二区三区| 欧美一卡二卡三卡四卡| 欧美一级黄色录像| 91精品欧美一区二区三区综合在| 欧美三级电影网| 欧美年轻男男videosbes| 欧美日韩三级一区二区| 91精品视频网| 精品国产123| 久久精品亚洲国产奇米99| 国产亚洲精品中文字幕| 国产日韩视频一区二区三区| 亚洲国产精品精华液ab| 一区二区中文视频| 婷婷久久综合九色综合绿巨人| 日韩高清电影一区| 国产成人啪免费观看软件 | 老鸭窝一区二区久久精品| 亚洲成av人片一区二区| 美女免费视频一区二区| 成人精品一区二区三区四区 | 精品免费99久久| 国产精品视频看| 亚洲精品国产a| 九九精品视频在线看| jvid福利写真一区二区三区| 欧美伊人久久大香线蕉综合69 | 国产日韩欧美精品电影三级在线 | 日韩午夜电影av| 国产精品久久精品日日| 日本一区中文字幕 | 天天综合天天做天天综合| 国产不卡视频一区二区三区| 欧美亚日韩国产aⅴ精品中极品| 久久婷婷国产综合国色天香| 亚洲视频中文字幕| 91福利在线观看| www成人在线观看| 日韩电影在线一区二区| 91黄色小视频| 中文字幕的久久| 床上的激情91.| 国产亚洲一区二区在线观看| 麻豆精品视频在线观看视频| 色婷婷香蕉在线一区二区| 国产精品青草久久| 韩国成人在线视频| 欧美成人精品高清在线播放| 亚洲韩国一区二区三区| 91九色02白丝porn| 亚洲一区视频在线观看视频| 欧美在线免费视屏| 亚洲精品久久久蜜桃| 色94色欧美sute亚洲13| 亚洲精品日产精品乱码不卡| 日本韩国欧美三级| 亚洲午夜在线电影| 日韩午夜电影av| 国产美女主播视频一区| 国产精品夫妻自拍| 日本韩国欧美一区二区三区| 亚洲bdsm女犯bdsm网站| 欧美日本一道本在线视频| 狂野欧美性猛交blacked| 久久精品夜色噜噜亚洲aⅴ| 成人高清视频在线| 亚洲免费观看高清完整版在线观看熊 | 精品国产三级电影在线观看| 国产v综合v亚洲欧| 亚洲午夜电影在线| 欧美va天堂va视频va在线| www.亚洲精品| 奇米777欧美一区二区| 国产精品人妖ts系列视频| 欧美性大战久久久久久久| 国产福利91精品一区| 五月婷婷激情综合网| 国产精品久久综合| 日韩视频在线一区二区| zzijzzij亚洲日本少妇熟睡| 亚洲国产精品麻豆| 日韩午夜激情av| 欧美日韩国产综合视频在线观看| 国产在线麻豆精品观看| 亚洲国产精品精华液网站| 国产欧美日韩麻豆91| 日韩欧美一区在线观看| 色噜噜狠狠成人中文综合| 国产美女一区二区三区| 热久久免费视频| 亚洲成a人在线观看| 亚洲欧洲中文日韩久久av乱码| 久久亚洲免费视频| 欧美成va人片在线观看| 日韩一区二区三区电影| 欧美精品久久久久久久久老牛影院| 成人高清视频在线观看| 丰满少妇在线播放bd日韩电影| 秋霞午夜av一区二区三区| 图片区日韩欧美亚洲| 亚洲风情在线资源站| 亚洲成人av福利| 视频一区二区中文字幕| 日韩黄色免费电影| 久久激情五月激情| 国产美女视频一区| 成人性生交大片免费 | 天堂av在线一区| 奇米888四色在线精品| 国产精品18久久久| 成人成人成人在线视频| 色综合久久久久网| 91精品国产综合久久久蜜臀图片| 欧美日韩国产综合一区二区 | 欧洲色大大久久| 欧美一区二区精品| 国产精品美女久久久久久久| 国产精品久久久久影院老司| 一区二区国产盗摄色噜噜| 男女男精品视频| 成人伦理片在线| 日韩三级在线免费观看| 国产欧美精品国产国产专区| 欧美国产综合色视频| 亚洲四区在线观看| 国产曰批免费观看久久久| 91视频www| 久久―日本道色综合久久| 亚洲影视在线观看| 国产超碰在线一区| 日韩写真欧美这视频| 亚洲狼人国产精品| 国产精品18久久久久久久网站| 91极品美女在线| 国产精品午夜春色av| 国产在线视频一区二区| 91精品国产综合久久香蕉的特点 | 制服丝袜亚洲播放| 亚洲免费色视频| www.爱久久.com| 欧美激情在线看| 国产成a人亚洲精品| 国产人成亚洲第一网站在线播放| 日韩不卡手机在线v区| 在线播放一区二区三区|