27 二叉搜索樹與雙向鏈表

#include <iostream>
#include "BinaryTree.h"

BinaryTreeNode* Convert(BinaryTreeNode* pRootOftree)
{
    BinaryTreeNode* pLastNodeOfList = NULL;
    ConvertNode(pRootOftree, &pLastNodeOfList);

    //pLastNodeOfList指向雙向鏈表的尾結(jié)點(diǎn)
    //我們需要返回頭結(jié)點(diǎn)
    BinaryTreeNode* pHeadOfList = pLastNodeOfList;
    while(pLastNodeOfList != NULL && pLastNodeOfList->m_pLeft != NULL)
        pHeadOfList = pHeadOfList->m_pLeft;

    return pHeadOfList;
}

void ConvertNode(BinaryTreeNode* pNode, BinaryTreeNode** pLastNodeOfList)
{
    if(pNode == NULL)
        return;

    BinaryTreeNode* pCurrent = pNode;

    if(pCurrent->m_pLeft != NULL)
        ConvertNode(pCurrent->m_pLeft, pLastNodeOfList);

    //注意雙向
    pCurrent->m_pLeft = pCurrent;
    if(*pLastNodeOfList != NULL)
        (*pLastNodeOfList)->m_pRight = pCurrent;

    *pLastNodeOfList = pCurrent;

    if(pCurrent->m_pRight != NULL)
        ConvertNode(pCurrent->m_pRight, pLastNodeOfList);
}

// ====================測試代碼====================
void PrintDoubleLinkedList(BinaryTreeNode* pHeadOfList)
{
    BinaryTreeNode* pNode = pHeadOfList;

    printf("The nodes from left to right are:\n");
    while(pNode != NULL)
    {
        printf("%d\t", pNode->m_nValue);

        if(pNode->m_pRight == NULL)
            break;
        pNode = pNode->m_pRight;
    }

    printf("\nThe nodes from right to left are:\n");
    while(pNode != NULL)
    {
        printf("%d\t", pNode->m_nValue);

        if(pNode->m_pLeft == NULL)
            break;
        pNode = pNode->m_pLeft;
    }

    printf("\n");
}

void DestroyList(BinaryTreeNode* pHeadOfList)
{
    BinaryTreeNode* pNode = pHeadOfList;
    while(pNode != NULL)
    {
        BinaryTreeNode* pNext = pNode->m_pRight;

        delete pNode;
        pNode = pNext;
    }
}

void Test(char* testName, BinaryTreeNode* pRootOfTree)
{
    if(testName != NULL)
        printf("===%s begins:===\n", testName);

    PrintTree(pRootOfTree);

    BinaryTreeNode* pHeadOfList = Convert(pRootOfTree);

    PrintDoubleLinkedList(pHeadOfList);
}

//            10
//         /      \
//        6        14
//       /\        /\
//      4  8     12  16
void Test1()
{
    BinaryTreeNode* pNode10 = CreateBinaryTreeNode(10);
    BinaryTreeNode* pNode6 = CreateBinaryTreeNode(6);
    BinaryTreeNode* pNode14 = CreateBinaryTreeNode(14);
    BinaryTreeNode* pNode4 = CreateBinaryTreeNode(4);
    BinaryTreeNode* pNode8 = CreateBinaryTreeNode(8);
    BinaryTreeNode* pNode12 = CreateBinaryTreeNode(12);
    BinaryTreeNode* pNode16 = CreateBinaryTreeNode(16);

    ConnectTreeNodes(pNode10, pNode6, pNode14);
    ConnectTreeNodes(pNode6, pNode4, pNode8);
    ConnectTreeNodes(pNode14, pNode12, pNode16);

    Test("Test1", pNode10);

    DestroyList(pNode4);
}

//               5
//              /
//             4
//            /
//           3
//          /
//         2
//        /
//       1
void Test2()
{
    BinaryTreeNode* pNode5 = CreateBinaryTreeNode(5);
    BinaryTreeNode* pNode4 = CreateBinaryTreeNode(4);
    BinaryTreeNode* pNode3 = CreateBinaryTreeNode(3);
    BinaryTreeNode* pNode2 = CreateBinaryTreeNode(2);
    BinaryTreeNode* pNode1 = CreateBinaryTreeNode(1);

    ConnectTreeNodes(pNode5, pNode4, NULL);
    ConnectTreeNodes(pNode4, pNode3, NULL);
    ConnectTreeNodes(pNode3, pNode2, NULL);
    ConnectTreeNodes(pNode2, pNode1, NULL);

    Test("Test2", pNode5);

    DestroyList(pNode1);
}

// 1
//  \
//   2
//    \
//     3
//      \
//       4
//        \
//         5
void Test3()
{
    BinaryTreeNode* pNode1 = CreateBinaryTreeNode(1);
    BinaryTreeNode* pNode2 = CreateBinaryTreeNode(2);
    BinaryTreeNode* pNode3 = CreateBinaryTreeNode(3);
    BinaryTreeNode* pNode4 = CreateBinaryTreeNode(4);
    BinaryTreeNode* pNode5 = CreateBinaryTreeNode(5);

    ConnectTreeNodes(pNode1, NULL, pNode2);
    ConnectTreeNodes(pNode2, NULL, pNode3);
    ConnectTreeNodes(pNode3, NULL, pNode4);
    ConnectTreeNodes(pNode4, NULL, pNode5);

    Test("Test3", pNode1);

    DestroyList(pNode1);
}

// 樹中只有1個(gè)結(jié)點(diǎn)
void Test4()
{
    BinaryTreeNode* pNode1 = CreateBinaryTreeNode(1);
    Test("Test4", pNode1);

    DestroyList(pNode1);
}

// 樹中沒有結(jié)點(diǎn)
void Test5()
{
    Test("Test5", NULL);
}

int main(void)
{
    Test1();
    Test2();
    Test3();
    Test4();
    Test5();

    return 0;
}

結(jié)果

未命名_meitu_0.jpg
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市瘾腰,隨后出現(xiàn)的幾起案子肴甸,更是在濱河造成了極大的恐慌,老刑警劉巖腿时,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異饭宾,居然都是意外死亡批糟,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門看铆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來徽鼎,“玉大人,你說我怎么就攤上這事弹惦》裼伲” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵棠隐,是天一觀的道長石抡。 經(jīng)常有香客問我,道長宵荒,這世上最難降的妖魔是什么汁雷? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任净嘀,我火速辦了婚禮,結(jié)果婚禮上侠讯,老公的妹妹穿的比我還像新娘挖藏。我一直安慰自己,他們只是感情好厢漩,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布膜眠。 她就那樣靜靜地躺著,像睡著了一般溜嗜。 火紅的嫁衣襯著肌膚如雪宵膨。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天炸宵,我揣著相機(jī)與錄音辟躏,去河邊找鬼。 笑死土全,一個(gè)胖子當(dāng)著我的面吹牛捎琐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播裹匙,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼瑞凑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了概页?” 一聲冷哼從身側(cè)響起籽御,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎惰匙,沒想到半個(gè)月后技掏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡徽曲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年零截,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了麸塞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秃臣。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖哪工,靈堂內(nèi)的尸體忽然破棺而出奥此,到底是詐尸還是另有隱情,我是刑警寧澤雁比,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布稚虎,位于F島的核電站,受9級(jí)特大地震影響偎捎,放射性物質(zhì)發(fā)生泄漏蠢终。R本人自食惡果不足惜序攘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望寻拂。 院中可真熱鬧程奠,春花似錦、人聲如沸祭钉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽慌核。三九已至距境,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間垮卓,已是汗流浹背垫桂。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留粟按,地道東北人伪货。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像钾怔,于是被迫代替她去往敵國和親碱呼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 題目:輸入一棵二叉搜索樹宗侦,將該二叉搜索樹轉(zhuǎn)換成一個(gè)排序的雙向鏈表愚臀。要求不能創(chuàng)建任何新的結(jié)點(diǎn),只能調(diào)整樹中結(jié)點(diǎn)指針的...
    3e1094b2ef7b閱讀 188評(píng)論 0 0
  • 題目輸入一棵二叉搜索樹矾利,將該二叉搜索樹轉(zhuǎn)換成一個(gè)排序的雙向鏈表姑裂。要求不能創(chuàng)建任何新的結(jié)點(diǎn),只能調(diào)整樹中結(jié)點(diǎn)指針的指...
    no_one11閱讀 285評(píng)論 0 0
  • 本系列導(dǎo)航:劍指offer(第二版)java實(shí)現(xiàn)導(dǎo)航帖 面試題36:二叉搜索樹與雙向鏈表 題目要求:輸入一顆二叉搜...
    ryderchan閱讀 1,262評(píng)論 2 0
  • 題目描述輸入一棵二叉搜索樹男旗,將該二叉搜索樹轉(zhuǎn)換成一個(gè)排序的雙向鏈表舶斧。要求不能創(chuàng)建任何新的結(jié)點(diǎn),只能調(diào)整樹中結(jié)點(diǎn)指針...
    哦漏昵稱已被占用閱讀 218評(píng)論 0 0
  • 2008年的5月12日矾缓,沒覺得特別。 第二天公司開始做賑災(zāi)活動(dòng)稻爬,我全程負(fù)責(zé)嗜闻,也沒覺得特別。畢竟桅锄,四川距離浙江琉雳,相距...
    暴拿鐵閱讀 320評(píng)論 0 2