日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

一文搞定面试中的二叉树问题

發(fā)布時(shí)間:2023/12/13 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 一文搞定面试中的二叉树问题 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一文搞定面試中的二叉樹(shù)問(wèn)題

版權(quán)所有,轉(zhuǎn)載請(qǐng)注明出處,謝謝!
http://blog.csdn.net/walkinginthewind/article/details/7518888

樹(shù)是一種比較重要的數(shù)據(jù)結(jié)構(gòu),尤其是二叉樹(shù)。二叉樹(shù)是一種特殊的樹(shù),在二叉樹(shù)中每個(gè)節(jié)點(diǎn)最多有兩個(gè)子節(jié)點(diǎn),一般稱(chēng)為左子節(jié)點(diǎn)和右子節(jié)點(diǎn)(或左孩子和右孩子),并且二叉樹(shù)的子樹(shù)有左右之分,其次序不能任意顛倒。二叉樹(shù)是遞歸定義的,因此,與二叉樹(shù)有關(guān)的題目基本都可以用遞歸思想解決,當(dāng)然有些題目非遞歸解法也應(yīng)該掌握,如非遞歸遍歷節(jié)點(diǎn)等等。本文努力對(duì)二叉樹(shù)相關(guān)題目做一個(gè)較全的整理總結(jié),希望對(duì)找工作的同學(xué)有所幫助。

二叉樹(shù)節(jié)點(diǎn)定義如下:
struct BinaryTreeNode
{
? ? int m_nValue;
? ? BinaryTreeNode* m_pLeft;
? ? BinaryTreeNode* m_pRight;
};

相關(guān)鏈接:
輕松搞定面試中的鏈表題目

題目列表:

1. 求二叉樹(shù)中的節(jié)點(diǎn)個(gè)數(shù)
2. 求二叉樹(shù)的深度
3. 前序遍歷,中序遍歷,后序遍歷
4.分層遍歷二叉樹(shù)(按層次從上往下,從左往右)
5. 將二叉查找樹(shù)變?yōu)橛行虻碾p向鏈表
6. 求二叉樹(shù)第K層的節(jié)點(diǎn)個(gè)數(shù)
7. 求二叉樹(shù)中葉子節(jié)點(diǎn)的個(gè)數(shù)
8. 判斷兩棵二叉樹(shù)是否結(jié)構(gòu)相同
9. 判斷二叉樹(shù)是不是平衡二叉樹(shù)
10. 求二叉樹(shù)的鏡像
11. 求二叉樹(shù)中兩個(gè)節(jié)點(diǎn)的最低公共祖先節(jié)點(diǎn)
12. 求二叉樹(shù)中節(jié)點(diǎn)的最大距離
13. 由前序遍歷序列和中序遍歷序列重建二叉樹(shù)
14.判斷二叉樹(shù)是不是完全二叉樹(shù)

詳細(xì)解答

1. 求二叉樹(shù)中的節(jié)點(diǎn)個(gè)數(shù)
遞歸解法:
(1)如果二叉樹(shù)為空,節(jié)點(diǎn)個(gè)數(shù)為0
(2)如果二叉樹(shù)不為空,二叉樹(shù)節(jié)點(diǎn)個(gè)數(shù) = 左子樹(shù)節(jié)點(diǎn)個(gè)數(shù) + 右子樹(shù)節(jié)點(diǎn)個(gè)數(shù) + 1
參考代碼如下:

[cpp]?view plaincopy
  • int?GetNodeNum(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)?//?遞歸出口??
  • ????????return?0;??
  • ????return?GetNodeNum(pRoot->m_pLeft)?+?GetNodeNum(pRoot->m_pRight)?+?1;??
  • }??
  • 2. 求二叉樹(shù)的深度
    遞歸解法:
    (1)如果二叉樹(shù)為空,二叉樹(shù)的深度為0
    (2)如果二叉樹(shù)不為空,二叉樹(shù)的深度 = max(左子樹(shù)深度, 右子樹(shù)深度) + 1
    參考代碼如下:
    [cpp]?view plaincopy
  • int?GetDepth(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)?//?遞歸出口??
  • ????????return?0;??
  • ????int?depthLeft?=?GetDepth(pRoot->m_pLeft);??
  • ????int?depthRight?=?GetDepth(pRoot->m_pRight);??
  • ????return?depthLeft?>?depthRight???(depthLeft?+?1)?:?(depthRight?+?1);???
  • }??
  • 3. 前序遍歷,中序遍歷,后序遍歷
    前序遍歷遞歸解法:
    (1)如果二叉樹(shù)為空,空操作
    (2)如果二叉樹(shù)不為空,訪問(wèn)根節(jié)點(diǎn),前序遍歷左子樹(shù),前序遍歷右子樹(shù)
    參考代碼如下:
    [cpp]?view plaincopy
  • void?PreOrderTraverse(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)??
  • ????????return;??
  • ????Visit(pRoot);?//?訪問(wèn)根節(jié)點(diǎn)??
  • ????PreOrderTraverse(pRoot->m_pLeft);?//?前序遍歷左子樹(shù)??
  • ????PreOrderTraverse(pRoot->m_pRight);?//?前序遍歷右子樹(shù)??
  • }??
  • 中序遍歷遞歸解法
    (1)如果二叉樹(shù)為空,空操作。
    (2)如果二叉樹(shù)不為空,中序遍歷左子樹(shù),訪問(wèn)根節(jié)點(diǎn),中序遍歷右子樹(shù)
    參考代碼如下:
    [cpp]?view plaincopy
  • void?InOrderTraverse(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)??
  • ????????return;??
  • ????InOrderTraverse(pRoot->m_pLeft);?//?中序遍歷左子樹(shù)??
  • ????Visit(pRoot);?//?訪問(wèn)根節(jié)點(diǎn)??
  • ????InOrderTraverse(pRoot->m_pRight);?//?中序遍歷右子樹(shù)??
  • }??
  • 后序遍歷遞歸解法
    (1)如果二叉樹(shù)為空,空操作
    (2)如果二叉樹(shù)不為空,后序遍歷左子樹(shù),后序遍歷右子樹(shù),訪問(wèn)根節(jié)點(diǎn)
    參考代碼如下:
    [cpp]?view plaincopy
  • void?PostOrderTraverse(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)??
  • ????????return;??
  • ????PostOrderTraverse(pRoot->m_pLeft);?//?后序遍歷左子樹(shù)??
  • ????PostOrderTraverse(pRoot->m_pRight);?//?后序遍歷右子樹(shù)??
  • ????Visit(pRoot);?//?訪問(wèn)根節(jié)點(diǎn)??
  • }??
  • 4.分層遍歷二叉樹(shù)(按層次從上往下,從左往右)

    相當(dāng)于廣度優(yōu)先搜索,使用隊(duì)列實(shí)現(xiàn)。隊(duì)列初始化,將根節(jié)點(diǎn)壓入隊(duì)列。當(dāng)隊(duì)列不為空,進(jìn)行如下操作:彈出一個(gè)節(jié)點(diǎn),訪問(wèn),若左子節(jié)點(diǎn)或右子節(jié)點(diǎn)不為空,將其壓入隊(duì)列。

    [cpp]?view plaincopy
  • void?LevelTraverse(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)??
  • ????????return;??
  • ????queue<BinaryTreeNode?*>?q;??
  • ????q.push(pRoot);//添加元素到隊(duì)列尾部 ?
  • ????while(!q.empty())??
  • ????{??
  • ????????BinaryTreeNode?*?pNode?=?q.front();//指向隊(duì)列的首部 ?
  • ????????q.pop();//刪除首部元素(即指針) ?
  • ????????Visit(pNode);?//?訪問(wèn)節(jié)點(diǎn)??
  • ????????if(pNode->m_pLeft?!=?NULL)??
  • ????????????q.push(pNode->m_pLeft);//添加元素到隊(duì)列尾部??
  • ????????if(pNode->m_pRight?!=?NULL)??
  • ????????????q.push(pNode->m_pRight);//添加元素到隊(duì)列尾部??
  • ????}??
  • ????return;??
  • }??
  • 5. 將二叉查找樹(shù)變?yōu)橛行虻碾p向鏈表

    要求不能創(chuàng)建新節(jié)點(diǎn),只調(diào)整指針。
    遞歸解法:
    (1)如果二叉樹(shù)查找樹(shù)為空,不需要轉(zhuǎn)換,對(duì)應(yīng)雙向鏈表的第一個(gè)節(jié)點(diǎn)是NULL,最后一個(gè)節(jié)點(diǎn)是NULL
    (2)如果二叉查找樹(shù)不為空:
    如果左子樹(shù)為空,對(duì)應(yīng)雙向有序鏈表的第一個(gè)節(jié)點(diǎn)是根節(jié)點(diǎn),左邊不需要其他操作; 如果左子樹(shù)不為空,轉(zhuǎn)換左子樹(shù),二叉查找樹(shù)對(duì)應(yīng)雙向有序鏈表的第一個(gè)節(jié)點(diǎn)就是左子樹(shù)轉(zhuǎn)換后雙向有序鏈表的第一個(gè)節(jié)點(diǎn),同時(shí)將根節(jié)點(diǎn)和左子樹(shù)轉(zhuǎn)換后的雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)連接; 如果右子樹(shù)為空,對(duì)應(yīng)雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)是根節(jié)點(diǎn),右邊不需要其他操作; 如果右子樹(shù)不為空,對(duì)應(yīng)雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)就是右子樹(shù)轉(zhuǎn)換后雙向有序鏈表的最后一個(gè)節(jié)點(diǎn),同時(shí)將根節(jié)點(diǎn)和右子樹(shù)轉(zhuǎn)換后的雙向有序鏈表的第一個(gè)節(jié)點(diǎn)連接。 參考代碼如下:
    [cpp]?view plaincopy
  • /******************************************************************************?
  • 參數(shù):?
  • pRoot:?二叉查找樹(shù)根節(jié)點(diǎn)指針?
  • pFirstNode:?轉(zhuǎn)換后雙向有序鏈表的第一個(gè)節(jié)點(diǎn)指針?
  • pLastNode:?轉(zhuǎn)換后雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)指針?
  • ******************************************************************************/??
  • void?Convert(BinaryTreeNode?*?pRoot,???
  • ?????????????BinaryTreeNode?*?&?pFirstNode,?BinaryTreeNode?*?&?pLastNode)??
  • {??
  • ????BinaryTreeNode?*pFirstLeft,?*pLastLeft,?*?pFirstRight,?*pLastRight;??
  • ????if(pRoot?==?NULL)???
  • ????{??
  • ????????pFirstNode?=?NULL;??
  • ????????pLastNode?=?NULL;??
  • ????????return;??
  • ????}??
  • ??
  • ????if(pRoot->m_pLeft?==?NULL)??
  • ????{??
  • ????????//?如果左子樹(shù)為空,對(duì)應(yīng)雙向有序鏈表的第一個(gè)節(jié)點(diǎn)是根節(jié)點(diǎn)??
  • ????????pFirstNode?=?pRoot;??
  • ????}??
  • ????else??
  • ????{??
  • ????????Convert(pRoot->m_pLeft,?pFirstLeft,?pLastLeft);??
  • ????????//?二叉查找樹(shù)對(duì)應(yīng)雙向有序鏈表的第一個(gè)節(jié)點(diǎn)就是左子樹(shù)轉(zhuǎn)換后雙向有序鏈表的第一個(gè)節(jié)點(diǎn)??
  • ????????pFirstNode?=?pFirstLeft;??
  • ????????//?將根節(jié)點(diǎn)和左子樹(shù)轉(zhuǎn)換后的雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)連接??
  • ????????pRoot->m_pLeft?=?pLastLeft;??
  • ????????pLastLeft->m_pRight?=?pRoot;??
  • ????}??
  • ??
  • ????if(pRoot->m_pRight?==?NULL)??
  • ????{??
  • ????????//?對(duì)應(yīng)雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)是根節(jié)點(diǎn)??
  • ????????pLastNode?=?pRoot;??
  • ????}??
  • ????else??
  • ????{??
  • ????????Convert(pRoot->m_pRight,?pFirstRight,?pLastRight);??
  • ????????//?對(duì)應(yīng)雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)就是右子樹(shù)轉(zhuǎn)換后雙向有序鏈表的最后一個(gè)節(jié)點(diǎn)??
  • ????????pLastNode?=?pLastRight;??
  • ????????//?將根節(jié)點(diǎn)和右子樹(shù)轉(zhuǎn)換后的雙向有序鏈表的第一個(gè)節(jié)點(diǎn)連接??
  • ????????pRoot->m_pRight?=?pFirstRight;??
  • ????????pFirstRight->m_pLeft?=?pRoot;??
  • ????}??
  • ??
  • ????return;??
  • }??
  • 6. 求二叉樹(shù)第K層的節(jié)點(diǎn)個(gè)數(shù)
    遞歸解法:
    (1)如果二叉樹(shù)為空或者k<1返回0
    (2)如果二叉樹(shù)不為空并且k==1,返回1
    (3)如果二叉樹(shù)不為空且k>1,返回左子樹(shù)中k-1層的節(jié)點(diǎn)個(gè)數(shù)與右子樹(shù)k-1層節(jié)點(diǎn)個(gè)數(shù)之和
    參考代碼如下:
    [cpp]?view plaincopy
  • int?GetNodeNumKthLevel(BinaryTreeNode?*?pRoot,?int?k)??
  • {??
  • ????if(pRoot?==?NULL?||?k?<?1)??
  • ????????return?0;??
  • ????if(k?==?1)??
  • ????????return?1;??
  • ????int?numLeft?=?GetNodeNumKthLevel(pRoot->m_pLeft,?k-1);?//?左子樹(shù)中k-1層的節(jié)點(diǎn)個(gè)數(shù)??
  • ????int?numRight?=?GetNodeNumKthLevel(pRoot->m_pRight,?k-1);?//?右子樹(shù)中k-1層的節(jié)點(diǎn)個(gè)數(shù)??
  • ????return?(numLeft?+?numRight);??
  • }??
  • 7. 求二叉樹(shù)中葉子節(jié)點(diǎn)的個(gè)數(shù)

    完全二叉樹(shù)有2*n-1 個(gè)節(jié)點(diǎn),則它的葉子節(jié)點(diǎn)數(shù)為?

    完全二叉樹(shù)的節(jié)點(diǎn)數(shù)是奇數(shù),說(shuō)明此完全二叉樹(shù)也是滿二叉樹(shù),也就是說(shuō)每個(gè)內(nèi)部節(jié)點(diǎn)正好都有2個(gè)葉結(jié)點(diǎn).
    設(shè)內(nèi)部節(jié)點(diǎn)數(shù)為a,葉節(jié)點(diǎn)數(shù)為b,結(jié)點(diǎn)總數(shù)為m,明顯有a+b=m (1)
    非空滿二叉樹(shù)中所有節(jié)點(diǎn)的出度正好等于入度,每個(gè)內(nèi)部節(jié)點(diǎn)出度為2,葉節(jié)點(diǎn)出度為0,所有節(jié)點(diǎn)的出度和為2a;根節(jié)點(diǎn)入度為0,其他節(jié)點(diǎn)的入度為1,所有節(jié)點(diǎn)的入度和為a+b-1;因此有2a=a+b-1 (2)
    由(1),(2)得 b=(m+1)/2,a=(m-1)/2,b=a+1
    也就是說(shuō),非空滿二叉樹(shù)的葉節(jié)點(diǎn)數(shù)正好比內(nèi)部節(jié)點(diǎn)數(shù)多1
    此完全二叉樹(shù)的結(jié)點(diǎn)總數(shù)為2n-1,因此其葉結(jié)點(diǎn)數(shù)為n.


    遞歸解法:

    (1)如果二叉樹(shù)為空,返回0
    (2)如果二叉樹(shù)不為空且左右子樹(shù)為空,返回1
    (3)如果二叉樹(shù)不為空,且左右子樹(shù)不同時(shí)為空,返回左子樹(shù)中葉子節(jié)點(diǎn)個(gè)數(shù)加上右子樹(shù)中葉子節(jié)點(diǎn)個(gè)數(shù)
    參考代碼如下:
    [cpp]?view plaincopy
  • int?GetLeafNodeNum(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)??
  • ????????return?0;??
  • ????if(pRoot->m_pLeft?==?NULL?&&?pRoot->m_pRight?==?NULL)??
  • ????????return?1;??
  • ????int?numLeft?=?GetLeafNodeNum(pRoot->m_pLeft);?//?左子樹(shù)中葉節(jié)點(diǎn)的個(gè)數(shù)??
  • ????int?numRight?=?GetLeafNodeNum(pRoot->m_pRight);?//?右子樹(shù)中葉節(jié)點(diǎn)的個(gè)數(shù)??
  • ????return?(numLeft?+?numRight);??
  • } ?
  • 8. 判斷兩棵二叉樹(shù)是否結(jié)構(gòu)相同

    不考慮數(shù)據(jù)內(nèi)容。結(jié)構(gòu)相同意味著對(duì)應(yīng)的左子樹(shù)和對(duì)應(yīng)的右子樹(shù)都結(jié)構(gòu)相同。
    遞歸解法:
    (1)如果兩棵二叉樹(shù)都為空,返回真
    (2)如果兩棵二叉樹(shù)一棵為空,另一棵不為空,返回假
    (3)如果兩棵二叉樹(shù)都不為空,如果對(duì)應(yīng)的左子樹(shù)和右子樹(shù)都同構(gòu)返回真,其他返回假
    參考代碼如下:
    [cpp]?view plaincopy
  • bool?StructureCmp(BinaryTreeNode?*?pRoot1,?BinaryTreeNode?*?pRoot2)??
  • {??
  • ????if(pRoot1?==?NULL?&&?pRoot2?==?NULL)?//?都為空,返回真??
  • ????????return?true;??
  • ????else?if(pRoot1?==?NULL?||?pRoot2?==?NULL)?//?有一個(gè)為空,一個(gè)不為空,返回假??
  • ????????return?false;??
  • ????bool?resultLeft?=?StructureCmp(pRoot1->m_pLeft,?pRoot2->m_pLeft);?//?比較對(duì)應(yīng)左子樹(shù)???
  • ????bool?resultRight?=?StructureCmp(pRoot1->m_pRight,?pRoot2->m_pRight);?//?比較對(duì)應(yīng)右子樹(shù)??
  • ????return?(resultLeft?&&?resultRight);??
  • }???
  • 9. 判斷二叉樹(shù)是不是平衡二叉樹(shù)
    遞歸解法:
    (1)如果二叉樹(shù)為空,返回真
    (2)如果二叉樹(shù)不為空,如果左子樹(shù)和右子樹(shù)都是AVL樹(shù)并且左子樹(shù)和右子樹(shù)高度相差不大于1,返回真,其他返回假
    參考代碼:
    [cpp]?view plaincopy
  • bool?IsAVL(BinaryTreeNode?*?pRoot,?int?&?height)??
  • {??
  • ????if(pRoot?==?NULL)?//?空樹(shù),返回真??
  • ????{??
  • ????????height?=?0;??
  • ????????return?true;??
  • ????}??
  • ????int?heightLeft;??
  • ????bool?resultLeft?=?IsAVL(pRoot->m_pLeft,?heightLeft);??
  • ????int?heightRight;??
  • ????bool?resultRight?=?IsAVL(pRoot->m_pRight,?heightRight);??
  • ????if(resultLeft?&&?resultRight?&&?abs(heightLeft?-?heightRight)?<=?1)?//?左子樹(shù)和右子樹(shù)都是AVL,并且高度相差不大于1,返回真??
  • ????{??
  • ????????height?=?max(heightLeft,?heightRight)?+?1;??
  • ????????return?true;??
  • ????}??
  • ????else??
  • ????{??
  • ????????height?=?max(heightLeft,?heightRight)?+?1;??
  • ????????return?false;??
  • ????}??
  • }??
  • 10. 求二叉樹(shù)的鏡像
    遞歸解法:
    (1)如果二叉樹(shù)為空,返回空
    (2)如果二叉樹(shù)不為空,求左子樹(shù)和右子樹(shù)的鏡像,然后交換左子樹(shù)和右子樹(shù)
    參考代碼如下:
    [cpp]?view plaincopy
  • BinaryTreeNode?*?Mirror(BinaryTreeNode?*?pRoot)??
  • {??
  • ????if(pRoot?==?NULL)?//?返回NULL??
  • ????????return?NULL;??
  • ????BinaryTreeNode?*?pLeft?=?Mirror(pRoot->m_pLeft);?//?求左子樹(shù)鏡像??
  • ????BinaryTreeNode?*?pRight?=?Mirror(pRoot->m_pRight);?//?求右子樹(shù)鏡像??
  • ????????//?交換左子樹(shù)和右子樹(shù)??
  • ????pRoot->m_pLeft?=?pRight;??
  • ????pRoot->m_pRight?=?pLeft;??
  • ????return?pRoot;??
  • }??
  • 11. 求二叉樹(shù)中兩個(gè)節(jié)點(diǎn)的最低公共祖先節(jié)點(diǎn)
    遞歸解法:
    (1)如果兩個(gè)節(jié)點(diǎn)分別在根節(jié)點(diǎn)的左子樹(shù)和右子樹(shù),則返回根節(jié)點(diǎn)
    (2)如果兩個(gè)節(jié)點(diǎn)都在左子樹(shù),則遞歸處理左子樹(shù);如果兩個(gè)節(jié)點(diǎn)都在右子樹(shù),則遞歸處理右子樹(shù)
    參考代碼如下:
    [cpp]?view plaincopy
  • bool?FindNode(BinaryTreeNode?*?pRoot,?BinaryTreeNode?*?pNode)??
  • {??
  • ????if(pRoot?==?NULL?||?pNode?==?NULL)??
  • ????????return?false;??
  • ??
  • ????if(pRoot?==?pNode)??
  • ????????return?true;??
  • ??
  • ????bool?found?=?FindNode(pRoot->m_pLeft,?pNode);??
  • ????if(!found)??
  • ????????found?=?FindNode(pRoot->m_pRight,?pNode);??
  • ??
  • ????return?found;??
  • }??
  • ??
  • BinaryTreeNode?*?GetLastCommonParent(BinaryTreeNode?*?pRoot,???
  • ?????????????????????????????????????BinaryTreeNode?*?pNode1,???
  • ?????????????????????????????????????BinaryTreeNode?*?pNode2)??
  • {??
  • ????if(FindNode(pRoot->m_pLeft,?pNode1))??
  • ????{??
  • ????????if(FindNode(pRoot->m_pRight,?pNode2))??
  • ????????????return?pRoot;??
  • ????????else??
  • ????????????return?GetLastCommonParent(pRoot->m_pLeft,?pNode1,?pNode2);??
  • ????}??
  • ????else??
  • ????{??
  • ????????if(FindNode(pRoot->m_pLeft,?pNode2))??
  • ????????????return?pRoot;??
  • ????????else??
  • ????????????return?GetLastCommonParent(pRoot->m_pRight,?pNode1,?pNode2);??
  • ????}??
  • }??
  • 遞歸解法效率很低,有很多重復(fù)的遍歷,下面看一下非遞歸解法。
    非遞歸解法:
    先求從根節(jié)點(diǎn)到兩個(gè)節(jié)點(diǎn)的路徑,然后再比較對(duì)應(yīng)路徑的節(jié)點(diǎn)就行,最后一個(gè)相同的節(jié)點(diǎn)也就是他們?cè)诙鏄?shù)中的最低公共祖先節(jié)點(diǎn)
    參考代碼如下:
    [cpp]?view plaincopy
  • bool?GetNodePath(BinaryTreeNode?*?pRoot,?BinaryTreeNode?*?pNode,???
  • ?????????????????list<BinaryTreeNode?*>?&?path)??
  • {??
  • ????if(pRoot?==?pNode)??
  • ????{?????
  • ????????path.push_back(pRoot);??
  • ????????return?true;??
  • ????}??
  • ????if(pRoot?==?NULL)??
  • ????????return?false;??
  • ????path.push_back(pRoot);??
  • ????bool?found?=?false;??
  • ????found?=?GetNodePath(pRoot->m_pLeft,?pNode,?path);??
  • ????if(!found)??
  • ????????found?=?GetNodePath(pRoot->m_pRight,?pNode,?path);??
  • ????if(!found)??
  • ????????path.pop_back();??
  • ????return?found;??
  • }??
  • BinaryTreeNode?*?GetLastCommonParent(BinaryTreeNode?*?pRoot,?BinaryTreeNode?*?pNode1,?BinaryTreeNode?*?pNode2)??
  • {??
  • ????if(pRoot?==?NULL?||?pNode1?==?NULL?||?pNode2?==?NULL)??
  • ????????return?NULL;??
  • ????list<BinaryTreeNode*>?path1;??
  • ????bool?bResult1?=?GetNodePath(pRoot,?pNode1,?path1);??
  • ????list<BinaryTreeNode*>?path2;??
  • ????bool?bResult2?=?GetNodePath(pRoot,?pNode2,?path2);??
  • ????if(!bResult1?||?!bResult2)???
  • ????????return?NULL;??
  • ????BinaryTreeNode?*?pLast?=?NULL;??
  • ????list<BinaryTreeNode*>::const_iterator?iter1?=?path1.begin();??
  • ????list<BinaryTreeNode*>::const_iterator?iter2?=?path2.begin();??
  • ????while(iter1?!=?path1.end()?&&?iter2?!=?path2.end())??
  • ????{??
  • ????????if(*iter1?==?*iter2)??
  • ????????????pLast?=?*iter1;??
  • ????????else??
  • ????????????break;??
  • ????????iter1++;??
  • ????????iter2++;??
  • ????}??
  • ????return?pLast;??
  • }??

  • 在上述算法的基礎(chǔ)上稍加變化即可求二叉樹(shù)中任意兩個(gè)節(jié)點(diǎn)的距離了。
    12. 求二叉樹(shù)中節(jié)點(diǎn)的最大距離
    即二叉樹(shù)中相距最遠(yuǎn)的兩個(gè)節(jié)點(diǎn)之間的距離。
    遞歸解法:
    (1)如果二叉樹(shù)為空,返回0,同時(shí)記錄左子樹(shù)和右子樹(shù)的深度,都為0
    (2)如果二叉樹(shù)不為空,最大距離要么是左子樹(shù)中的最大距離,要么是右子樹(shù)中的最大距離,要么是左子樹(shù)節(jié)點(diǎn)中到根節(jié)點(diǎn)的最大距離+右子樹(shù)節(jié)點(diǎn)中到根節(jié)點(diǎn)的最大距離,同時(shí)記錄左子樹(shù)和右子樹(shù)節(jié)點(diǎn)中到根節(jié)點(diǎn)的最大距離。

    參考代碼如下:

    [cpp]?view plaincopy
  • int?GetMaxDistance(BinaryTreeNode?*?pRoot,?int?&?maxLeft,?int?&?maxRight)??
  • {??
  • ????//?maxLeft,?左子樹(shù)中的節(jié)點(diǎn)距離根節(jié)點(diǎn)的最遠(yuǎn)距離??
  • ????//?maxRight,?右子樹(shù)中的節(jié)點(diǎn)距離根節(jié)點(diǎn)的最遠(yuǎn)距離??
  • ????if(pRoot?==?NULL)??
  • ????{??
  • ????????maxLeft?=?0;??
  • ????????maxRight?=?0;??
  • ????????return?0;??
  • ????}??
  • ????int?maxLL,?maxLR,?maxRL,?maxRR;??
  • ????int?maxDistLeft,?maxDistRight;??
  • ????if(pRoot->m_pLeft?!=?NULL)??
  • ????{??
  • ????????maxDistLeft?=?GetMaxDistance(pRoot->m_pLeft,?maxLL,?maxLR);??
  • ????????maxLeft?=?max(maxLL,?maxLR)?+?1;??
  • ????}??
  • ????else??
  • ????{??
  • ????????maxDistLeft?=?0;??
  • ????????maxLeft?=?0;??
  • ????}??
  • ????if(pRoot->m_pRight?!=?NULL)??
  • ????{??
  • ????????maxDistRight?=?GetMaxDistance(pRoot->m_pRight,?maxRL,?maxRR);??
  • ????????maxRight?=?max(maxRL,?maxRR)?+?1;??
  • ????}??
  • ????else??
  • ????{??
  • ????????maxDistRight?=?0;??
  • ????????maxRight?=?0;??
  • ????}??
  • ????return?max(max(maxDistLeft,?maxDistRight),?maxLeft+maxRight);??
  • }??
  • 13. 由前序遍歷序列和中序遍歷序列重建二叉樹(shù)
    二叉樹(shù)前序遍歷序列中,第一個(gè)元素總是樹(shù)的根節(jié)點(diǎn)的值。中序遍歷序列中,左子樹(shù)的節(jié)點(diǎn)的值位于根節(jié)點(diǎn)的值的左邊,右子樹(shù)的節(jié)點(diǎn)的值位
    于根節(jié)點(diǎn)的值的右邊。
    遞歸解法:
    (1)如果前序遍歷為空或中序遍歷為空或節(jié)點(diǎn)個(gè)數(shù)小于等于0,返回NULL。
    (2)創(chuàng)建根節(jié)點(diǎn)。 前序遍歷的第一個(gè)數(shù)據(jù)就是根節(jié)點(diǎn)的數(shù)據(jù),在中序遍歷中找到根節(jié)點(diǎn)的位置,可分別得知左子樹(shù)和右子樹(shù)的前序和中序遍

    歷序列,重建左右子樹(shù)。

    題目描述:

    輸入某二叉樹(shù)的前序遍歷和中序遍歷的結(jié)果,請(qǐng)重建出該二叉樹(shù)。假設(shè)輸入的前序遍歷和中序遍歷的結(jié)果中都不含重復(fù)的數(shù)字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹(shù)并輸出它的后序遍歷序列。

    輸入:

    輸入可能包含多個(gè)測(cè)試樣例,對(duì)于每個(gè)測(cè)試案例,

    輸入的第一行為一個(gè)整數(shù)n(1<=n<=1000):代表二叉樹(shù)的節(jié)點(diǎn)個(gè)數(shù)。

    輸入的第二行包括n個(gè)整數(shù)(其中每個(gè)元素a的范圍為(1<=a<=1000)):代表二叉樹(shù)的前序遍歷序列。

    輸入的第三行包括n個(gè)整數(shù)(其中每個(gè)元素a的范圍為(1<=a<=1000)):代表二叉樹(shù)的中序遍歷序列。

    輸出:

    對(duì)應(yīng)每個(gè)測(cè)試案例,輸出一行:

    如果題目中所給的前序和中序遍歷序列能構(gòu)成一棵二叉樹(shù),則輸出n個(gè)整數(shù),代表二叉樹(shù)的后序遍歷序列,每個(gè)元素后面都有空格。

    如果題目中所給的前序和中序遍歷序列不能構(gòu)成一棵二叉樹(shù),則輸出”No”。

    樣例輸入:
    81 2 4 7 3 5 6 84 7 2 1 5 3 8 681 2 4 7 3 5 6 84 1 2 7 5 3 8 6
    樣例輸出:
    7 4 2 5 8 6 3 1 No

    ? ? 采用遞歸的方式重構(gòu)二叉樹(shù),關(guān)鍵是要考慮到一些特殊情況,比如:只有根節(jié)點(diǎn)的二叉樹(shù)、只有左子樹(shù)或只有右子樹(shù)的二叉樹(shù)以及二叉樹(shù)根節(jié)點(diǎn)為NULL、前序中序序列不匹配導(dǎo)致不能重構(gòu)二叉樹(shù)等。

    ? ? AC代碼如下(一直在如何實(shí)現(xiàn)判斷能否重構(gòu)二叉樹(shù)的地方徘徊,在九度論壇里大致看了下,借鑒了下各位前輩的思路:定義一個(gè)全局bool變量,用來(lái)跟蹤判斷能夠重構(gòu)):

    [cpp]?view plaincopy
  • #include<stdio.h>??
  • #include<stdlib.h>??
  • ??
  • typedef?int?ElemType;??
  • typedef?struct?BTNode???
  • {??
  • ????ElemType?data;??
  • ????struct?BTNode?*left;??
  • ????struct?BTNode?*right;??
  • }BTNode,*BTree;??
  • ??
  • bool?CanReBuild;????//用來(lái)標(biāo)示是否能夠重構(gòu)二叉樹(shù)??
  • ??
  • /*?
  • pre為前序遍歷數(shù)組,inv為中序遍歷數(shù)組,len為數(shù)組長(zhǎng)度,重構(gòu)二叉樹(shù)*ppTree?
  • */??
  • void?RebuildBinaryTree(BTree?*ppTree,int?*pre,int?*inv,int?len)??
  • {??
  • ????if(p
  • 總結(jié)

    以上是生活随笔為你收集整理的一文搞定面试中的二叉树问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    亚洲a资源| 精品国模一区二区 | 欧美一级视频一区 | 亚洲成人精品久久 | 在线观看自拍 | 国产精品永久免费在线 | 美女黄频在线观看 | 最近中文字幕大全中文字幕免费 | 五月婷婷在线观看 | 欧美午夜精品久久久久久孕妇 | 国产精品久久在线 | 日韩a在线看 | 操操碰 | 亚洲aⅴ乱码精品成人区 | 狠狠色丁香久久婷婷综合_中 | 欧美视屏一区二区 | 久久精品久久综合 | 中文字幕在线观看日本 | 亚洲春色综合另类校园电影 | 视频在线观看入口黄最新永久免费国产 | 国产黄色精品网站 | 国产热re99久久6国产精品 | 99热精品久久 | 久久av在线 | 在线亚州| 亚洲一二区视频 | 91传媒在线播放 | 国产亚洲精品久久久久久久久久久久 | 免费日韩一区二区三区 | 国产小视频国产精品 | 午夜性色 | 91色蜜桃| 天天综合操 | 中文字幕影片免费在线观看 | 中文字幕av在线播放 | 久久免费视频这里只有精品 | 超碰成人网 | 国产精品激情在线观看 | 欧美精品久久久久久久久久丰满 | 国产精品久久一区二区三区不卡 | 久久精品99精品国产香蕉 | 免费视频黄 | 精品一区二区三区电影 | 2022国产精品视频 | 97免费在线观看视频 | 亚洲精品xxxx| 91麻豆产精品久久久久久 | 国产亚洲视频在线观看 | 国产中文在线字幕 | 日韩a在线观看 | 播五月综合 | 91精品一区二区三区蜜臀 | 成人动图 | 在线观看视频福利 | 国产精品手机视频 | 婷婷伊人综合亚洲综合网 | 五月激情久久久 | 日韩欧美精品在线观看视频 | 欧美日韩不卡在线观看 | 97av视频 | 黄色资源在线观看 | 日本免费一二三区 | 日韩中文字幕第一页 | 久久最新视频 | 成年人在线观看免费视频 | 亚洲黄色免费观看 | 免费看一级黄色大全 | 999视频精品 | 国产精品福利在线 | 草久久影院 | 久久精品99国产精品酒店日本 | 69av免费视频 | 最近中文字幕国语免费高清6 | 欧美了一区在线观看 | 日韩va在线观看 | 国产精品福利午夜在线观看 | 91精品国产福利 | 日韩一级电影在线观看 | 久久久影院官网 | 欧美乱码精品一区 | 中文字幕国产一区 | 九九九九九九精品任你躁 | 摸bbb搡bbb搡bbbb| 欧美另类z0zx | 亚洲欧美激情精品一区二区 | 蜜臀aⅴ国产精品久久久国产 | 天天弄天天干 | 国产中文字幕久久 | 超碰97久久| 日韩视频一区二区三区在线播放免费观看 | 在线视频日韩 | 欧美少妇bbwhd | 亚洲国产精品人久久电影 | 亚洲国产一区二区精品专区 | 久操中文字幕在线观看 | 7777xxxx| 国产精品美女久久久久久2018 | 欧美a在线免费观看 | 免费精品在线视频 | 亚洲精品mv在线观看 | 亚洲精品九九 | 一区二区三区中文字幕在线观看 | 免费观看一区二区 | 精品久久久久国产免费第一页 | 高清一区二区三区av | 国产尤物视频在线 | 久久草草影视免费网 | 欧美一级黄色视屏 | 成人在线免费视频 | 一区二区视频在线看 | 最近免费观看的电影完整版 | www.av在线播放 | 亚洲成a人片在线观看网站口工 | 亚洲国产成人久久 | 亚洲狠狠婷婷 | 精品96久久久久久中文字幕无 | 成人一级片在线观看 | 久久国产露脸精品国产 | 99精品国产99久久久久久福利 | 国产精品视频内 | 中文字幕在线免费看线人 | 国产黄色免费电影 | 国产黑丝袜在线 | 六月激情婷婷 | 99久久精品一区二区成人 | 丁香婷婷久久久综合精品国产 | 在线视频欧美精品 | 亚洲 欧美 另类人妖 | 欧美日韩视频一区二区三区 | 国产欧美三级 | 国产欧美精品在线观看 | 国产一区视频免费在线观看 | 国产精品尤物视频 | 免费a一级 | 国产在线不卡一区 | 在线观看黄网站 | 日韩av高清在线观看 | 成人av中文字幕在线观看 | 国产成人一区在线 | 黄色毛片观看 | 在线免费观看视频一区 | 亚洲国产精品资源 | 欧美日韩国产伦理 | 国产精品毛片一区二区在线看 | 狠狠干狠狠久久 | 中文字幕a∨在线乱码免费看 | 亚洲色五月| 国产涩涩网站 | 成人一级免费电影 | 亚洲国产精品500在线观看 | 久综合网| 国产精品激情偷乱一区二区∴ | 一区二区激情 | 久在线观看 | 色免费在线 | 在线免费观看亚洲视频 | 婷婷亚洲五月 | 国内精品亚洲 | 欧美成人黄色片 | 天天色天天干天天色 | 中文字幕在线观看网址 | 中文国产在线观看 | 91传媒免费观看 | 青草视频在线 | 亚洲三级黄色 | 日韩大陆欧美高清视频区 | 婷婷日日| 免费观看91视频大全 | 91理论电影 | 91视频麻豆 | 在线成人免费av | 国产精品亚洲成人 | 狠狠色丁香久久婷婷综 | 成年人在线免费看视频 | 亚洲夜夜爽 | 国产精品久久久久久久久蜜臀 | 婷婷久久综合九色综合 | 欧美精品第一 | 国产精品久久久久永久免费 | 欧美一二三四在线 | 亚洲激色| 日韩精品黄 | 成人综合日日夜夜 | 成人xxxx | 成人av在线影视 | 成人福利在线播放 | 国产精品久久久久久久免费大片 | 99精品在这里 | 亚洲欧美日韩国产精品一区午夜 | 成年人免费在线看 | 最近中文字幕在线播放 | www.天天射.com | 中文字幕在线观看不卡 | h文在线观看免费 | 国产亚洲精品久久久久久久久久久久 | 色偷偷av男人天堂 | 色多多污污在线观看 | 国内综合精品午夜久久资源 | 久久人人爽爽 | 午夜av在线免费 | 99久久婷婷国产综合精品 | 久久免费视屏 | av中文在线播放 | 久久精品99国产国产 | www.com在线观看 | 国产精品久久久精品 | 91亚洲精品久久久 | 亚洲人成在 | 97精品国产97久久久久久 | 黄色大片免费播放 | 午夜久久久久久久久久影院 | 999超碰 | 亚洲日日日 | 国产精品一区二区在线播放 | 国产精品一区二区三区四区在线观看 | 亚洲激情综合网 | 日韩av片无码一区二区不卡电影 | 色视频在线| 国产成人精品久久久久蜜臀 | 欧美一区中文字幕 | 久久精品第一页 | 在线播放91| 日日干日日色 | 久久6精品 | 黄色小说在线观看视频 | 国产麻豆剧传媒免费观看 | 五月天视频网站 | 久久五月网 | 亚洲欧美视屏 | 免费在线播放av电影 | www.色在线| 日韩精品不卡在线 | 日韩大片在线免费观看 | 成人久久久精品国产乱码一区二区 | 国产最新精品视频 | 在线精品视频在线观看高清 | 久久公开免费视频 | 黄污网站在线观看 | 九色自拍视频 | 久久久久国产精品一区二区 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 国产伦精品一区二区三区无广告 | 国产爽妇网 | 99久久精品电影 | 国产精品国产毛片 | 亚洲人成人在线 | 亚洲精品影视 | 97免费视频在线 | 亚洲免费在线播放视频 | 在线观看视频在线观看 | 99久久日韩精品免费热麻豆美女 | 午夜手机电影 | 一级a性色生活片久久毛片波多野 | 色爽网站 | 一本一本久久a久久精品综合 | 天天干天天做 | 亚洲精品国产精品国自产在线 | 久久久精品 | av片在线看 | 东方av在| 美女很黄免费网站 | 日韩精品视频免费看 | 国产精品免费一区二区三区在线观看 | 亚洲成a人片77777潘金莲 | 色噜噜狠狠狠狠色综合久不 | 西西444www大胆高清视频 | 国产a国产 | av高清网站在线观看 | 在线免费黄色片 | 在线一区二区三区 | 最新国产精品久久精品 | 免费在线观看亚洲视频 | 亚洲精品视频免费看 | 亚洲人成网站精品片在线观看 | 免费av片在线 | 国内久久视频 | 国产一区二区三精品久久久无广告 | 国产婷婷精品av在线 | 久久精品久久久精品美女 | 人人干网站 | 中文字幕一区二区三 | 五月婷婷在线综合 | 亚洲成av人片在线观看 | 99精品免费视频 | 欧美在线视频第一页 | 二区视频在线 | 中日韩欧美精彩视频 | 欧美日韩在线观看一区二区 | 欧美日韩一区二区三区免费视频 | 在线视频手机国产 | 久久er99热精品一区二区三区 | 狠狠色丁香九九婷婷综合五月 | 99亚洲天堂 | 国产在线一区观看 | 91人人澡 | 在线 影视 一区 | 麻豆国产精品一区二区三区 | 国产一区二区三区 在线 | 国内精品美女在线观看 | 国产美女主播精品一区二区三区 | 激情电影影院 | 国产精品久久久久久久电影 | 久九视频 | 午夜.dj高清免费观看视频 | 日韩国产欧美在线播放 | 日韩欧美高清视频在线观看 | 国内精品久久久久久久97牛牛 | 亚洲二级片 | 久久国产精品免费视频 | 成人午夜黄色影院 | 色姑娘综合天天 | 国产一区在线免费 | 91精品国产九九九久久久亚洲 | 人人射网站| 国产精品第三页 | 丁香婷婷色月天 | 日韩欧美一区视频 | 91九色成人 | 精品一区二区在线看 | 久久a免费视频 | 亚洲精品456在线播放第一页 | 免费中午字幕无吗 | 久久国产精品区 | 四虎成人精品在永久免费 | 人人爽人人插 | 日夜夜精品视频 | 国产啊v在线观看 | 97超碰人人网 | 久久五月婷婷丁香社区 | www.com黄色| 少妇按摩av | 精品中文字幕视频 | 国产精品av在线免费观看 | 亚洲久草在线 | 日日干干夜夜 | 国产日韩精品一区二区三区在线 | 国产精品 美女 | 日女人免费视频 | 一区二区 精品 | 亚洲理论电影网 | 亚洲国产日韩欧美 | 成人一级在线 | 精品久久国产 | 狠狠操狠狠操 | 99久久精品免费一区 | 欧洲一区二区在线观看 | av不卡中文字幕 | 国精产品999国精产品视频 | 欧美精品一二 | 欧美91视频 | 91原创在线观看 | 国产 欧美 在线 | 久久久天天操 | 亚洲精品视频第一页 | 中文字幕在线免费看线人 | 国产99视频在线观看 | 99热精品久久 | 外国av网 | 97超碰资源 | 国产精品一区在线观看你懂的 | 色夜视频 | 久久久久女人精品毛片 | 免费看十八岁美女 | 天堂视频一区 | 国产福利一区二区三区视频 | 波多野结衣在线观看一区二区三区 | 黄色电影在线免费观看 | 黄色视屏免费在线观看 | 视频一区二区精品 | 欧美日韩国产在线一区 | 中文字幕中文字幕在线一区 | 超碰av在线播放 | 中文字幕欧美日韩va免费视频 | 欧美少妇xxx | 18性欧美xxxⅹ性满足 | 日韩精品一区二区三区水蜜桃 | 国产综合精品久久 | 九九免费在线观看 | 欧美va天堂在线电影 | 91成人在线免费观看 | 久久精品亚洲一区二区三区观看模式 | 成人在线观看网址 | 在线成人免费 | 久久人人爽人人爽人人片av免费 | 欧美精品中文在线免费观看 | 91精品啪在线观看国产线免费 | 精品久久久久久久久久久久久久久久 | 夜色在线资源 | 国产精品久久久久久久免费观看 | 狠狠色狠狠色终合网 | 久久精品99国产精品酒店日本 | 九九九在线 | 91高清免费看 | 欧美午夜剧场 | 四虎国产精品成人免费4hu | 久久福利综合 | 免费色婷婷 | 中文av在线播放 | av一级久久 | 韩国一区二区三区在线观看 | 在线观看一区视频 | av不卡中文字幕 | 色综合天天做天天爱 | 亚洲年轻女教师毛茸茸 | 国产视频精品免费播放 | 999超碰 | 欧美精品一区二区三区一线天视频 | 丁香激情五月婷婷 | 视频国产在线观看18 | 亚洲精品视频在线观看视频 | 少妇性bbb搡bbb爽爽爽欧美 | 国产精品久久久久久久久费观看 | 久久看视频 | 国产在线国产 | 婷婷99 | 中文字幕资源在线观看 | 中文字幕在线视频免费播放 | 伊人中文字幕在线 | 日韩三级一区 | 亚洲三级视频 | 午夜精品一区二区三区在线播放 | 成人av高清在线观看 | 欧美精品久久久久a | 久久黄色影视 | 久久99精品久久久久久 | 国产精品视频免费在线观看 | 蜜桃视频在线观看一区 | 久久国产精品免费观看 | 黄污在线看 | 国产原创中文在线 | 欧美日韩久久一区 | 国产麻豆视频网站 | 中文在线8新资源库 | 亚洲精品中文在线 | 日韩av区| 玖玖在线观看视频 | 免费看片网址 | 狠狠狠狠狠色综合 | 欧美日韩aaaa | 成人午夜网址 | 日韩中文久久 | 精品在线观看一区二区 | 99在线视频免费观看 | 狠狠色狠狠色综合日日92 | 午夜视频亚洲 | 久久精品日产第一区二区三区乱码 | 欧美日韩国产二区 | 在线v | 国产精品爽爽爽 | 久久久久久在线观看 | 精品人妖videos欧美人妖 | 亚洲a网 | 亚洲人成免费 | 在线免费观看视频a | 99在线观看视频 | 久久黄色小说视频 | 狠狠色噜噜狠狠狠狠2021天天 | 欧美一区二区免费在线观看 | 00av视频| 最新午夜电影 | 操操综合网 | 99热99re6国产在线播放 | 射射射综合网 | 玖玖在线播放 | 91视频链接 | 99视频黄 | 97偷拍视频| 久久99亚洲精品久久 | 美女精品 | 97精品国产91久久久久久 | 国产视频 亚洲精品 | 国产一区二区在线看 | 激情五月婷婷综合 | 6699私人影院| 日日干天夜夜 | 西西4444www大胆无视频 | 超级碰99 | 在线免费看片 | 欧美久草在线 | 欧美日韩中文字幕综合视频 | 人人澡人人舔 | 亚洲精品玖玖玖av在线看 | 日韩欧美在线观看一区二区 | 99精品在线免费视频 | 日本最新高清不卡中文字幕 | 久久福利精品 | 九色91在线视频 | 亚洲欧美精品一区二区 | 999视频在线播放 | 99热最新精品 | 色婷婷成人网 | 色窝资源 | 国产精品永久免费 | 91免费版成人 | 国产精品免费视频观看 | 亚洲美女精品 | 日本公妇色中文字幕 | 免费亚洲视频在线观看 | 久久99亚洲精品久久 | 精品国产精品国产偷麻豆 | 国产一线在线 | 日韩免费中文字幕 | 免费看的黄网站软件 | av激情五月 | 视频一区久久 | 日本女人的性生活视频 | 成人av免费在线观看 | 亚洲高清视频在线播放 | 国产91精品看黄网站在线观看动漫 | 国产小视频网站 | 免费看久久久 | 亚洲色图22p | 国产91精品在线观看 | 国产日韩欧美在线播放 | 亚洲精品天天 | 成人午夜精品久久久久久久3d | 国产精品一区久久久久 | 国产主播大尺度精品福利免费 | 中文字幕电影在线 | 日本三级中文字幕在线观看 | 午夜精品99久久免费 | 99国内精品 | 国产一区二区在线观看视频 | 婷婷国产v亚洲v欧美久久 | 国产麻豆剧传媒免费观看 | 日韩欧美一区二区不卡 | 日本精品视频在线播放 | 国产精品入口麻豆 | 欧美 日韩 国产 中文字幕 | 日韩在线免费不卡 | 一区二区三区在线免费观看 | 精品一区二区在线免费观看 | 国产韩国日本高清视频 | av不卡中文字幕 | 免费看精品久久片 | 亚洲极色 | 日韩欧美一二三 | 久久人人97超碰com | 欧美91精品久久久久国产性生爱 | 国产精品欧美久久 | 一区二区三区四区在线免费观看 | 国产精品视频永久免费播放 | 久久亚洲免费视频 | 精品国产亚洲在线 | 久久精品国产成人精品 | 久精品视频在线 | 男女全黄一级一级高潮免费看 | 久久毛片网站 | 欧美xxxxx在线视频 | 一本一本久久a久久精品牛牛影视 | 91精品久久久久 | 亚洲国产色一区 | 国产亚洲91 | 亚洲人成人在线 | 久久99久久久久久 | 精品一区二区三区电影 | 不卡中文字幕在线 | 日韩网站在线观看 | 免费观看av| 国产资源在线视频 | 国产精品综合av一区二区国产馆 | 97精品视频在线 | 日韩 在线 | 在线日本看片免费人成视久网 | 亚洲黄色在线播放 | 999久久国产精品免费观看网站 | 在线国产一区二区三区 | www.大网伊人 | 91自拍视频在线观看 | 国产不卡毛片 | 一区二区网| 一区二区三区高清在线 | 亚洲精品五月天 | 国产精品18久久久久久首页狼 | 黄色电影在线免费观看 | 91人人爽久久涩噜噜噜 | 国产精品久久99综合免费观看尤物 | 亚洲黄色片 | 色婷婷综合在线 | 日本一区二区不卡高清 | 亚洲三级在线免费观看 | 国产精品久久久久久久电影 | 天天干夜夜爽 | 午夜黄网 | 蜜臀久久99精品久久久无需会员 | 色视频在线| 婷婷深爱网 | 五月婷婷综合在线视频 | 亚洲免费在线播放视频 | 日韩在线一区二区免费 | 97色狠狠 | 国产一区 在线播放 | 亚洲韩国一区二区三区 | 成人中文字幕在线 | 欧亚日韩精品一区二区在线 | 激情婷婷久久 | 欧美一级久久久 | 国产精品一区二区在线 | 国产成视频在线观看 | 亚洲v欧美v国产v在线观看 | 操久久免费视频 | 91免费观看网站 | 激情婷婷 | 欧美性生爱 | 欧美日本三级 | 久久不卡国产精品一区二区 | 欧美一二三专区 | 人九九精品 | 色射爱| 国产成人综合图片 | 国产精久久久久久久 | 男女全黄一级一级高潮免费看 | 亚洲精品中文字幕在线 | 69xxxx欧美 | 国产精品美女免费看 | 狂野欧美激情性xxxx欧美 | 色香网| 波多野结衣久久资源 | 久久福利| 亚洲黑丝少妇 | 黄色国产区| 日韩欧美有码在线 | 808电影免费观看三年 | 中文字幕资源网在线观看 | 成人97视频| 久久精品综合 | 国产精品女教师 | 国产美女被啪进深处喷白浆视频 | 91在线精品播放 | 久久午夜网 | 日韩在线视频网站 | 8x成人在线 | 中文字幕av一区二区三区四区 | 亚洲国产精品视频在线观看 | 成人日批视频 | 91视频观看免费 | 亚洲天天摸日日摸天天欢 | 日日射天天射 | 91麻豆传媒 | 黄色片免费在线 | 超碰在线观看99 | 亚洲精品五月 | 日韩最新av| 亚洲五月综合 | 成人av视屏 | 久久精品影视 | 一区二区三区在线播放 | 国外成人在线视频网站 | 精品国产视频一区 | 色视频网页 | 久久精品com | 久久亚洲欧美 | 久久久福利视频 | 亚洲欧美日韩精品久久奇米一区 | 日韩视频在线观看免费 | 国产成人综合图片 | 国产 视频 久久 | 精品亚洲一区二区 | 久久精品网| 欧美一区二区三区在线 | 国产精品欧美日韩 | 亚洲有 在线 | 免费在线观看av电影 | 国产成人免费在线 | 一本一本久久a久久 | 国产精品美女久久久久久久 | 激情中文字幕 | 在线观看一区 | 久久夜夜操 | 国产精品一区二区中文字幕 | 99在线热播精品免费 | 99免费在线观看视频 | 91成人免费电影 | 精品美女在线视频 | 91精品亚洲影视在线观看 | 国产视频一区在线播放 | 日本久久片 | 免费观看一级 | 午夜丁香视频在线观看 | 国产成人61精品免费看片 | 国产视频在线免费 | 视频国产在线 | 18国产精品白浆在线观看免费 | 在线视频1卡二卡三卡 | 九九久久影院 | 99久久久国产精品免费99 | 中文字幕免费观看视频 | 国产日韩欧美精品在线观看 | 国产精品一区免费在线观看 | 亚洲狠狠 | 国产精品ssss在线亚洲 | 亚洲午夜久久久久久久久 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 精品国偷自产国产一区 | 欧美激情xxxx性bbbb | 国产又黄又硬又爽 | 特黄特色特刺激视频免费播放 | 中文网丁香综合网 | 日本三级在线观看中文字 | www.在线看片.com | 91手机视频在线 | www.久久爱.cn | 免费看的黄色 | 天天射日 | 色婷婷婷| 欧美日韩国产精品一区 | 在线综合色 | 在线看av的网址 | 免费男女羞羞的视频网站中文字幕 | 天天做夜夜做 | 日韩在线电影一区 | 免费高清在线观看电视网站 | 国内成人综合 | 91精品婷婷国产综合久久蝌蚪 | 福利电影久久 | 久久久久久久av麻豆果冻 | 久草电影在线观看 | 一区二区三区在线观看免费视频 | 91黄色在线看 | 亚在线播放中文视频 | 国精产品满18岁在线 | 狠狠狠狠狠狠狠狠干 | 亚洲欧美日韩国产精品一区午夜 | 日日夜夜草 | 国产精品资源在线观看 | 久久久久一区二区三区四区 | 成人动漫一区二区 | 欧美色图狠狠干 | 日产av在线播放 | 天天摸夜夜操 | 九九热精品视频在线播放 | 精品字幕在线 | 国产一级电影 | 国产亚洲精品久久久久动 | 久久精品一区二区三区中文字幕 | 美女网站视频一区 | 91成人免费 | 日本在线观看黄色 | 国产在线a | 一区二区三区四区五区六区 | 日日干网址 | 久久伦理影院 | 18岁免费看片 | 亚洲免费视频观看 | 国产一二区精品 | 狠狠色伊人亚洲综合成人 | 99在线精品视频观看 | 久久在线影院 | 亚州性色 | 中文字幕电影高清在线观看 | 国产精品一区二区三区在线播放 | 午夜久久久影院 | 九九热在线免费观看 | 77国产精品| 亚洲精品小视频 | 久久午夜鲁丝片 | 综合网久久 | 国产不卡精品视频 | 男女男视频| 韩国av电影网 | 男女拍拍免费视频 | 亚洲激情婷婷 | 99热这里只有精品8 久久综合毛片 | av黄色影院| 国产综合91 | 国产成人精品免费在线观看 | 国产一二三区在线观看 | 天天激情天天干 | 国产综合精品久久 | 久久精品国产亚洲 | 黄色大片av | 欧美一区二视频在线免费观看 | 天天激情综合网 | 福利一区二区三区四区 | 色综合久久88色综合天天人守婷 | 免费黄色网址网站 | 色资源在线观看 | 韩日电影在线免费看 | 日韩有码欧美 | 91热视频在线观看 | 99精品视频在线看 | 色综合a | 久久久精品福利视频 | 青青河边草观看完整版高清 | 成人av电影在线播放 | 91成人看片| 伊人中文字幕在线 | 超碰999| 91精品在线视频观看 | 九九日九九操 | 国产一级视频在线免费观看 | 蜜桃视频在线观看一区 | 亚洲欧美观看 | 二区三区在线观看 | 99热免费在线 | 丝袜+亚洲+另类+欧美+变态 | 五月婷婷电影网 | 西西444www大胆无视频 | 成人永久在线 | 国产精品久久久久久久久免费看 | 日日干视频 | 91在线视频免费播放 | 国产亚洲精品久久久久动 | 在线国产日韩 | 亚洲经典中文字幕 | 中文字幕在线观看av | 麻豆传媒一区二区 | 欧美日韩国产精品一区二区亚洲 | 久草在线免费看视频 | 国产成人免费av电影 | 国产视频在线看 | 色综合天天综合网国产成人网 | 色五月成人 | 五月情婷婷 | 97在线观看视频免费 | 99亚洲天堂| 亚洲伊人网在线观看 | 久久精品久久99精品久久 | 亚洲国产精品激情在线观看 | 精品视频在线观看 | 日韩av影视 | 天天色天天色 | 久久伊人色综合 | 欧美国产日韩在线视频 | 91精品免费看 | 亚洲国产经典视频 | 天天干,天天射,天天操,天天摸 | 超碰在线色 | 日韩av一区二区三区四区 | 九九免费在线观看视频 | 久久中文欧美 | 中文字幕一区二区三区视频 | 欧美天堂影院 | 中文字幕在线观看亚洲 | 欧美黄色特级片 | 精品自拍sae8—视频 | 500部大龄熟乱视频 欧美日本三级 | 18pao国产成视频永久免费 | 久久成人一区二区 | 日韩欧美一区二区在线 | 粉嫩av一区二区三区四区在线观看 | 人人爽爽人人 | 成人av片免费看 | 在线观看黄色 | 亚洲午夜av电影 | av网站手机在线观看 | 91中文字幕在线播放 | 69精品久久 | 日韩av网站在线播放 | 91麻豆高清视频 | 国内精品一区二区 | 在线色视频小说 | 狠狠躁夜夜av | 中文字幕成人在线观看 | 国产小视频免费在线网址 | www.亚洲精品 | aaa亚洲精品一二三区 | 99久热在线精品 | 婷婷色九月 | 日韩,中文字幕 | 国产91精品在线播放 | 伊人影院在线观看 | 亚洲国产一区二区精品专区 | 欧美污污网站 | 亚洲三级毛片 | 99热在线网站 | 一区二区三区久久精品 | 亚洲电影网站 | av在线永久免费观看 | 国产成人资源 | 91亚洲精品久久久蜜桃网站 | 久久午夜羞羞影院 | 香蕉久草在线 | 免费在线观看av片 | 欧美精品一区在线发布 | 美女视频黄频大全免费 | 91热视频在线观看 | 天天操月月操 | 国产原创在线 | 美女视频网站久久 | 婷婷丁香六月天 | 免费视频二区 | 欧美视频国产视频 | 精品久久久免费视频 | 四虎国产精 | 伊人国产视频 | 五月天久久久 | 欧美精品亚洲精品 | 亚洲激情网站免费观看 | 粉嫩一区二区三区粉嫩91 | 在线小视频你懂的 | 91精品国自产拍天天拍 | 成人黄色视 | 欧美地下肉体性派对 | 日韩黄色在线电影 | 欧美精品午夜 | 成年人在线电影 | 99午夜 | 日日日视频 | 亚欧日韩av | 99精品观看 | 成人黄色大片在线观看 | 欧美日韩高清一区二区三区 | 国产精品一区二区三区免费看 | 国产成人香蕉 | www.91成人 | 色之综合网 | 亚洲一区日韩在线 | 婷婷色伊人 | 国产一级免费在线 | 亚洲一区二区天堂 | 欧美高清成人 | 国产色啪| 免费黄色网址大全 | 国产无遮挡又黄又爽在线观看 | 国产一区国产二区在线观看 | 久久精品亚洲国产 | 国产码电影| 亚洲精品a区 | 国产网红在线观看 | 97手机电影网 | 国内精品久久久 | 亚洲一区网 | 三级黄色大片在线观看 | www.色午夜.com| 亚洲精品mv在线观看 | 国产资源站 | 日韩精品一区二区三区三炮视频 | 超碰在线最新网址 | 女人魂免费观看 | 91精品欧美一区二区三区 | h动漫中文字幕 | 欧美日本中文字幕 | av中文字幕在线看 | av大片网站| 亚洲国产wwwccc36天堂 | 奇米影视777四色米奇影院 | 色网站在线观看 | 久久精品视频网 | 欧美日本高清视频 | 永久中文字幕 | 成人免费在线播放视频 | 久久精品—区二区三区 | 一区二区三区四区五区在线 | 伊人天天综合 | 免费在线观看成年人视频 | 亚洲成人国产精品 | 欧美一区二区三区激情视频 | 日韩av看片 | 黄色在线小网站 | 亚洲国产欧美一区二区三区丁香婷 | 精品国产1区2区 | 日韩av在线影视 | 一本一本久久a久久 | 91免费版在线 | 欧洲性视频 | 九九涩涩av台湾日本热热 | 日日操夜 | 亚洲精品a区 | 91在线一区 | 欧美成人黄| 黄av免费在线观看 | 国产一区高清在线 | 中文一区二区三区在线观看 | 国产综合在线观看视频 | 亚洲专区 国产精品 | 国产精品专区在线观看 | 蜜臀一区二区三区精品免费视频 | 天天操伊人 | 精品国产一区二区三区四区vr | 亚洲人成综合 | 中文字幕免费高 | 伊人午夜视频 | 在线免费色 | 久久久久久久久久久久久影院 | 中文国产成人精品久久一 | 天天干国产 | 在线中文字幕av观看 | 狠狠色香婷婷久久亚洲精品 | 成人在线免费观看网站 | 丰满少妇在线观看 | 欧美一区免费在线观看 | 久久大视频| 99 色| 亚洲春色综合另类校园电影 | 一区二区精品国产 | 免费成人黄色av | 午夜精品视频在线 | 亚洲黄色免费电影 | 欧美日性视频 | 国产日韩欧美网站 | 中国一级片视频 | 91视频91自拍 | 91亚洲成人| 国产精品国产三级国产专区53 | 在线观看一级视频 | 国产精品嫩草影视久久久 | 国际精品久久 |