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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

c++判断二叉树是否为二叉搜索树_原创 | 好端端的数据结构,为什么叫它SB树呢?...

發布時間:2023/12/3 c/c++ 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c++判断二叉树是否为二叉搜索树_原创 | 好端端的数据结构,为什么叫它SB树呢?... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方藍字,關注并星標,和我一起學技術。

大家好,今天給大家介紹一個很厲害的數據結構,它的名字就很厲害,叫SB樹,業內大佬往往叫做傻叉樹。這個真不是我框你們,而是它的英文縮寫就叫SBT。

SBT其實是英文Size balanced tree的縮寫,翻譯過來可以理解成節點平衡樹,這是大牛陳啟峰在高中參加算法競賽時期發明的數據結構。不得不說大牛實在是大牛,在高中的時候就已經難以望其項背了。

二叉搜索樹

SBT本質上是一棵二叉搜索樹,我們之前介紹過二叉搜索樹,但是從來沒有真正實現過。我們今天先來復習一下二叉搜索樹的概念。

對于一棵二叉樹而言,如果它滿足對于每一個節點都有,以它右孩子構成的右子樹中的所有元素大于它,左孩子為根構成的左子樹所有元素都小于它,那么這樣一棵二叉樹就可以被認為是一棵二叉搜索樹。比如下圖,就是一棵經典的二叉搜索樹。

二叉搜索樹有什么好處呢?我們觀察一下上圖,其實很容易發現,當我們想要查找某個元素是否存在于二叉樹當中的時候,我們可以利用剛才提到的性質進行快速地查找。比如我們想要判斷15這個元素在不在樹當中,我們首先和根節點的11進行判斷,由于15大于11,如果15存在一定在11的右子樹。所以我們移動到它的右子樹16上,繼續判斷。由于15小于16,所以15要存在一定在它的左子樹當中,以此類推,我們只需要經過最多4次比較,就可以找到15。

對于一棵二叉樹而言,如果它是完美二叉樹,每一層的元素都是滿的。我們假設它的層數是k,那么它一共可以存放個元素。反過來說,如果一個完美二叉樹當中存在n個元素,那么它的層數應該是。換句話說,我們只需要次操作就可以判斷元素是否存在

但是這是完美的情況,大多數情況下普通方法構建出來的二叉搜索樹并不是完美的,其中可能存在傾斜。在極端情況下,甚至可以蛻化成鏈表。比如這樣:

正因為如此,所以我們才需要設置一些機制來保證二叉搜索樹的平衡性。平衡性有了,二叉搜索樹的查找效率才能得到保障。

關于讓二叉樹維持平衡的方法,現在有很多種,比如大名鼎鼎的紅黑樹、AVL樹等等,其實本質上都是二叉搜索樹。只是它們維護二叉樹平衡性的方法不同。今天我們介紹的SBT同樣也是一種自平衡二叉搜索樹的實現方法,它的核心機制是旋轉。

旋轉

旋轉是二叉搜索樹維持平衡的常用機制,說是旋轉,其實可以理解成樹上的某些節點之間互換位置。當然位置不能隨意更換,我們必須要保證更換位置之后不會破壞二叉搜索樹的特性,同時讓二叉樹整體更加趨向于平衡。

旋轉分為兩種,一種是左旋,另外一種是右旋。我們一個一個來介紹。

左旋

左旋可以理解成逆時針旋轉,我們來看一個例子:

是不是看著有點蒙,不知道這個旋轉怎么實現的?這里我有一個方法,我們可以想象一下,我們把左邊的二叉樹以B為軸逆時針旋轉90度,之后得到的結果是這樣:

我們可以發現B節點擁有三個孩子節點了,這顯然就違反了二叉樹的規則。那么我們就需要斷掉它的一個孩子,重新分配。那么為什么重新分配是把E分配給D而不是把C分配給E或者是D呢?

首先我們觀察一下就知道,C子樹的元素都是比B要大的,那么把它分配給D顯然不合適。對于把C分配給E,看起來似乎沒有問題,但其實仔細想下也會發現不妥。不妥的原因在哪里?不妥的地方在于我們不知道E節點的情況,如果E沒有右子樹還好,如果E存在右子樹,那么怎么處理?

所以我們只有一種解法,就是把E分配給D做右子樹,因為D原先的右子樹是B,旋轉之后一定就不存在右子樹了。

我們試著寫出偽代碼:

def?left_rotate(u):
????ur?=?u.right
????u.right?=?ur.left
????ur.left?=?u
????u?=?ur

看起來旋轉一通操作猛如虎,但是寫成代碼也就這么幾行。

右旋

左旋理解了,右旋也就好辦了,實際上右旋就是左旋的逆操作。左旋剛才是逆時針的旋轉,那么右旋自然就是順時針的旋轉。這個不需要死記,你只需要記住是向左旋轉或者是向右旋轉就可以了。

對于這樣一棵子樹我們要進行右旋:

之前左旋的時候我們是以右孩子作為旋轉軸,那么右旋自然就要以左孩子作為旋轉軸了。旋轉90度之后,我們得到了這樣的結果:

同樣我們發現A節點的孩子數量超過了限制,我們需要斷開重連。根據剛才一樣的判斷方法,我們可以發現只有一種重連的方式,就是把C節點作為D的左孩子。因為D的左孩子原本是A,由于旋轉,D沒有左孩子了,這樣連接一定不會引起沖突和問題。最終,我們得到的結果就是:

同樣,我們可以寫出偽代碼:

def?right_rotate(u):
????ul?=?u.left
????u.left?=?ul.right
????ul.right?=?u
????u?=?ul

旋轉很好理解,但是我們為什么要旋轉呢?我們觀察一下會發現旋轉最重要的功能就是改變了一些節點的位置,這樣可以扭轉一些不平衡的情況。

比如在右旋之前,可能E或者C子樹當中元素過多,引發了不平衡。當我們旋轉之后,我們把E和C分別放到了樹的兩邊。這樣旋轉之后的樹距離平衡也就更接近了一些,但是如何嚴格地保證完全達到完美平衡呢?這里就需要引入本數據結構的核心概念——size balance了。

Size Balance

前面我們也說過了,實現二叉樹平衡的方法有很多,同樣定義一棵二叉樹是否平衡的標準也有很多。比如在AVL樹當中是通過左右兩棵子樹的樹深來判斷的,兩邊的樹深差不超過1,那么就認為是平衡了。而在SBT當中,我們對二叉樹平衡的定義是基于節點數量的,也就是Size。

這里呢,我們需要定義一下size的概念,對于樹上某個節點而言,它的size指的是以它為樹根的子樹當中節點的數量。接下來,我們就要結合size來討論平衡樹不平衡的情況以及我們讓它變得平衡能夠使用的辦法。

首先,我們先來看看我們認為平衡樹達到平衡的條件。這里呢我們一共有兩個條件,這兩個條件都是對稱的。我們先來看下一個一般意義上的平衡樹。

我們觀察一下上面的圖,來思考一下,什么情況下可以認為這棵樹達成平衡了呢?是L.size == R.size嗎?這其實是有問題的,因為可能L的節點都落在了A上,R的節點都落在了C上。這同樣是不平衡的,但這種情況除非我們繼續往下遞歸,否則很難識別。

所以這里換了一種方法,我們判斷R和AB的size的關系,以及L和CD size的關系。我們要求L.size >= C.size, D.size, R.size >= A.size, B.size。

也就是說高層的size一定要比底層來的大,這兩個條件都很直觀,也都很好記。這兩個條件理解了,我們再去分析它不平衡的條件就很清楚了。一共有四種情況:

  • Size of A > size of R

  • Size of B > size of R

  • Size of C > size of L

  • Size of D > size of L

  • 在這4種情況當中,1和3是對稱的,2和4也是對稱的。所以我們只需要著重分析其中兩種就可以了,另外兩種可以通過對稱性得到。

    由于我們使用遞歸來維護樹的平衡性的時候,是從底往上的。因此我們可以假設ABCDLR這六棵子樹都是平衡的,這樣可以簡化我們的分析。我們假設我們現在有了一個函數叫做maintain,它可以將一棵不平衡的子樹旋轉到平衡狀態。我們先假設已經有了這個函數,再去看看它里面需要實現哪些邏輯。

    接下來我們來看看上面四種情況如果不滿足的話,我們應該怎么處理。

    情況1

    情況1當中A.size > R.size,也就是A當中的節點比較多,為了能夠趨近于平衡。我們將原子樹右旋,得到:

    我們右旋之后,A的層級向上提升了一層。我們觀察一下旋轉之后的結果,會發現R子樹的平衡性得到了保持,沒有被破壞,A子樹本身就是平衡的。所以旋轉之后,還有還有兩個節點的平衡性沒有保證。一個是T節點,一個是L節點。那么,我們遞歸調用maintain(T)和maintain(L)即可。

    我們寫成偽代碼就是:

    right_rotate(T)
    maintain(T)
    maintain(L)

    情況2

    下面我們來看情況2,也就是B.size > R.size的情況。和上面一種情況類似,由于B的節點比較多,我們希望能夠把B往上提。但是B節點在內部,我們無論對L左旋還是右旋都

    既然對T旋轉不行,那么我們可以對L進行旋轉啊,這樣不就可以影響到B節點了嗎?為了展示地更加清楚,我們把B子樹的孩子節點也畫出來。

    接著我們對L進行左旋,這樣可以把B往上提升一層,得到:

    雖然我們把B往上提了一層,但是對于T子樹而言,左重右輕的局面仍然沒有改變。要想改變T的不平衡,我們還需要對T進行右旋,得到:

    對于這個結果而言,除了L、T和B這三棵樹而言,其他所有的子樹都滿足平衡了。所以我們按順序維護L、T和B即可。

    我們寫成代碼就是:

    left_rotate(L)
    right_rotate(T)
    maintain(L)
    maintain(T)
    maintain(B)

    情況3和情況1剛好相反,我們把左旋和右旋互換即可,情況4和情況2也一樣。

    所以我們可以寫出所有的情況來了:

    def?maintain(t):
    ????if?t.left.left.size?>?t.right.size:
    ????????right_rotate(t)
    ????????maintain(t.right)
    ????????maintain(t)
    ????elif?t.left.right.size?>?t.right.size:
    ????????left_rotate(t.left)
    ????????right_rotate(t)
    ????????maintain(t.left)
    ????????maintain(t.right)
    ????????maintain(t)
    ????elif?t.right.right.size?>?t.left.size:
    ????????left_rotate(t)
    ????????maintain(t.left)
    ????????maintain(t)
    ????else:
    ????????right_rotate(t.right)
    ????????left_rotate(t)
    ????????maintain(t.left)
    ????????maintain(t.right)
    ????????maintain(t)????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????

    這里的四種情況羅列出來當然就可以,但是有很多代碼重復了,我們可以設置一個flag標記,表示我們判斷的是左子樹還是右子樹。這樣我們可以把一些情況歸并在一起,讓代碼顯得更加簡潔:

    def?maintain(t,?flag):
    ????if?flag:
    ????????if?t.left.left.size?>?s.right.size:
    ????????????right_rotate(t)
    ????????elif?s.left.right.size?>?t.right.size:
    ????????????left_rotate(t.left)
    ????????????right_rotate(t)
    ????????else:
    ????????????return
    ????else:
    ????????if?t.right.right.size?>?t.left.size:
    ?????????left_rotate(t)
    ?????elif?t.right.left.size?>?t.left.size:
    ?????????right_rotate(t.right)
    ????????????left_rotate(t)
    ????????else:
    ????????????return
    ????maintain(t.left,?False)
    ????maintain(t.right,?True)
    ????maintain(t,?False)
    ????maintain(t,?True)????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????

    這里其實我們省略了maintain(t.left, True)和maintain(t.right, False)這兩種情況,這兩種情況我們稍微分析一下會發現其實已經被包含了。

    我們搞清楚了這些之后,還有一個疑問沒有解開,就是為什么旋轉操作可以讓二叉樹趨向于平衡呢,而不是無窮無盡地旋轉下去呢?

    盡管我們已經知道了不會,但是還是想要來證明一下。我們以情況一舉例,我們右旋之后的結果是:

    我們對比一下旋轉之前的結果,會發現T、R、C、D的高度增加1,而L和A的高度減小了1。由于A.size > R.size,A的size最小等于R.size + 1,也就剛好是T加上R子樹的size。這兩個部分一增一減互相抵消之后,至少還有L這個節點的深度減小了1。也就是說旋轉之后的所有元素的深度和是在減小的,不僅是情況1如此,其他的情況也是一樣。

    既然深度和是在減小的,那么maintain這個操作就一定不是無限的。并且它也的確可以讓樹趨向于穩定,因為完美平衡的情況下所有元素的深度和才是最小的。

    實現細節

    到這里我們就已經把SBT的原理都講解完了,但是還存在一些細節上的問題。由于我們是使用Python是引用語言,所以當我們在旋轉的時候進行賦值只是指針之間改變了引用的目標, 并沒有實際對原本的結構進行改變。

    我們來看下剛才上面的偽代碼:

    def?right_rotate(u):
    ????ul?=?u.left
    ????u.left?=?ul.right
    ????ul.right?=?u
    ????u?=?ul

    由于我們把u的左孩子右旋,代替了u本來的位置。當我們執行u = ul的時候,只是u這個指針改變了指向的位置。至于原本的數據結構當中的內容,并沒有發生變化。因為u、ul這些變量都是臨時變量,都是拷貝出來的,我們隨便更改,也不會影響類當中的值。

    在C++當中我們可以傳入引用,這樣我們修改引用就是修改原值了。但是Python當中不行,想要解決這個問題,只有一種方法,就是對于每個節點我們都記錄它父節點的位置。當我們旋轉完了之后,我們需要去更新它父節點中儲存的孩子節點的地址,這樣的話,我們就不只是局部變量之間互相修改了,就真正落實到了數據結構上了。

    我們以右旋為例:

    ????def?reset_child(self,?node,?child,?left_or_right='left'):
    ????????"""
    ????????Since?Python?pass?instance?by?reference,?in?order?to?rotate?the?node?in?tree,?we?need?to?reset?the?child?of?father?node
    ????????Otherwise?the?modify?won't?be?effective
    ????????"""
    ????????if?node?is?None:
    ????????????self.root?=?child
    ????????????self.root.father?=?None
    ????????????return?
    ????????if?left_or_right?==?'left':
    ????????????node.lchild?=?child
    ????????else:
    ????????????node.rchild?=?child
    ????????if?child?is?not?None:
    ????????????child.father?=?node

    ?def?rotate_right(self,?node,?left_or_right='left'):
    ????????"""
    ????????Right?rotate?operation?of?Treap.
    ????????Example:?
    ????????????????D
    ??????????????/???\
    ?????????????A?????B
    ????????????/?\
    ???????????E???C
    ????????After?rotate:
    ????????????????A
    ???????????????/?\
    ??????????????E???D
    ?????????????????/?\
    ????????????????C???B?
    ????????"""
    ????????father?=?node.father
    ????????lchild?=?node.lchild
    ????????node.lchild?=?lchild.rchild
    ????????if?lchild.rchild?is?not?None:
    ????????????lchild.rchild.father?=?node
    ????????lchild.rchild?=?node
    ????????node.father?=?lchild
    ????????#?要重新reset父節點的孩子節點,這樣整個改動才是真的生效了。
    ????????self.reset_child(father,?lchild,?left_or_right)
    ????????#?更新節點買的size
    ????????node.size?=?node_size(node.lchild)?+?node_size(node.rchild)?+?1
    ????????lchild.size?=?node_size(lchild.lchild)?+?node_size(lchild.rchild)?+?1
    ????????return?lchild

    由于每個節點的孩子節點有兩個,所以我們還需要一個變量來記錄我們當前要改變的節點究竟是它父親節點的左孩子還是右孩子,這樣我們才能在reset的時候正確地修改。不僅是旋轉如此,刪除和添加也是一樣的,我們都需要修改父節點當中的信息,否則我們修改來修改去,改的都只是局部變量而已。

    另外一點是我們旋轉之后還需要更新每個節點的size,這個邏輯如果忘記了,那么后面的maintain就無從談起了。

    最后我們思考一個問題,我們在什么情況下需要maintain操作呢,也就是什么情況下會破壞樹的平衡性呢?其實很簡單,就是當樹中的元素數量發生改變的時候。無論是增多或者是減少都有可能破壞樹的平衡。所以我們在完成了插入和刪除之后都需要maintain一次樹的平衡。

    論文當中對于maintain這個操作還有詳細的分析,可以證明maintain的均攤復雜度是,也就是常數級的操作,這也是為什么SBT運行效率高的原因。

    論文的最后還附上了SBT和其他常用平衡樹數據結構的比較,我們可以看出SBT無論是運行效率還是質量都是其中佼佼者。

    最后,我們聊一聊SBT的實現。關于SBT這類復雜數據結構的實現還是C++要更方便一些,主要原因就是因為C++當中帶有引用和指針的傳遞操作。我們可以在函數內部修改全局的值,而Python當中則不行。參數傳遞默認傳遞的是拷貝,我們在函數內部賦值并不會影響結果。所以如果使用Python實現會更加復雜一些,并且需要一些修改父節點的額外操作。

    因此網上關于SBT的Python實現非常非常少,我有自信說我的代碼目前是我能找到的實現得比較好的一個。相關代碼很長,足足有五百多行,不適合放在文章當中。如果大家感興趣,可以在公眾號內回復SBT關鍵字進行獲取。

    今天的文章就到這里,衷心祝愿大家每天都有所收獲。如果還喜歡今天的內容的話,請來一個三連支持吧~(點贊、在看、轉發)

    - END -

    總結

    以上是生活随笔為你收集整理的c++判断二叉树是否为二叉搜索树_原创 | 好端端的数据结构,为什么叫它SB树呢?...的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    日韩电影中文,亚洲精品乱码 | 中文字幕超清在线免费 | 国产在线p | 亚洲精品国偷自产在线91正片 | 在线观看91av | 九色91在线视频 | 欧美日韩国产综合一区二区 | 亚洲精品视频大全 | 精品视频免费久久久看 | 成人免费观看在线视频 | 国产一级淫片在线观看 | 日韩理论视频 | 99免费在线视频 | 日韩理论片 | 激情综合色综合久久综合 | 国产成人亚洲在线观看 | 精品亚洲免费视频 | 四虎国产精品免费 | 婷婷丁香av| 一本一本久久a久久精品牛牛影视 | 国内三级在线 | 一区二区三区四区五区在线 | 日韩精品久久久久久久电影99爱 | 日韩3区| 亚洲电影图片小说 | 日韩中文三级 | 99久久www | 久久久久国产一区二区 | 亚洲精品在线视频观看 | 美女在线国产 | 久久视频精品在线观看 | 91久久久久久国产精品 | 黄色一级大片免费看 | 免费人成在线观看网站 | 中文字幕永久 | 国产精品你懂的在线观看 | 中文字幕有码在线观看 | 毛片在线播放网址 | 97人人澡人人添人人爽超碰 | av片子在线观看 | 人人超在线公开视频 | 91精品视频一区二区三区 | 91丨九色丨国产在线 | 日韩欧美在线观看一区二区三区 | 狠狠干婷婷色 | 丁香久久久| 香蕉影视| 日韩精品一区二 | 国产伦精品一区二区三区无广告 | 日本黄色免费电影网站 | 在线免费观看av网站 | 五月婷婷黄色 | 精品三级av | 久久久久国产精品午夜一区 | 国产精品视频永久免费播放 | 激情久久久久久久久久久久久久久久 | 欧美日韩国产在线观看 | 婷婷性综合 | 色婷婷激情五月 | 综合av在线 | 欧美激情综合五月 | 亚洲成年片 | 黄在线免费观看 | 99热官网| 九九三级毛片 | 日韩激情精品 | 综合网成人 | 在线看成人 | 97免费视频在线 | 欧美久久综合 | 中日韩免费视频 | 天天操天天干天天 | 精品国产成人av在线免 | 国产一区二区精品91 | 99视频国产精品 | 国产一级片在线播放 | 欧美大片在线看免费观看 | 久久久久高清毛片一级 | 香蕉影视app | 91精品人成在线观看 | 婷婷综合在线 | 久草免费在线观看视频 | 日本性生活一级片 | 亚洲闷骚少妇在线观看网站 | 黄色小说视频网站 | 中日韩三级视频 | 精品视频久久 | 蜜桃视频成人在线观看 | 国产精品久久久一区二区三区网站 | 在线观看aaa | 91av精品| 国产一级在线 | 国产高清av| 天天艹天天操 | 久久综合久久久 | 2023av在线 | 97精品国产一二三产区 | 国产视频一区二区在线观看 | 91午夜精品 | 开心激情网五月天 | 精品一区二区在线免费观看 | 亚洲第一色| 亚洲午夜久久久久 | 99视频+国产日韩欧美 | www夜夜操 | 久久999久久 | 99久久综合精品五月天 | 欧美日韩一区二区在线 | 日韩欧在线 | 亚州av网站大全 | 91成品人影院 | 亚洲春色奇米影视 | 久久久久久精 | 一区二区三区四区精品视频 | 国产在线一卡 | 国产精品美女久久久久久免费 | 亚洲欧洲一级 | 18女毛片| 91精品国产福利在线观看 | 激情视频在线高清看 | 国产精品女 | 国内精品久久久久久久久久久久 | av网站在线免费观看 | 亚洲精品xxx | 久久国产手机看片 | 成年人黄色av | 91av原创 | 成人免费观看完整版电影 | 欧美精品在线免费 | 免费看高清毛片 | 色婷婷综合久色 | 久久免费大片 | 亚洲成人中文在线 | 18久久久久 | 九九久久婷婷 | 日韩精品一区二区在线 | 热re99久久精品国产66热 | 日本丶国产丶欧美色综合 | 九九色视频| 免费观看国产精品视频 | 最近更新中文字幕 | 中文在线免费视频 | 亚洲日本欧美在线 | 91在线精品秘密一区二区 | 美女视频永久黄网站免费观看国产 | 正在播放久久 | 嫩草伊人久久精品少妇av | 久久婷婷一区二区三区 | 91成人在线视频 | 黄色三级在线观看 | 久久精品视 | 久久久精品国产免费观看同学 | 亚洲精品乱码久久久久久写真 | 制服丝袜亚洲 | 99色视频在线 | 青青河边草手机免费 | 97超碰国产精品女人人人爽 | 视频成人免费 | 91综合久久一区二区 | 在线观看免费国产小视频 | 九九热视频在线 | 日韩av片免费在线观看 | 亚洲精品在线观 | 国产福利在线免费观看 | 欧美精品在线观看一区 | 久久综合五月婷婷 | 在线成人av | 国产精品成人免费一区久久羞羞 | 成人黄色av免费在线观看 | 国产在线观看你懂得 | 久久色网站 | 亚洲精品在线观看视频 | 欧美综合久久 | www四虎影院 | 九九日九九操 | 国产成人精品av久久 | 视频成人永久免费视频 | 五月婷婷一区二区三区 | 日本公妇在线观看高清 | 免费在线观看黄 | 91成版人在线观看入口 | 夜夜夜夜爽 | 久久男人中文字幕资源站 | 亚洲好视频 | 在线观看视频99 | 免费看av在线 | 亚洲aⅴ免费在线观看 | 国产一级不卡毛片 | 全久久久久久久久久久电影 | 黄色三级免费 | 国产亚洲小视频 | av免费在线观看1 | 亚洲激情校园春色 | 免费高清男女打扑克视频 | 欧美性色网站 | 99久久99视频只有精品 | 久久资源总站 | 中文乱码视频在线观看 | 成人午夜电影免费在线观看 | 伊人视频 | 99精品视频免费看 | 中文在线最新版天堂 | 国产高清精 | 免费观看的黄色 | 国产精品高 | 国产成人在线观看 | 成人av片免费观看app下载 | 免费看精品久久片 | 青青河边草免费观看 | 日日碰狠狠躁久久躁综合网 | 日本精品一区二区三区在线观看 | 狠狠久久综合 | 日韩欧美黄色网址 | 国产在线观看一 | 国产成人综合图片 | 毛片网免费 | 在线观看久草 | 在线观看午夜 | 国产精品一区二区三区视频免费 | a级国产乱理论片在线观看 伊人宗合网 | 超碰在线人人爱 | 高清av免费观看 | 99国产精品久久久久久久久久 | 高清中文字幕av | 色综合小说 | 在线看片一区 | 欧美日韩免费观看一区二区三区 | 国产探花 | 国产视频精品久久 | 91精品国产亚洲 | 欧美一二区视频 | 国产一区二区三区在线免费观看 | 日韩欧美精品一区二区 | 麻豆传媒电影在线观看 | 999视频网站 | 色婷婷丁香 | 日日爽夜夜爽 | av.com在线 | 最近中文字幕久久 | 91精品国| 国产网红在线 | 天天爽夜夜操 | 国语黄色片| 91av官网 | 久久婷亚洲五月一区天天躁 | 激情欧美在线观看 | 在线日韩av | 久久色视频 | 丁香影院在线 | 99精品视频在线播放免费 | 91麻豆网 | 97日日 | 日韩欧美在线国产 | 久久最新视频 | 人人插人人看 | 久草免费在线视频观看 | 久久久免费 | 人人超在线公开视频 | 久久tv| 依人成人综合网 | 中文字幕免费观看全部电影 | 国产精品久久久久久爽爽爽 | 91色视频| 青青草在久久免费久久免费 | av日韩不卡 | 日韩av资源站 | 正在播放国产一区二区 | 久久综合久久久 | 人成午夜视频 | 最新真实国产在线视频 | 欧美精品在线观看免费 | 国产黄免费在线观看 | 在线观看黄网站 | 成人免费视频视频在线观看 免费 | 中文字幕在线观看免费 | 伊人干综合 | 亚洲最大成人免费网站 | 97超碰站 | 欧美 亚洲 另类 激情 另类 | 久久激情视频网 | av资源在线观看 | 欧美韩日在线 | 国产首页| 人人干网站 | 日本高清久久久 | 麻豆国产精品va在线观看不卡 | 日韩国产高清在线 | 成人黄色av免费在线观看 | 美女黄久久 | 久草免费新视频 | 国产网站在线免费观看 | 久热久草在线 | 91网址在线观看 | av电影中文字幕在线观看 | 天天综合区 | 精品视频9999 | 久久精品五月 | 国产在线高清 | 国产理论在线 | 久久99欧美 | 免费看的黄色的网站 | 国产视频日韩视频欧美视频 | 日韩一级黄色片 | 欧美日韩后 | 全黄色一级片 | 国产精品videossex国产高清 | 亚洲三级性片 | 在线中文字幕视频 | 人人草在线视频 | 国产成人在线免费观看 | 99久久久久久久久久 | 波多野结衣在线视频一区 | 9ⅰ精品久久久久久久久中文字幕 | 亚洲国产中文在线观看 | 久久久婷 | 成人aⅴ视频 | 在线视频 精品 | 丁香婷婷久久 | 亚洲精品色婷婷 | japanesexxxhd奶水| 成在线播放 | 在线午夜电影神马影院 | 很黄很色很污的网站 | 欧美日韩高清一区二区 | 国产精品免费久久久久久 | 久久久久亚洲精品成人网小说 | 亚洲精品男人的天堂 | 中文字幕 在线 一 二 | 国产视频高清 | 日本精品一区二区 | 日韩中文字幕a | 天天综合色网 | 丁香婷婷综合网 | 91成版人在线观看入口 | 色综合久久久久久久久五月 | 超碰av在线免费观看 | 欧美激情xxxx| 综合久久久 | 九九久久影视 | 九九九九九九精品 | 500部大龄熟乱视频使用方法 | 久久一区二区三区超碰国产精品 | 成人在线一区二区三区 | 久久99久久99精品免费看小说 | 亚洲精品在线免费看 | 午夜视频在线观看一区二区三区 | 国产免费精彩视频 | 狠狠色丁香婷综合久久 | 国产黄网在线 | 久久久国产网站 | 99视频在线精品免费观看2 | 欧美日韩国产免费视频 | 亚洲人成人99网站 | 18pao国产成视频永久免费 | 欧美精品亚洲精品 | 久久午夜影院 | 综合精品久久久 | 成人网在线免费视频 | 国产精品美女久久久久久久久 | 天天爽人人爽夜夜爽 | 日韩在线免费高清视频 | 色在线免费 | 色九九影院 | 亚洲欧美在线观看视频 | 亚洲人成免费 | 天天躁日日躁狠狠躁 | 日韩在线观看视频在线 | 亚洲精品av中文字幕在线在线 | 亚洲激情网站免费观看 | 日韩丝袜在线观看 | 久久国产精品99久久久久 | 亚洲精品乱码久久久久久久久久 | 日韩欧美视频免费在线观看 | 一区二区三区电影 | 四虎影院在线观看av | 狠狠色丁香久久婷婷综合五月 | 亚洲午夜精品福利 | 亚洲精品美女视频 | 久久人人精 | 亚洲成人黄 | 久久久久久毛片精品免费不卡 | 欧美激情片在线观看 | 色婷婷av国产精品 | 亚洲精品一区二区三区在线观看 | 欧美大片www| 99免费看片| 国产91aaa| av免费在线观看网站 | 91看片成人 | 久久五月情影视 | 久久特级毛片 | 在线看不卡av | 日韩视频欧美视频 | 成人中文字幕+乱码+中文字幕 | 亚洲成年人在线播放 | 在线观看国产一区 | 日日日爽爽爽 | 亚洲天堂香蕉 | 婷婷久久一区二区三区 | 久久久久亚洲最大xxxx | 日韩av免费观看网站 | 午夜婷婷网| 日韩欧美视频在线观看免费 | 在线一二三四区 | 特黄一级毛片 | 69av视频在线观看 | 亚洲一级片免费观看 | 亚洲午夜久久久综合37日本 | 日本免费一二三区 | 97超碰人人澡人人爱学生 | 韩国在线视频一区 | 成人久久影院 | 五月婷婷久草 | 黄色1级毛片| 国产免费av一区二区三区 | 日韩专区一区二区 | 一区二区三区电影 | 玖玖视频 | 日韩视频 一区 | 国产 在线 高清 精品 | 天天干 天天摸 天天操 | 亚洲理论电影 | 国产手机免费视频 | 婷婷国产v亚洲v欧美久久 | 国内精品视频一区二区三区八戒 | 五月丁婷婷 | 免费视频黄 | 99欧美视频 | 精品超碰 | 美女免费视频观看网站 | 999视频网 | 人人舔人人插 | 日韩有码专区 | avcom在线| 中文字幕在线人 | 日韩在线 一区二区 | 日韩av免费一区 | 亚洲综合少妇 | 欧美在线一二 | 国产在线观看网站 | 国产区av在线 | 色综合久久久久综合99 | 午夜精品久久久久久久久久久久 | 日本中文字幕电影在线免费观看 | 久草爱 | 丁香婷婷激情 | 欧美一级免费片 | 麻豆视频一区 | 国产成人精品aaa | 亚洲视频电影在线 | av在线不卡观看 | 久久99九九99精品 | 日日夜色 | 午夜av色| 一区二区精 | 日韩精品一区二区三区在线视频 | 久久8| 正在播放国产一区二区 | 五月激情丁香图片 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 亚洲专区中文字幕 | 99热播精品| 丰满少妇在线 | 国产麻豆视频免费观看 | 国产精品女视频 | 国产精品一区二区久久精品爱涩 | 极品美女被弄高潮视频网站 | 手机av在线免费观看 | 国产精品免费久久久久影院仙踪林 | 亚洲精品免费在线播放 | 日韩精品在线看 | 娇妻呻吟一区二区三区 | 一区av在线播放 | 日韩av中文字幕在线免费观看 | 亚洲综合婷婷 | 五月花婷婷 | 国产另类xxxxhd高清 | 在线观看免费视频 | 国产区精品在线观看 | 久久国产精品一区二区 | 久久不卡国产精品一区二区 | av黄色国产| 97精品视频在线播放 | 亚洲精品88欧美一区二区 | 国产精品18久久久久久首页狼 | 亚洲精品国偷拍自产在线观看 | 亚洲视频一区二区三区在线观看 | 超级碰视频 | 九九九热 | 国产精品18毛片一区二区 | 中文字幕一区二区三区在线视频 | 久久爱导航 | 精品黄色视| 婷婷六月天丁香 | 国产亚洲激情视频在线 | 91色在线观看视频 | 久久久久国产一区二区三区四区 | 丁香 久久 综合 | 亚洲免费视频在线观看 | 一级黄色片在线 | 国产精品久久久久影院 | 美女福利视频在线 | 在线精品亚洲一区二区 | 五月综合激情婷婷 | a天堂一码二码专区 | 国产一区视频在线观看免费 | 玖玖视频国产 | 日韩中文字幕在线看 | 色播五月激情综合网 | 欧美日韩免费一区二区 | 9999在线观看 | 91激情视频在线 | 婷婷去俺也去六月色 | 国产一级淫片在线观看 | 亚洲专区 国产精品 | av在线等 | 日本特黄一级 | 91成人精品国产刺激国语对白 | 久久国产精品偷 | av电影一区| 亚洲第一色 | 久久精品免视看 | 一区二区三区电影在线播 | 免费欧美高清视频 | 91视视频在线直接观看在线看网页在线看 | 国产精华国产精品 | 精品99在线视频 | 中文一区二区三区在线观看 | 91视频亚洲 | 日本女人在线观看 | 国产精品第二十页 | 九九精品视频在线看 | 国产成人精品av在线观 | 欧美日韩a视频 | 成年人免费看片 | 国产精品嫩草影院123 | 国产又粗又猛又爽 | 久久精品中文字幕一区二区三区 | 日韩成人在线免费观看 | 人人爱人人做人人爽 | 最新黄色av网址 | 国产91亚洲精品 | 国产人成免费视频 | 91丨九色丨勾搭 | 久久久久久久久久久综合 | 黄网站色欧美视频 | 国产精品国产三级在线专区 | 欧洲激情在线 | 狠狠的干| 日韩欧美区 | 中文字幕a∨在线乱码免费看 | 欧美日本高清视频 | 欧美日韩一区二区视频在线观看 | 蜜桃传媒一区二区 | 欧美日韩网址 | av观看网站 | 国产专区一 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 欧日韩在线视频 | 天天干天天操天天入 | 97成人精品视频在线观看 | 日韩精品欧美专区 | 国产成人精品久 | 五月天视频网站 | 韩国av不卡 | 天天av综合网 | 欧美日韩久久一区 | 国产一级片一区二区三区 | 在线观看成年人 | 国产高清av免费在线观看 | 波多野结衣在线视频一区 | 热久久免费国产视频 | www.狠狠| 99国产视频在线 | 久久久免费观看完整版 | 久久av高清 | 成人黄在线观看 | 在线观看精品国产 | 激情欧美在线观看 | a级国产乱理伦片在线观看 亚洲3级 | 天天射日 | 在线视频 91 | 在线免费观看黄色小说 | 看全黄大色黄大片 | 黄色亚洲大片免费在线观看 | 日韩精品91偷拍在线观看 | 久久久久北条麻妃免费看 | 岛国av在线不卡 | 91视频免费国产 | 国产精品福利在线观看 | 在线观看日韩av | 久久免费99 | 久草在线久草在线2 | 久久调教视频 | 日韩字幕 | 久久综合久久综合久久综合 | av不卡在线看 | 中文字幕视频免费观看 | 在线看国产一区 | 91社区国产高清 | 久久精彩免费视频 | 在线国产日本 | a级国产毛片 | 精品国产成人 | 色婷婷97 | 亚州精品天堂中文字幕 | 亚洲精品在线二区 | 激情黄色一级片 | 九九在线视频免费观看 | 久久久综合九色合综国产精品 | 天天弄天天干 | 国色天香永久免费 | 亚欧日韩成人h片 | 久久精品伊人 | 久久久久国产精品厨房 | av在线免费不卡 | 久久综合久色欧美综合狠狠 | 九九视频这里只有精品 | 日日夜夜骑 | 久久精品99久久 | 日韩av一区二区三区四区 | 亚洲精品久久久久中文字幕m男 | 五月婷婷在线播放 | 高清av免费观看 | 亚洲人成免费网站 | 欧美大片第1页 | 日日夜精品 | 中文av在线免费观看 | 亚洲成人黄色 | 欧美日韩色婷婷 | 亚洲精品在| 99久久婷婷国产一区二区三区 | 精油按摩av | 亚洲精品久久久久999中文字幕 | 欧美色精品天天在线观看视频 | 天天干天天操天天 | av色综合网 | 最近免费观看的电影完整版 | 91精品秘密在线观看 | 91精品啪在线观看国产81旧版 | 欧美午夜久久 | 91av小视频 | 美女黄网站视频免费 | 992tv又爽又黄的免费视频 | 99久热在线精品视频 | 91麻豆精品国产午夜天堂 | 免费网站色 | 欧美日韩性 | 91视频-88av| 日韩极品视频在线观看 | 毛片网站观看 | 亚洲综合色激情五月 | 日日夜夜精品视频天天综合网 | 中文区中文字幕免费看 | 久久国产免费视频 | 久久久一本精品99久久精品66 | 国产最顶级的黄色片在线免费观看 | 97色婷婷成人综合在线观看 | 视频一区二区国产 | 成在人线av| 久久午夜精品影院一区 | 亚洲欧美日韩在线一区二区 | 亚洲精品在线免费观看视频 | 少妇超碰在线 | 国产精品一区二区av日韩在线 | 国产 字幕 制服 中文 在线 | 久久天天操 | 国产亚洲aⅴaaaaaa毛片 | 最近中文字幕大全中文字幕免费 | 亚洲国内在线 | 五月天婷婷免费视频 | 久久精品亚洲国产 | 黄色av一区二区 | 视频国产在线 | 激情www| av千婊在线免费观看 | 国产黄a三级三级三级三级三级 | 亚洲精品免费在线视频 | 中文字幕一区三区 | 一区二区三区 中文字幕 | 成人在线播放网站 | 久久久久久免费毛片精品 | 亚洲国产精品va在线 | 蜜桃视频成人在线观看 | 色网免费观看 | 欧美精品在线观看一区 | 欧美日本一区 | 精品国产一区二区三区久久久 | 国产高清视频在线 | 四虎影视精品成人 | 国产一级片毛片 | 91天堂影院 | 日韩欧美一区二区三区黑寡妇 | 精品国产乱码久久久久久1区2匹 | 久久视频这里只有精品 | 日批视频| 久久久久欧美精品999 | 成人影片在线免费观看 | 91热爆视频| 在线观看视频 | 国产精品成人一区二区三区 | 久久久久久久久久久久99 | wwxxxx日本 | 正在播放 久久 | 久久久久久国产精品 | 激情在线网址 | 国产高清日韩 | 18国产精品白浆在线观看免费 | 成人a免费 | www黄免费 | 99国产精品视频免费观看一公开 | 香蕉视频啪啪 | 91亚洲在线观看 | 91传媒在线| 亚洲成av片人久久久 | 日韩精品视频在线观看免费 | 日韩精品欧美视频 | 伊人va| 亚洲午夜大片 | www黄色软件 | 日韩av中文在线观看 | 99精品国产福利在线观看免费 | 天天草夜夜 | 久久视频精品在线观看 | 成人a免费看 | 免费看片黄色 | 在线观看精品 | 欧美午夜a| 亚洲国产精品免费 | 婷婷久久久 | 天天爽天天摸 | 热久久电影 | 亚洲精品成人免费 | 日本大尺码专区mv | 国产高清免费在线观看 | 黄色三几片 | 国产成人精品亚洲日本在线观看 | 亚洲无人区小视频 | 久久久国产精品一区二区三区 | 久久草视频 | 欧美视屏一区二区 | 深夜国产在线 | www.成人sex | 激情五月婷婷综合 | 国产一区二区在线观看免费 | 蜜臀久久99精品久久久无需会员 | 成人在线一区二区三区 | 91超级碰| 成人a视频在线观看 | 婷婷六月丁 | 国产精品一区二区在线 | 黄色免费网 | 色诱亚洲精品久久久久久 | 99精品热视频 | 亚洲国产手机在线 | 亚洲精品中文字幕视频 | av大全免费在线观看 | 国产一区久久久 | 亚洲狠狠婷婷综合久久久 | 日韩美在线观看 | 天天做日日爱夜夜爽 | 久久免费福利视频 | 精品国产乱子伦一区二区 | 亚洲免费成人av电影 | 日韩精品第一区 | 91亚洲精品国偷拍 | 激情视频久久 | 国产精品免费观看视频 | 亚洲一区日韩精品 | 六月丁香婷婷久久 | 综合精品久久久 | 亚洲精品在线看 | 亚洲一级电影 | 九九九九九九精品任你躁 | 久久精品99久久 | 欧美 激情 国产 91 在线 | 国产成人精品日本亚洲999 | 一级免费av| 成年人视频在线免费观看 | 国产中文字幕大全 | 国产成人在线播放 | 日韩三级视频在线看 | 色婷婷午夜 | 久久久免费高清视频 | 狠狠干成人综合网 | 在线视频观看91 | 一级免费片 | 天天添夜夜操 | 欧美激情视频在线免费观看 | 欧美性超爽 | 成人福利在线观看 | 成年人三级网站 | 公开超碰在线 | 人人澡超碰碰 | 欧美日韩aaaa | 国产精品免费一区二区三区 | 国产精品99久久久久久小说 | 国产精品va在线观看入 | 日韩av不卡播放 | 奇米先锋| 国产在线中文 | 国产日本在线播放 | www夜夜 | 九九热视频在线播放 | 中文伊人| 超碰99人人 | 欧美综合在线视频 | 久久久免费精品国产一区二区 | 日韩在线一二三区 | 中文字幕国语官网在线视频 | 9在线观看免费 | 午夜美女av| 中文字幕在线观看完整版电影 | 狠狠干网 | 国产精品欧美 | 国产香蕉在线 | 国产成人精品一区二区在线观看 | 免费日韩一区二区 | 日韩免费在线视频 | 69av免费视频 | 亚洲国产精品成人女人久久 | 欧美综合国产 | 91av视频网 | 五月激情五月激情 | 国产精品正在播放 | 日韩美女一级片 | 亚洲精品国产精品99久久 | 日韩视频在线观看免费 | 99亚洲精品在线 | 综合国产在线观看 | av国产在线观看 | 久久久综合精品 | 国产资源站 | 亚洲精品动漫久久久久 | 99久在线精品99re8热视频 | 午夜精品av | 亚洲黄色免费 | 亚洲黄在线观看 | 国产精品自在欧美一区 | 成人av播放 | 麻豆一二三精选视频 | 精品国产电影 | 午夜视频二区 | 精品成人久久 | 久久69精品久久久久久久电影好 | 激情中文在线 | 一 级 黄 色 片免费看的 | 中文字幕乱码视频 | 丰满少妇一级片 | 九色在线| 久久精品99国产精品酒店日本 | 久久av影视 | 亚洲精品国产精品乱码在线观看 | 国内精品久久久久久中文字幕 | 久久怡红院 | 欧美国产高清 | 成 人 黄 色 视频免费播放 | 亚洲欧美一区二区三区孕妇写真 | 久久精品这里精品 | 久久一及片| 九九视频免费在线观看 | 伊人激情网 | 亚洲精品乱码白浆高清久久久久久 | 婷婷av色综合 | 91麻豆精品国产 | 国产成人一区二区三区影院在线 | 婷婷在线免费观看 | 草久在线观看 | 色五月成人 | 狠狠干天天干 | 久草在线免费色站 | 欧美成年性 | 麻花传媒mv免费观看 | 美女视频黄频大全免费 | 日韩精品一区在线观看 | 精品国产一区二区久久 | 亚洲 成人 欧美 | 999成人 | 日韩精品中文字幕久久臀 | 四虎免费在线观看视频 | 午夜av色 | 国际精品久久久 | 一区免费在线 | 黄色精品一区二区 | 日韩中文字幕91 | 狠狠色丁香婷婷综合 | 国产一级二级在线播放 | 五月视频| 91人人爽人人爽人人精88v | av黄色在线播放 | 91精品久久久久 | 日韩成人一级大片 | 久av在线| 伊人五月| 91一区啪爱嗯打偷拍欧美 | 日本久久中文字幕 | 国产黄色大全 | 亚洲精品乱码久久久久久蜜桃动漫 | av线上免费观看 | 在线观看一区二区视频 | 亚洲dvd| 免费高清看电视网站 | 美女黄色网在线播放 | 国内成人综合 | 天天干天天做天天操 | 日本中文乱码卡一卡二新区 | 亚洲高清国产视频 | 国内丰满少妇猛烈精品播 | 国产裸体视频网站 | 久久久久久久久免费视频 | 狠狠色伊人亚洲综合网站野外 | 免费91麻豆精品国产自产在线观看 | 成人av直播 | 久久人人爽爽人人爽人人片av | 精品国产视频一区 | 欧美亚洲精品一区 | 伊人久久av | 久久久久成人精品免费播放动漫 | 成人av片免费观看app下载 | 在线观看免费观看在线91 | 91在线免费播放 | 日韩午夜av | 婷婷色在线资源 | 精品国产一区二 | 色婷婷国产精品一区在线观看 | 日日爱网站| 久久婷婷五月综合色丁香 | www狠狠操| 国产1区2区 | 91九色综合 | free. 性欧美.com | 伊人狠狠操 | 久操97 | 在线免费看黄色 | 日韩精品视频在线观看免费 | 毛片无卡免费无播放器 | 97色狠狠| 狠狠干狠狠久久 | 免费在线观看黄网站 | 天天射天天 | 黄色a在线 | 亚洲日本va午夜在线影院 | 涩涩网站在线看 | 日韩中文字幕视频在线 | 日本性视频 | 97人人模人人爽人人喊中文字 | 999久久国产| 日韩精品中文字幕久久臀 | 美女久久久 | 国产丝袜高跟 | 婷婷射五月 | 午夜av一区 | 亚洲区另类春色综合小说校园片 | 玖玖在线观看视频 | 欧美一级片免费观看 | 亚洲精品mv在线观看 | 中文字幕免费在线 | 亚洲午夜久久久久久久久久久 | 狠狠躁日日躁狂躁夜夜躁av | 人人射人人射 | 亚洲人成免费网站 | 国产精品乱码久久久久 | 亚洲国产精品一区二区久久,亚洲午夜 | 在线小视频你懂的 | 三级av在线播放 | 黄色字幕网 | 91成年人在线观看 | 国产精品久久久久久久久久久久久久 | 国产精品观看视频 | 久久久久国产精品免费 | 国模精品一区二区三区 | 免费看片成人 | 日韩精品资源 | 黄色av免费 | 久久久影院一区二区三区 | av中文字幕第一页 | 久久久国产精品电影 | 日韩欧美aaa | 粉嫩av一区二区三区四区 | 狠狠干,狠狠操 | 99精品国产在热久久下载 | 欧美激情第十页 | 岛国精品一区二区 | 五月天婷亚洲天综合网鲁鲁鲁 | 中文字幕在线观看视频一区二区三区 | 国产成人精品一区二区三区在线观看 | 中文字幕有码在线观看 | 久久久精品福利视频 | 五月婷婷色 | 欧美性生交大片免网 | 国产老妇av | 亚洲视频,欧洲视频 | 91丨九色丨国产在线观看 | 久久久国产一区二区三区四区小说 | 国产精品午夜免费福利视频 | 色综合天天狠天天透天天伊人 | 亚洲天堂激情 | 国产高清免费在线播放 |