青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Where there is a dream ,there is hope

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  64 Posts :: 0 Stories :: 8 Comments :: 0 Trackbacks

常用鏈接

留言簿(1)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

原文地址:http://zhedahht.blog.163.com/blog/static/254111742007127104759245/
題目:輸入一棵二元查找樹,將該二元查找樹轉換成一個排序的雙向鏈表。要求不能創建任何新的結點,只調整指針的指向。

  比如將二元查找樹
    
                                        10
                                          /    \
                                        6       14
                                      /  \     /  \
                                    4     8  12    16
轉換成雙向鏈表

4=6=8=10=12=14=16。

  分析:本題是微軟的面試題。很多與樹相關的題目都是用遞歸的思路來解決,本題也不例外。下面我們用兩種不同的遞歸思路來分析。

  思路一:當我們到達某一結點準備調整以該結點為根結點的子樹時,先調整其左子樹將左子樹轉換成一個排好序的左子鏈表,再調整其右子樹轉換右子鏈表。最近鏈接左子鏈表的最右結點(左子樹的最大結點)、當前結點和右子鏈表的最左結點(右子樹的最小結點)。從樹的根結點開始遞歸調整所有結點。

  思路二:我們可以中序遍歷整棵樹。按照這個方式遍歷樹,比較小的結點先訪問。如果我們每訪問一個結點,假設之前訪問過的結點已經調整成一個排序雙向鏈表,我們再把調整當前結點的指針將其鏈接到鏈表的末尾。當所有結點都訪問過之后,整棵樹也就轉換成一個排序雙向鏈表了。

參考代碼:

首先我們定義二元查找樹結點的數據結構如下:
    struct BSTreeNode // a node in the binary search tree
    {
        int          m_nValue; // value of node
        BSTreeNode  *m_pLeft;  // left child of node
        BSTreeNode  *m_pRight; // right child of node
    };

思路一對應的代碼:
///////////////////////////////////////////////////////////////////////
// Covert a sub binary-search-tree into a sorted double-linked list
// Input: pNode - the head of the sub tree
//        asRight - whether pNode is the right child of its parent
// Output: if asRight is true, return the least node in the sub-tree
//         else return the greatest node in the sub-tree
///////////////////////////////////////////////////////////////////////
BSTreeNode* ConvertNode(BSTreeNode* pNode, bool asRight)
{
      if(!pNode)
            return NULL;

      BSTreeNode *pLeft = NULL;
      BSTreeNode *pRight = NULL;

      // Convert the left sub-tree
      if(pNode->m_pLeft)
            pLeft = ConvertNode(pNode->m_pLeft, false);

      // Connect the greatest node in the left sub-tree to the current node
      if(pLeft)
      {
            pLeft->m_pRight = pNode;
            pNode->m_pLeft = pLeft;
      }

      // Convert the right sub-tree
      if(pNode->m_pRight)
            pRight = ConvertNode(pNode->m_pRight, true);

      // Connect the least node in the right sub-tree to the current node
      if(pRight)
      {
            pNode->m_pRight = pRight;
            pRight->m_pLeft = pNode;
      }

      BSTreeNode *pTemp = pNode;

      // If the current node is the right child of its parent, 
      // return the least node in the tree whose root is the current node
      if(asRight)
      {
            while(pTemp->m_pLeft)
                  pTemp = pTemp->m_pLeft;
      }
      // If the current node is the left child of its parent, 
      // return the greatest node in the tree whose root is the current node
      else
      {
            while(pTemp->m_pRight)
                  pTemp = pTemp->m_pRight;
      }
 
      return pTemp;
}

///////////////////////////////////////////////////////////////////////
// Covert a binary search tree into a sorted double-linked list
// Input: the head of tree
// Output: the head of sorted double-linked list
///////////////////////////////////////////////////////////////////////
BSTreeNode* Convert(BSTreeNode* pHeadOfTree)
{
      // As we want to return the head of the sorted double-linked list,
      // we set the second parameter to be true
      return ConvertNode(pHeadOfTree, true);
}

思路二對應的代碼:
///////////////////////////////////////////////////////////////////////
// Covert a sub binary-search-tree into a sorted double-linked list
// Input: pNode -           the head of the sub tree
//        pLastNodeInList - the tail of the double-linked list
///////////////////////////////////////////////////////////////////////
void ConvertNode(BSTreeNode* pNode, BSTreeNode*& pLastNodeInList)
{
      if(pNode == NULL)
            return;

      BSTreeNode *pCurrent = pNode;

      // Convert the left sub-tree
      if (pCurrent->m_pLeft != NULL)
            ConvertNode(pCurrent->m_pLeft, pLastNodeInList);

      // Put the current node into the double-linked list
      pCurrent->m_pLeft = pLastNodeInList; 
      if(pLastNodeInList != NULL)
            pLastNodeInList->m_pRight = pCurrent;

      pLastNodeInList = pCurrent;

      // Convert the right sub-tree
      if (pCurrent->m_pRight != NULL)
            ConvertNode(pCurrent->m_pRight, pLastNodeInList);
}

///////////////////////////////////////////////////////////////////////
// Covert a binary search tree into a sorted double-linked list
// Input: pHeadOfTree - the head of tree
// Output: the head of sorted double-linked list
///////////////////////////////////////////////////////////////////////
BSTreeNode* Convert_Solution1(BSTreeNode* pHeadOfTree)
{
      BSTreeNode *pLastNodeInList = NULL;
      ConvertNode(pHeadOfTree, pLastNodeInList);

      // Get the head of the double-linked list
      BSTreeNode *pHeadOfList = pLastNodeInList;
      while(pHeadOfList && pHeadOfList->m_pLeft)
            pHeadOfList = pHeadOfList->m_pLeft;

      return pHeadOfList;
}

posted on 2010-12-17 08:58 IT菜鳥 閱讀(343) 評論(0)  編輯 收藏 引用 所屬分類: 算法/數據結構
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲高清av在线| 欧美人牲a欧美精品| 永久久久久久| 国产亚洲一区二区三区在线观看| 国产精品老牛| 国产伦精品一区二区三区免费迷| 国产精品一区在线观看你懂的| 国产精品成人av性教育| 国产精品久久久久久模特| 国产毛片一区二区| 伊人久久大香线蕉综合热线 | 在线欧美一区| 亚洲精品中文字幕在线观看| 正在播放亚洲| 欧美伊人影院| 亚洲二区在线观看| 中文亚洲字幕| 久久精品亚洲一区二区| 欧美r片在线| 国产精品theporn88| 狠狠色噜噜狠狠色综合久| 亚洲欧洲一区二区三区久久| 亚洲一区日本| 欧美高清在线一区| 一区二区三区不卡视频在线观看| 欧美一区二区| 欧美日韩国产黄| 国产人久久人人人人爽| 亚洲欧洲综合另类| 欧美在线一级va免费观看| 欧美激情综合色| 西瓜成人精品人成网站| 欧美精品激情在线| 精品动漫一区二区| 亚洲男同1069视频| 亚洲国产天堂久久综合网| 亚洲免费网址| 欧美性片在线观看| 最新日韩在线视频| 巨胸喷奶水www久久久免费动漫| 亚洲乱码国产乱码精品精98午夜| 久久大香伊蕉在人线观看热2| 欧美日韩中文字幕精品| 亚洲精品1区| 久久久久久一区二区三区| 99国产精品自拍| 欧美成人一品| 国产综合色产在线精品| 午夜一区在线| 99精品视频免费观看| 欧美成人自拍| 亚洲日本无吗高清不卡| 久久综合给合久久狠狠狠97色69| 在线视频欧美日韩| 欧美精品在线免费观看| 久久国产福利国产秒拍| 久久亚洲欧美| 激情亚洲网站| 久久久久欧美精品| 欧美一级黄色网| 国产精品亚洲综合色区韩国| 亚洲综合视频1区| 一区二区精品在线| 国产精品s色| 亚洲自拍偷拍网址| 亚洲综合第一页| 国产精品亚洲综合久久| 午夜精品久久久久久久蜜桃app| 在线一区二区日韩| 国产精品视频xxx| 欧美在线一区二区| 久久成人18免费网站| 很黄很黄激情成人| 欧美国产第一页| 欧美成人一区二区| 亚洲特级毛片| 亚洲一二三区精品| 国产欧美一区二区三区另类精品 | 国产精品久久久久9999高清| 99pao成人国产永久免费视频| 亚洲精品一区在线观看| 国产精品日韩| 久久人人爽爽爽人久久久| 久久久国产精品一区二区中文 | 欧美日韩午夜视频在线观看| 在线一区观看| 午夜精品视频在线| 亚洲激情亚洲| 99精品国产99久久久久久福利| 国产精品色婷婷| 欧美成人精品激情在线观看| 欧美激情精品久久久久久大尺度 | 亚洲电影下载| 亚洲人www| 国产一区二区三区不卡在线观看 | 亚洲国产视频直播| 亚洲美女在线视频| 国产日韩一区二区三区在线| 欧美福利精品| 国产精品久线观看视频| 欧美va亚洲va国产综合| 欧美日韩免费观看一区=区三区| 亚洲欧美日韩一区二区三区在线观看 | 亚洲欧美一区二区三区在线| 久久精品女人| 亚洲一区二区不卡免费| 欧美黄色片免费观看| 亚洲在线观看免费| 91久久久亚洲精品| 午夜精品久久久久久99热软件| 亚洲风情亚aⅴ在线发布| 亚洲乱码精品一二三四区日韩在线 | 在线国产亚洲欧美| 亚洲一区二区三区四区视频 | 久久国产精品色婷婷| 欧美二区在线| 美女精品在线| 国产精品日韩在线| 亚洲精品1区| 国产一区二区三区成人欧美日韩在线观看 | 麻豆成人在线播放| 欧美中文在线免费| 欧美激情视频在线播放| 久久久无码精品亚洲日韩按摩| 欧美日韩成人免费| 欧美国产丝袜视频| 在线观看91精品国产麻豆| 午夜激情亚洲| 久久9热精品视频| 欧美性久久久| 日韩午夜三级在线| 亚洲精品四区| 欧美激情 亚洲a∨综合| 欧美电影在线观看| 激情综合亚洲| 久久久久久综合网天天| 久久久夜夜夜| 国产一区二区三区久久精品| 亚洲综合大片69999| 午夜日本精品| 国产婷婷色一区二区三区在线 | 欧美 日韩 国产一区二区在线视频| 国产精品三级久久久久久电影| 日韩小视频在线观看专区| 99这里只有精品| 欧美日韩国产综合网| 亚洲国产日韩欧美综合久久| 亚洲高清网站| 牛夜精品久久久久久久99黑人 | 国产精品国产亚洲精品看不卡15| 亚洲区一区二| 亚洲性夜色噜噜噜7777| 欧美日韩一区二区三区在线看| 999亚洲国产精| 午夜影院日韩| 国内视频精品| 亚洲一二三区精品| 欧美亚洲专区| 亚洲精品免费在线| 欧美精品免费在线| 一区二区三区四区在线| 亚洲永久免费av| 国产欧美va欧美va香蕉在| 久久国产精品久久久久久电车| 久久综合精品国产一区二区三区| 在线欧美视频| 欧美午夜精品久久久久免费视| 亚洲综合国产| 欧美bbbxxxxx| 亚洲午夜高清视频| 国产视频亚洲| 欧美二区视频| 亚洲欧美日韩国产一区二区三区| 蜜月aⅴ免费一区二区三区| 亚洲精品在线二区| 国产女主播一区| 欧美成人免费全部观看天天性色| 一二三区精品| 美女视频一区免费观看| 亚洲视频欧洲视频| 亚洲国产va精品久久久不卡综合| 欧美日韩免费观看一区=区三区 | 亚洲欧美中文另类| 欧美激情第三页| 西西裸体人体做爰大胆久久久| 91久久精品一区| 国产精品一区二区视频| 欧美.www| 欧美在线资源| 亚洲一区欧美| 亚洲成人直播| 久久久久网址| 香蕉成人伊视频在线观看| 亚洲精品乱码| 伊人久久噜噜噜躁狠狠躁| 国产精品久久久久婷婷| 欧美日韩一区二区国产| 久久蜜桃精品| 欧美一区二区私人影院日本| 一区二区日韩伦理片|