精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

搞懂二叉堆的那些事

開發 前端
我們在日常生活中,通常會說“一堆東西”或者“堆東西”,這里的“堆”,通常指重疊放置的許多東西。

1. 什么是二叉堆?

“二叉”自不必多說,本章主要介紹的樹都是二叉樹。那么啥是“堆”呢?

我們在日常生活中,通常會說“一堆東西”或者“堆東西”,這里的“堆”,通常指重疊放置的許多東西。

 [[397348]]

一堆東西

我們在堆東西的時候,肯定都有一個經驗,即:為了使這堆東西更穩定,會將比較重的、大的東西放在下面,比較輕的、小的東西放在上面。

這個經驗放在數據結構——二叉樹中,同樣適用。只不過“重”“大”是根據結點值的大小來判斷的,并且是在雙親結點和孩子結點之間進行比較的

比如,結點值大的,作為孩子結點;結點值小的,作為雙親結點。

下面舉一個例子,先看下面一顆普通二叉樹,也是一顆完全二叉樹:

再看下面一顆二叉堆:

最小堆

這個二叉堆的特點是:

  • 它是一顆完全二叉樹。事實上,該二叉堆就是由上圖的完全二叉樹經過調整轉化而來;
  • 任何一個雙親結點的值,均小于或等于左孩子和右孩子的值;
  • 每條分支從根結點開始都是升序排序(如分支 1-2-3-4)。

這樣的二叉堆被稱為最小堆,它的堆頂,即根結點 A,是整棵樹的最小值。

與最小堆相對應的是最大堆:

  • 最大堆是一顆完全二叉樹;
  • 它的任何一個雙親結點的值,均大于或等于左孩子和右孩子的值;
  • 每條分支從根結點開始都是降序排序。

最大堆的堆頂,是整棵樹的最大值。

我們將上圖中的普通二叉樹轉化為最大堆,如下圖:

最大堆

2. 二叉堆的操作

2.1. 構造二叉堆

給你一顆完全二叉樹,如何調整結點,構造出一個二叉堆?下面是一顆無序的完全二叉樹:

現在我們想要構造出一個最小堆,首先找到這顆完全二叉樹中所有的非葉子結點(綠色標記):

我們要做的事是:對每個非葉子結點,做最小堆的“下沉”調整。

何謂最小堆的“下沉”調整?

對某個非葉子結點,如果該結點大于其孩子結點中最小的那個,則交換二者位置,否則不用交換。在圖上則表現出非葉子結點(即大值結點)“下沉”一個層次。運動是相對的,大值結點“下沉”,就相當于小值結點“上浮”。

需要注意的是,有時下沉一次是不夠的,我們需要下沉多次,確保該結點下沉到底(即它不再大于其孩子)。

所有非葉子結點,從最后一個開始,按照從右到左,從下到上的順序進行多次最小堆的下沉調整,即可構造成最小堆。

比如對于值為 4 的非葉子結點而言,它下沉到第 3 層次后,仍然大于其孩子,這不算“下沉到底”,還需要繼續下沉到第 4 層次。至此,在分支 2-4-3-1 上,“大值”結點 4 算是下沉到底了。

下面進行分步解釋:

1.對非葉子結點 7,它小于其孩子結點 10, 不用“下沉”;

2.對非葉子結點 3,它大于其孩子結點中較大的結點 1,結點 3 要“下沉”,和結點 1 交換。顯然,結點 3 沉到底了。

 

3.對非葉子結點 6,它大于其孩子結點中較小的結點 5,結點 6 要“下沉”, 和結點 5 交換位置。顯然,結點 6 沉到底了。

4.對非葉子結點 4,它大于其孩子結點中最小的結點 1,結點 4 要 “下沉”,和結點 1 交換位置。顯然,結點 4 并未沉到底。

5.仍對結點 4,它大于其孩子結點中最小的結點 3,結點 4 要“下沉”, 和結點 3 交換位置。此時,結點 4 算是沉底了。

6.對非葉子結點 2,它大于其孩子結點中最小的結點 1,結點 2 要“下沉”,和結點 1 交換位置。顯然,結點 2 算是沉到底了。

至此,我們將一顆無序的完全二叉樹調整改造成了最小二叉堆,你可以檢查一下,最小堆中的所有結點皆滿足雙親的值小于孩子的值。并且,5 條分支上都是有序的。

構造最大堆的步驟類似,不過最大堆的下沉調整是:如果某結點小于其孩子結點中最大的那個,則交換二者位置,在圖上表現為非葉子結點(即小值結點)“下沉”一個層次。通過多次下沉調整,使該結點不再小于其孩子。

下圖把一個無序完全二叉樹調成為最大堆:

2.2. 插入結點

二叉堆是一個完全二叉樹,要向其中插入結點,插入到完全二叉樹的最后一個結點的下一個位置即可。

比如向下面的一個最大堆中插入結點 11,要插到最后一個結點 4 的下一個位置。當最大堆新插入一個結點 11 時,它就不再是最大堆了,因為結點 11 破壞了原堆的結構。所以,我們應當將其看作一個新的完全二叉樹,然后調整新完全二叉樹再次構造出最大堆。(調整過程見上)

插入過程

2.3. 刪除結點

刪除操作與插入操作相反,是刪除第一個位置的元素,即刪除堆頂。

我們以刪除上圖最大堆的堆頂 11 為例。

當刪除堆頂 11 后,二叉堆原結構被破壞,甚至不是一顆二叉樹了(變成兩顆):

為了保持完全二叉樹的形態,我們把最后一個結點 7 補到根結點去,頂替被刪除的根結點 11。如此一來,我們又得到了一個新完全二叉樹(不是二叉堆),然后我們根據這顆新完全二叉樹再次構造出最大堆即可。

刪除過程

3. 二叉堆的存儲結構

二叉堆的存儲結構是順序存儲,因為二叉堆是一顆完全二叉樹,在文章【二叉樹的存儲】中我們說過:完全二叉樹適合使用順序存儲結構來實現。

下圖是一個最大堆,紅色方框是對結點的編號,和數組下標一一對應。

 

二叉堆的順序存儲

鏈式存儲結構能夠清晰而形象地為我們展現出二叉堆中雙親結點和左右孩子的關系。但是數組中沒有指針,只有數組下標,怎么表示雙親和孩子的關系呢?

其實對于完全二叉樹來說,數組下標足矣!

現假設二叉堆中雙親結點的數組下標為 parent_index,左孩子的數組下標為 left_child_index,右孩子的數組下標為 right_child_index,那么它們之間有如下關系:

(一)left_child_index = 2 × parent_index + 1

(二)right_child_index = 2 × parent_index + 2

(三)parent_index = (left_child_index - 1) ÷ 2

(四)parent_index = (right_child_index - 2) ÷ 2

(五)right_child_index = left_child_index + 1

比如:結點 3 的下標為 3 ,則其左孩子 2 的下標為 2 × 3 + 1 = 7、右孩子 1 的下標為 2 × 3 + 2 = 8;

結點 3 的下標為 3,作為左孩子,其雙親下標為 (3 - 1) ÷ 2 = 1;結點 7 的下標為 4,作為右孩子,其雙親下標為 (4 - 2) ÷ 2 = 1;

假設某結點的數組下標為 child_index,你不知道該結點是左孩子還是右孩子,要求其雙親的下標,有

(六)parent_index = (child_index - 1) ÷ 2

比如:你不知道結點 5(下標為 5)、結點 6(下標為 6)是左孩子還是右孩子,則結點 5 和結點 6 的雙親下標分別為 (5 - 1) ÷ 2 = 2 、(6 - 1) ÷ 2 = 2。(注意,編程語言中的整型運算,所以結果不是小數)

這里,我們使用結構體實現二叉堆:

  1. #define MAXSIZE 20 // 數組的最大存儲空間 
  2.  
  3. typedef struct { 
  4.     int array[MAXSIZE]; // 存儲數組 
  5.     int length; // 當前堆長度(結點數) 
  6. } BinaryHeap; 

在進行實際操作之前,需要初始化二叉堆,即對數組及堆長度賦值:

  1. /** 
  2.  * @description: 初始化二叉堆 
  3.  * @param {BinaryHeap} *heap 二叉堆 
  4.  * @param {int} *array 數組首地址,該數組是一個無序完全二叉樹 
  5.  * @param {int} arr_length 數組長度 
  6.  * @return {*} 無 
  7.  */ 
  8. void init_heap(BinaryHeap *heap, int *array, int arr_length) 
  9.     // array 拷貝到 heap 中 
  10.     memcpy(heap->array, array, arr_length * sizeof(int)); 
  11.     // 設置堆長度 
  12.     heap->length = arr_length; 

4. 二叉堆的具體實現

4.1. 調整和構造

這里以構造最小堆為例。

要構造一個最小堆,就得調整所有的非葉子結點。而調整的依據就是比較非葉子結點和其孩子的大小。

我們約定 parent 為非葉子結點, parent_index 為其下標。child 為其孩子中較小的那個,child_index為其下標。

child 開始默認標識左孩子,那么右孩子的下標即為 child_index + 1。當左孩子小于等于右孩子時,child 不需要改變;當左孩子大于右孩子時,就得更新 child_index ,使child 標識右孩子。

下面結合下圖中值為 4 的非葉子結點為例,講述代碼如何實現。

先比較 parent 的左右孩子,左孩子較小,則 child 為左孩子,不需要更新 child_index。

parent 和 child 各就各位,發現 parent 大于 child,可以交換位置。在交換之前,先保存一下 parent 的值,即 parent_value = 4:

交換位置:先把 child的值賦給 parent,從而達到 值1 上浮的效果:

 


然后更新 parent_index 和 child_index,二者都往下走一層次:

然后將之前保存的 value 賦給現在的 parent,從而達到 值4 下沉的效果:

一次調整完成,但對于 值4 來說,并沒有結束,因為 值4 還沒有沉到底。

比較此時 parent 的左右孩子,發現右孩子較小,則 child 為右子樹,需要更新 child_index,使 child 標識右孩子:

現在可以交換位置了,把 child 的值賦給 parent,達到 值3 的上浮:

 


然后,更新 parent_index 和 child_index 的值,二者向下走一個層次:

把 value 賦給 parent,達到 值4 的下沉:

 

此時,child_index 已超過了二叉堆的長度,即 值4 已經到底了。

調整代碼如下:

  1. /** 
  2.  * @description: 針對某個非葉子結點進行到底的下沉調整 
  3.  * @param {BinaryHeap} *heap 二叉堆(無序) 
  4.  * @param {int} parent_index 某個非葉子結點 
  5.  * @return {*} 無 
  6.  */ 
  7. void adjust_for_min_heap(BinaryHeap *heap, int parent_index) 
  8.     // value 保存非葉子結點的值 
  9.     int value = heap->array[parent_index]; 
  10.     // child_index 標識左孩子 
  11.     int child_index = parent_index * 2 + 1; 
  12.     // 最后一個結點的下標 
  13.     int last_child_index = heap->length - 1; 
  14.  
  15.     // 雙親結點 parent 至少有一個孩子 
  16.     while (child_index <= last_child_index) { 
  17.         // 如果雙親結點 parent 有左孩子和右孩子 
  18.         if (child_index < last_child_index) { 
  19.             // 比較左孩子和右孩子誰小,如果右孩子小, 
  20.             if (heap->array[child_index] > heap->array[child_index + 1]) { 
  21.                 // 則 child_index 標識右孩子 
  22.                 child_index = child_index + 1; 
  23.             } 
  24.         } 
  25.         // 如果雙親的值大于 child 的值 
  26.         if (value > heap->array[child_index]) { 
  27.             heap->array[parent_index] = heap->array[child_index]; // 小節點上浮 
  28.             parent_index = child_index; // 更新雙親下標 
  29.             child_index = parent_index * 2 + 1; // 更新孩子下標 
  30.         } else { // 不做操作,跳出循環 
  31.             break; 
  32.         } 
  33.         // 大節點下沉 
  34.         heap->array[parent_index] = value; 
  35.     } 

構造代碼如下:

  1. /** 
  2.  * @description: 構造最小堆 
  3.  * @param {BinaryHeap} *heap 二叉堆(無序) 
  4.  * @return {*} 無 
  5.  */ 
  6. void create_min_heap(BinaryHeap *heap) 
  7.     // 每個非葉子結點都調整 
  8.     for (int i = (heap->length - 2) / 2; i >= 0; i--) { 
  9.         adjust_for_min_heap(heap, i); 
  10.     } 

4.2. 插入結點

只需將新結點插入二叉堆最后一個結點的下一個位置,然后重新構造二叉堆。

以最小堆為例,代碼如下:

  1. /** 
  2.  * @description: 向最小堆中插入一個元素 
  3.  * @param {BinaryHeap} *heap 最小堆指針 
  4.  * @param {int} elem 新元素 
  5.  * @return {*} 無 
  6.  */ 
  7. void insert_into_min_heap(BinaryHeap *heap, int elem) 
  8.     if (heap->length == MAXSIZE) { 
  9.         printf("二叉堆已滿,無法插入。\n"); 
  10.         return
  11.     } 
  12.     heap->array[heap->length] = elem; // 插入 
  13.     heap->length++; // 更新長度 
  14.     create_min_heap(heap); // 重新構造 

4.3. 刪除結點

將最后一個結點移動(賦值)到堆頂,然后重新構造二叉堆。

以最小堆為例,代碼如下:

  1. /** 
  2.  * @description: 刪除最小堆的堆頂 
  3.  * @param {BinaryHeap} *heap 最小堆指針 
  4.  * @param {int} *elem 保存變量指針 
  5.  * @return {*} 無 
  6.  */ 
  7. void delete_from_min_heap(BinaryHeap *heap, int *elem) 
  8.     if (heap->length == 0) { 
  9.         printf("二叉堆空,無元素可刪。\n"); 
  10.         return
  11.     } 
  12.     *elem = heap->array[0]; 
  13.     heap->array[0] = heap->array[heap->length - 1]; // 移動到堆頂 
  14.     heap->length--; // 更新長度 
  15.     create_min_heap(heap); //重新構造 

5. 總結

構造最大堆的本質是:將每顆子樹的“大”結點上浮作為雙親,“小”結點下沉作為孩子。

構造最小堆的本質是:將每顆子樹的“小”結點上浮作為雙親,“大”結點下沉作為孩子。

插入結點的本質是:插入新結點至二叉堆末尾,破壞了原二叉堆的結構,然后調整新得到的完全二叉樹,重新構造二叉堆。

刪除結點的本質是:刪除堆頂,破壞了原完全二叉樹的結構,然后使用最后一個結點,重新構造完全二叉樹,再調整新得到的完全二叉樹,重新構造二叉堆。

用四個字概括就是——破而后立。

至于代碼實現,關鍵在于結點的調整,把這個搞明白,剩下的就簡單了。

以上就是二叉堆的原理和相關操作。

完整代碼請移步至 GitHub[1] | Gitee[2] 獲取。

參考資料
[1]GitHub: https://github.com/xingrenguanxue/Simple-DS-and-Easy-Algo

[2]Gitee: https://gitee.com/xingrenguanxue/Simple-DS-and-Easy-Algo

 

責任編輯:姜華 來源: 二十二畫程序員
相關推薦

2020-08-31 07:43:58

二叉堆大頂堆存儲

2021-03-02 10:57:39

二叉樹二叉堆節點

2020-11-23 08:53:34

堆Heap

2023-04-06 07:39:48

2021-04-06 08:20:24

二叉搜索樹數據結構算法

2020-04-27 07:05:58

二叉樹左子樹右子樹

2018-03-05 22:45:34

2020-12-11 09:49:29

二叉樹搜索樹數據

2021-04-19 07:47:42

數據結構二叉樹Tree

2021-04-20 08:37:14

數據結構二叉樹

2022-10-26 23:58:02

二叉樹數組算法

2021-08-31 11:35:24

二叉搜索樹迭代法公共祖先

2021-08-27 11:36:44

二叉樹回溯節點

2021-04-28 20:12:27

數據結構創建

2021-05-09 20:22:41

順序查找二叉查找數據結構

2021-03-17 08:19:22

二叉樹LeetCode

2013-07-15 16:35:55

二叉樹迭代器

2021-09-29 10:19:00

算法平衡二叉樹

2022-12-26 00:51:33

雙向鏈表二叉搜索樹

2014-06-06 16:08:17

初志科技
點贊
收藏

51CTO技術棧公眾號

欧美麻豆久久久久久中文| 精品视频在线免费| 精品欧美一区二区三区久久久| 欧美国产成人精品一区二区三区| 成人精品久久| 日韩欧美国产午夜精品| 97在线播放视频| 麻豆免费在线观看| 国产精品影视在线| 国产不卡一区二区在线播放| 日韩视频中文字幕在线观看| 猛男gaygay欧美视频| 欧美一区二区精品| 国产第一页视频| 欧美6一10sex性hd| 国产精品免费av| 国产综合欧美在线看| 中文字幕乱码人妻二区三区| 国产日韩欧美一区在线 | 少妇一级淫片免费看| 欧美aaa在线| 26uuu亚洲伊人春色| www.超碰在线观看| 日韩精品永久网址| 亚洲精品美女在线| 久久久久无码精品| 免费成人毛片| 欧美最猛黑人xxxxx猛交| 东北少妇不带套对白| 久草免费在线| 欧美激情在线看| 欧美激情论坛| 色婷婷在线视频| 国产很黄免费观看久久| 91精品国产综合久久香蕉| 无码人妻av免费一区二区三区| 亚洲午夜黄色| 久久99热精品这里久久精品| 婷婷国产成人精品视频| 精品国产一区二区三区| 精品香蕉一区二区三区| 日本一级片在线播放| 91精品久久久久久综合五月天 | 久久视频在线| 色偷偷9999www| 五月天精品在线| 精品一级毛片| 色视频www在线播放国产成人| 成人免费无遮挡无码黄漫视频| 久久av资源| 亚洲裸体xxxx| 伊人网在线视频观看| 亚洲国产国产| 亚洲欧美日韩高清| 亚洲一区二区三区日韩| 久久不卡国产精品一区二区| 亚洲人成网站777色婷婷| 日韩中文字幕电影| 经典一区二区| 自拍视频国产精品| 中国毛片直接看| 欧美视频四区| 亚州精品天堂中文字幕| 九九精品免费视频| 日韩精品色哟哟| 国产欧美日韩精品专区| 国产又粗又大又黄| 国产不卡高清在线观看视频| 成人午夜电影在线播放| 天天干,天天操,天天射| 久久久蜜桃精品| 亚洲精品一品区二品区三品区| 尤物视频在线免费观看| 亚洲婷婷综合色高清在线| 热久久最新网址| 国产无遮挡裸体视频在线观看| 欧美性猛交xxxx乱大交蜜桃| 国内自拍视频网| 国产精品亚洲一区二区在线观看| 日韩欧美一级二级三级久久久| 在线免费看黄色片| 国产剧情在线观看一区| 久久五月天综合| 日韩欧美亚洲一区二区三区| 日韩影院在线观看| 亚洲综合第一页| 青青青手机在线视频观看| 国产精品丝袜久久久久久app| 亚洲小视频在线播放| 欧美aaaaa性bbbbb小妇| 欧美三级日韩三级国产三级| 免费看91视频| 狠狠操综合网| 久久久久久久电影一区| 午夜久久久久久久久久影院| 亚洲承认视频| 在线观看黄av| 1区2区3区国产精品| 青青草视频在线免费播放| 日本高清一二三区| 波多野结衣的一区二区三区 | 国产精品污www一区二区三区| 香蕉视频国产在线| 国产免费久久精品| 成年人三级视频| 另类中文字幕国产精品| 欧美哺乳videos| 亚洲精品国产熟女久久久| 综合久久久久| 国产精品一区二区三区免费视频 | 久久av高潮av| 麻豆精品蜜桃| 日韩精品在线影院| 国产极品国产极品| 日韩国产欧美在线观看| 高清视频一区| 久操视频在线免费播放| 一本大道久久精品懂色aⅴ| 少妇欧美激情一区二区三区| 精品一区二区三区在线| 九九精品在线播放| 这里只有精品免费视频| 91一区二区在线| 992tv快乐视频| 成人四虎影院| 亚洲视频在线看| 色婷婷在线观看视频| 国产精品一二三区| 亚洲欧美日产图| 美女网站视频一区| 精品中文字幕久久久久久| 日本网站免费观看| 国产 日韩 欧美大片| dy888午夜| 欧美一区二区三区婷婷| 国产亚洲欧美另类中文| 日日骚av一区二区| 91亚洲男人天堂| 亚洲熟妇无码一区二区三区导航| 国产精品视频一区二区三区| 色偷偷噜噜噜亚洲男人的天堂| 黄色污污网站在线观看| 国产亚洲欧美一级| 国产福利视频在线播放| 久久不见久久见免费视频7| 日本精品久久久久影院| 免费一级毛片在线观看| 日韩欧美在线一区| 永久免费成人代码| 免费成人美女在线观看.| 亚洲精品国产一区| 成人久久网站| 久久久国产影院| 国产男女裸体做爰爽爽| 亚洲女同女同女同女同女同69| 国产人妻精品久久久久野外| 女人色偷偷aa久久天堂| 波多野结衣精品久久| 国产第一页在线| 亚洲精品美女在线观看| 樱花视频在线免费观看 | 久热这里有精品| 丁香啪啪综合成人亚洲小说 | 免费电影一区| 欧洲精品一区二区三区| 综合激情国产一区| 99久久精品无免国产免费| 亚洲黄一区二区三区| 国产精品扒开腿做爽爽爽a片唱戏 亚洲av成人精品一区二区三区 | 国产一级特黄毛片| 久久亚区不卡日本| 欧美成人福利在线观看| 午夜精品久久久久99热蜜桃导演 | 婷婷开心激情网| 91国偷自产一区二区三区观看| 蜜桃av免费在线观看| 国产成人在线色| 欧美色图色综合| 日韩av专区| 翡翠波斯猫1977年美国| 中文在线免费二区三区| 中文字幕亚洲综合久久| 亚洲精华国产精华精华液网站| 岛国av午夜精品| 性少妇xx生活| 丰满放荡岳乱妇91ww| 妞干网在线免费视频| 一二三区不卡| 欧美日韩大片一区二区三区| 成人短视频软件网站大全app| 91国产视频在线播放| 亚洲成人三级| 亚洲精品美女免费| 国产喷水吹潮视频www| 亚洲va欧美va人人爽午夜| 国产第一页精品| zzijzzij亚洲日本少妇熟睡| av污在线观看| 国产日韩欧美一区在线| 亚洲成人动漫在线| 视频一区欧美| 91丨九色丨国产| 成人性生活视频| 欧美日本高清视频| 番号集在线观看| 亚洲国产欧美在线成人app| 一级aaaa毛片| 一本大道av伊人久久综合| 欧美色图亚洲天堂| 国产精品久久午夜| jizz欧美性20| 成人动漫在线一区| 91aaa精品| 青青草伊人久久| 妺妺窝人体色www在线小说| 最新国产精品| 一区二区视频在线播放| 精品国产午夜| 日本一区视频在线| 极品国产人妖chinesets亚洲人妖 激情亚洲另类图片区小说区 | 日本视频www| 亚洲女人****多毛耸耸8| 日本猛少妇色xxxxx免费网站| 26uuu亚洲综合色欧美| www.黄色网| 国产黄人亚洲片| 91精品成人久久| 三级黄色片播放| 99精品免费网| 中文字幕日韩精品无码内射| 99久久婷婷国产综合精品电影√| 欧美日韩亚洲综合一区二区三区激情在线| 91在线一区| 99国精产品一二二线| 精品久久国产一区| 成人免费黄色网| 国产香蕉久久| 国产日韩精品电影| 久久久久黄色| 国产精品视频公开费视频| 国产v综合v| 国产精彩精品视频| 欧美精选视频一区二区| 国产精品91久久久| 精品成人免费一区二区在线播放| 青草成人免费视频| 唐人社导航福利精品| 日韩美女激情视频| 日韩天堂在线| 国产精品欧美一区二区三区奶水| 51一区二区三区| 国产一区深夜福利| 亚洲欧洲二区| 91久久大香伊蕉在人线| 亚洲日本va午夜在线电影| 粉嫩精品一区二区三区在线观看| aaa国产精品视频| 精品久久久久久中文字幕动漫| 女仆av观看一区| 欧美日韩一区综合| 成人一区不卡| 精品国产一区二区三区在线| 欧美永久精品| 屁屁影院ccyy国产第一页| 伊人精品成人久久综合软件| 水蜜桃色314在线观看| 性伦欧美刺激片在线观看| 手机看片福利日韩| 日本在线视频一区二区| 亚洲精品中文字幕在线观看| 亚洲av综合一区二区| 亚洲国产成人午夜在线一区| 91杏吧porn蝌蚪| 精品国产精品三级精品av网址| 亚洲午夜18毛片在线看| 欧美性xxxxxx少妇| 精品国产伦一区二区三| 亚洲精品福利在线观看| 国产福利电影在线| 精品少妇v888av| 二区三区不卡| 92国产精品久久久久首页 | 日韩一区二区精品葵司在线| 免费看av毛片| 亚洲视频在线观看免费| 中文字幕伦理免费在线视频 | 亚洲天堂第一区| 99热在线精品观看| 天天干天天爽天天射| 国产+成+人+亚洲欧洲自线| 男人操女人动态图| 亚洲柠檬福利资源导航| 日本一区二区免费电影| 欧美精品高清视频| 天堂v视频永久在线播放| 日韩有码在线观看| 91视频欧美| 成人h视频在线观看播放| 欧美aaaaa级| 精品国产一区二区三区在线| 久久激情中文| 国产精品91av| 国产精品欧美一级免费| 国产精品7777777| 91精选在线观看| 国产小视频免费在线网址| 免费成人高清视频| yiren22亚洲综合| 激情五月综合色婷婷一区二区 | 久久影院模特热| 亚洲高清黄色| 国产欧美日韩一区| 亚洲h色精品| 天天爽人人爽夜夜爽| 99re这里都是精品| 久草免费在线观看视频| 欧美日韩另类国产亚洲欧美一级| 亚洲区小说区图片区| 精品少妇v888av| 91精品国产自产观看在线| 日本一区二区三区四区在线观看 | 熟女人妻一区二区三区免费看| 欧美国产精品一区二区| 性色av免费观看| 精品一区电影国产| 国模雨婷捆绑高清在线| 91在线中文字幕| 97精品国产一区二区三区 | 丁香婷婷久久| 欧美精品v日韩精品v国产精品| 亚洲激情欧美| 制服丝袜在线第一页| 亚洲精品免费在线播放| 国产精品自拍电影| 色七七影院综合| 欧美啪啪网站| 一区二区三区我不卡| 麻豆精品视频在线观看| 女人黄色一级片| 欧美私人免费视频| 日本中文字幕伦在线观看| 国产日韩精品在线| 久久久久久久久久久久久久| www.桃色.com| 亚洲男人的天堂av| jizz国产视频| 欧美激情国产精品| 国产一区二区三区亚洲| 拔插拔插海外华人免费| 成人精品鲁一区一区二区| 国产污视频在线看| 亚洲国产精品电影在线观看| 国产伦久视频在线观看| 久久久一本精品99久久精品66 | 免费网站在线观看黄| 中文字幕一区二区三区在线不卡 | 电影亚洲精品噜噜在线观看| 四虎永久在线精品免费一区二区| 麻豆91在线观看| 日本天堂中文字幕| 亚洲成年人影院在线| 少妇视频一区| 亚州欧美一区三区三区在线| 久久精品国产秦先生| 波多野结衣不卡视频| 欧美精品一区二区三区很污很色的 | 精品人妻一区二区三区含羞草| 欧美风情在线观看| 青青草原在线亚洲| 欧美日韩高清区| 四虎影视在线观看2413| 国产成+人+综合+亚洲欧美丁香花| 欧美手机视频| 深夜做爰性大片蜜桃| 亚洲国产美女搞黄色| 精品福利视频导航大全| 成人激情视频在线播放| 国内精品久久久久久久97牛牛 | 亚洲国产合集| 97超碰成人在线| 亚洲h精品动漫在线观看| 精品三级久久久久久久电影聊斋| 国产精品美女午夜av| 欧美在线免费一级片| www.久久av| 91精品一区二区三区久久久久久 | 3d蒂法精品啪啪一区二区免费| 日韩天天综合| 激情无码人妻又粗又大| 亚洲黄色av网站| 欧美日韩视频免费看| www.av片| 亚洲欧洲日韩在线| 午夜性色福利视频| 成人免费在线视频网址| 国产午夜精品一区二区三区欧美 | 欧美性高潮床叫视频 | 亚洲黄色小视频| 国产视频福利在线| 国产乱人伦精品一区二区|