3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[数据结构与算法]平衡二叉树实现

發(fā)布時間:2025/3/21 编程问答 11 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [数据结构与算法]平衡二叉树实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

由于程序太長,分成了幾部分,后面附上源碼。

1 /** 2 * 平衡二叉搜索(排序)樹 3 * 4 * 平衡二叉搜索樹雙稱為AVL樹,它也是一棵二叉搜索樹,是對二叉搜索樹的一種改進,或都是具有下列性質(zhì)的二叉樹:它 5 * 的左子樹和右子樹都是平衡二叉樹,且左子樹和右子樹的深度之差的絕對值不超過1。 6 * 7 * 平衡因子(Balance Factor,BF)定義為該節(jié)點的左子樹的深度減去其右子樹的深度,則平衡二叉樹上所有節(jié)點的平 8 * 衡因子只可能是-1、0和1。只要樹上有一個節(jié)點的平衡因子的絕對值大于1,則該二叉樹就是不平衡的了。 9 * 10 * 使用二叉排序樹保持平衡的基本思想是:每當在二叉排序樹中插入一個節(jié)點時,首先檢查是否因插入而破壞了平衡,若 11 * 是,則找出其中的最小不平衡二叉樹,在保持二叉排序樹特性的情況下,調(diào)整最小不平衡子s樹中節(jié)點之間的關系,以達 12 * 到新的平衡。所謂最小不平衡子樹指離插入節(jié)點最近且以平衡因子的絕對值大于1的節(jié)點作為根的子樹。 13 * 14 * 對于平衡二叉搜索樹,保持樹的平衡的基本機制就是旋轉(zhuǎn)。旋轉(zhuǎn)是對樹的元素順序進行調(diào)節(jié)。旋轉(zhuǎn)的目的是消除由于臨 15 * 時插入和刪除對樹的平衡產(chǎn)生的影響。 16 * 17 * 有四種旋轉(zhuǎn): 18 * 1)繞某元素左旋轉(zhuǎn) 19 * 80 ← p 90 20 * /\ /\ 21 * 60 90 ← r → 80 120 22 * /\ /\ / 23 * 85 120 60 85 100 24 * / 25 * 100 26 * 27 * 2)繞某元素右旋轉(zhuǎn) 28 * p → 100 85 29 * /\ /\ 30 * l → 85 120 → 60 100 31 * /\ \ /\ 32 * 60 90 80 90 120 33 * \ 34 * 80 35 * 36 * 3)繞某元素的左子節(jié)點左旋轉(zhuǎn),接著再繞該元素自己右旋轉(zhuǎn)。此情況下就是 左旋與右旋 的結合,具體操作時可以分 37 * 解成這兩種操作,只是圍繞點不一樣而已 38 * 39 * 先繞100的左子節(jié)點80左旋轉(zhuǎn),接著再繞100左旋轉(zhuǎn) 40 * 41 * 左旋 右旋 42 * 100 → p → 100 → 90 43 * /\ /\ /\ 44 * p → 80 120 l → 90 120 80 100 45 * /\ / /\ \ 46 * 60 90 ← r 80 60 85 120 47 * / /\ 48 * 85 60 85 49 * 50 * 4)繞某元素的右子節(jié)點右旋轉(zhuǎn),接著再繞該元素自己左旋轉(zhuǎn)。此情況下就是 右旋與左旋 的結合,具體操作時可以分解 51 * 成這兩種操作,只是圍繞點不一樣而已 52 * 53 * 先繞80的右子節(jié)點80右旋轉(zhuǎn),接著再繞80左旋轉(zhuǎn) 54 * 右旋 左旋 55 * 80 → 80 ← p → 85 56 * /\ /\ /\ 57 * 60 100 ← p 60 85 ← r 80 100 58 * /\ \ / /\ 59 * l → 85 120 100 60 90 120 60 * \ /\ 61 * 90 90 120 62 * 63 * 平衡二叉樹實現(xiàn)類 AVLTree 中的很多方法與排序二叉樹是一新的,詳細請參考 BinSearchTree 類中相應方法 64 * 65 * AVLTree中的Entry對象與BinSearchTree中的Entry對象是有區(qū)別的,所以AVLTree類不能是BinSearchTree的 66 * 了類,雖然很多的方法是一樣的(如:contains、getEntry、successor、iterator),還有一些方法(add、de 67 * leteEntry)只是在操作后增加了節(jié)點平衡因子調(diào)整動作,但不能直接繼承于它。 68 * 69 * 二叉搜索樹與平衡二叉搜索樹沒有在Java集合框架中實現(xiàn),但RED-BLACK樹在TreeMap實現(xiàn)過,當然TreeSet也是, 70 * 因為它是基于TreeMap實現(xiàn)的,TreeSet對象基本上就是一個忽略了每個元素值部分的TreeMap對象。 71 * 72 */

?

1 package tree.avl; 2 3 import java.util.AbstractSet; 4 import java.util.Iterator; 5 6 /** 7 * 平衡二叉搜索(排序)樹 8 * 9 * @author jzj 10 * @data 2009-12-25 11 */ 12 public class AVLTree<E extends Comparable<E>> extends AbstractSet<E> { 13 private Entry<E> root;//根節(jié)點 14 private int size;//樹節(jié)點個數(shù) 15 16 private static class Entry<E> { 17 E elem;//數(shù)據(jù)域 18 Entry<E> parent;//父節(jié)點 19 Entry<E> left;//左節(jié)點 20 Entry<E> right;//右節(jié)點 21 /* 22 * 樹的平衡因子,等號表示左子樹和右子樹有同樣的高度。如果L,左子樹比右子樹高1。如果為R,則意味著右 23 * 子樹比左高1。剛創(chuàng)建時是平衡的,所以為= 24 * 50 25 * /R\ 26 * 20 80 27 * /L /R\ 28 * 10 70 100 29 * = = /=\ 30 * 92 103 31 * = = 32 */ 33 char balanceFactor = '='; 34 35 //構造函數(shù)只有兩個參數(shù),左右節(jié)點是調(diào)用add方法時設置 36 public Entry(E elem, Entry<E> parent) { 37 this.elem = elem; 38 this.parent = parent; 39 } 40 } 41 42 private class TreeIterator implements Iterator<E> { 43 44 private Entry<E> lastReturned = null; 45 private Entry<E> next; 46 47 TreeIterator() { 48 49 next = root; 50 if (next != null) 51 while (next.left != null) 52 next = next.left; 53 54 } 55 56 public boolean hasNext() { 57 58 return next != null; 59 60 } 61 62 public E next() { 63 64 lastReturned = next; 65 next = successor(next); 66 return lastReturned.elem; 67 68 } 69 70 public void remove() { 71 72 if (lastReturned.left != null && lastReturned != null) 73 next = lastReturned; 74 deleteEntry(lastReturned); 75 lastReturned = null; 76 77 } 78 } 79 80 /** 81 * 左旋轉(zhuǎn):結果就是將p移到它的左子節(jié)點的位置,而p的右子節(jié)點被移到該元素原來位置 82 * @param p 旋轉(zhuǎn)元素 83 */ 84 private void rotateLeft(Entry<E> p) { 85 /* 86 * 圍繞50左旋轉(zhuǎn): 87 *p → 50 90 88 * \ /\ 89 * r → 90 → 50 100 90 * \ 91 * 100 92 * 93 * 圍繞80左旋轉(zhuǎn):r的左子樹變成p的右子樹。因為位于r的左子樹上的任意一個元素值大于p且小于r,所以r的左子 94 * 樹可以成為p的右子樹這是沒有問題的。其實上面也發(fā)生了同樣的現(xiàn)象,只是r的左子樹為空罷了 95 * p → 80 90 96 * /\ /\ 97 * 60 90 ← r → 80 120 98 * /\ /\ / 99 * 85 120 60 85 100 100 * / 101 * 100 102 * 103 * 圍繞80在更大范圍內(nèi)旋轉(zhuǎn):元素不是圍繞樹的根旋轉(zhuǎn)。旋轉(zhuǎn)前后的樹都是二叉搜索樹。且被旋轉(zhuǎn)元素80上的所 104 * 有元素在旋轉(zhuǎn)中不移動(50、30、20、40這四個元素還是原來位置) 105 * 50 50 106 * / \ / \ 107 * 30 80 ← p 30 90 108 * /\ /\ /\ / \ 109 * 20 40 60 90 ← r → 20 40 80 120 110 * /\ /\ / 111 * 85 120 60 85 100 112 * / 113 * 100 114 * 115 * 節(jié)點數(shù)據(jù)結構: 116 * +------------------+ 117 * | elem | p | l | r | 118 * +------------------+ 119 * 120 * +------------------+ 121 * | 50 |NULL|NULL| r | 122 * +------------------+ 123 * ↖⑥ ↘④ 124 * +---------------+ 125 * |80| p | l | r | ← p 126 * +---------------+ 127 * ↗ ↙ ↖③ ↘① 128 * +----------------+ +---------------+ 129 * |60| p |NULL|NULL| |90| p | l | r | ← r 130 * +----------------+ +---------------+ 131 * ↗② ↙⑤ ↖↘ 132 * +----------------+ +---------------+ 133 * |85| p |NULL|NULL| |90| p | l |NULL| 134 * +----------------+ +---------------+ 135 * ↗ ↙ 136 * +-----------------+ 137 * |100| p |NULL|NULL| 138 * +-----------------+ 139 */ 140 141 Entry<E> r = p.right;//旋轉(zhuǎn)元素的右子節(jié)點 142 //把旋轉(zhuǎn)元素的右子節(jié)點的左子節(jié)點接到旋轉(zhuǎn)元素的右子樹 143 p.right = r.left;//144 //如果旋轉(zhuǎn)元素的右子節(jié)點存在左子節(jié)點的話,同時修改該節(jié)點的父節(jié)指針指向 145 if (r.left != null) { 146 //把旋轉(zhuǎn)元素的右子節(jié)點的左子節(jié)點的父設置成旋轉(zhuǎn)元素 147 r.left.parent = p;// 148 } 149 //將旋轉(zhuǎn)元素的右子節(jié)點的父設置成旋轉(zhuǎn)元素的父,這里有可以p為根節(jié)點,那么旋轉(zhuǎn)后p就成根節(jié)點 150 r.parent = p.parent;//151 152 //如果旋轉(zhuǎn)元素為根元素,則旋轉(zhuǎn)后,旋轉(zhuǎn)元素的右子節(jié)點r將成為根節(jié)點 153 if (p.parent == null) { 154 root = r; 155 }//否則p不是根節(jié)點,如果p是他父節(jié)點的左節(jié)點時 156 else if (p.parent.left == p) { 157 //讓p的父節(jié)點的左指針指向r 158 p.parent.left = r; 159 }//否則如果p是他父節(jié)點的右節(jié)點時 160 else { 161 //讓p的父節(jié)點的右指針指向r 162 p.parent.right = r;// 163 } 164 //讓旋轉(zhuǎn)元素的左節(jié)點指向旋轉(zhuǎn)元素p 165 r.left = p;//166 //讓旋轉(zhuǎn)元素的父節(jié)點指向旋轉(zhuǎn)元素右節(jié)點r 167 p.parent = r;// 168 } 169 170 /** 171 * 右旋轉(zhuǎn):結果就是將p移到它的右子節(jié)點的位置,而p的左子節(jié)點被移到該元素原來位置 172 * 與左旋轉(zhuǎn)是完全對稱的,將左旋轉(zhuǎn)中的lef與rigth互換即可得到,這里就不詳細解釋了 173 * @param p 旋轉(zhuǎn)元素 174 */ 175 private void rotateRight(Entry<E> p) { 176 177 /* 178 * 圍繞100右旋轉(zhuǎn): 179 * p → 100 90 180 * / /\ 181 * l → 90 → 50 100 182 * / 183 * 50 184 * 185 * 圍繞80右旋轉(zhuǎn):l的右子樹變成p的左子樹。因為位于l的右子樹上的任意一個元素值小于p且小于l,所以l的右 186 * 子樹可以成為p的左子樹這是沒有問題的。其實上面也發(fā)生了同樣的現(xiàn)象,只是l的右子樹為空罷了 187 * 188 * p → 80 60 189 * /\ /\ 190 * l → 60 90 → 50 80 191 * /\ \ /\ 192 * 50 70 55 70 90 193 * \ 194 * 55 195 */ 196 197 Entry<E> l = p.left; 198 p.left = l.right; 199 if (l.right != null) { 200 l.right.parent = p; 201 } 202 l.parent = p.parent; 203 204 if (p.parent == null) { 205 root = l; 206 } else if (p.parent.right == p) { 207 p.parent.right = l; 208 } else { 209 p.parent.left = l; 210 } 211 l.right = p; 212 p.parent = l; 213 } 214 215 /** 216 * AVLTree類的add方法類似于BinSerrchTree類的add方法,但是沿著根向下前進到插入點時,需記錄這樣一個被插 217 * 入Entry對象最近的祖先:該祖先的平衡因子balanceFactor值是L或R(即不殲),且讓ancestor指向這個祖先節(jié) 218 * 點,該祖先節(jié)有什么用呢,從ancestor的子開始到新增節(jié)點路徑上的所有祖先節(jié)點都是平衡,這些祖先節(jié)點會因為 219 * 新增節(jié)點而變得不平衡了,需要重新調(diào)整平衡因子,這個分界點在調(diào)整平衡因子時非常有用 220 * 221 * @param elem 要新增元素的數(shù)據(jù)域 222 * @return 223 */ 224 public boolean add(E elem) { 225 //如果樹為空,則直接插入 226 if (root == null) { 227 root = new Entry<E>(elem, null); 228 size++; 229 return true; 230 } else { 231 Entry<E> tmp = root;//新增節(jié)點的父節(jié)點,從根節(jié)點下面開始找插入點 232 Entry<E> ancestor = null;//平衡因子不為 = 的最近祖先節(jié)點 233 int comp; //比較結果 234 while (true) {//死循環(huán),直接找到插入點退出循環(huán) 235 comp = elem.compareTo(tmp.elem); 236 //如果已存在該元素,則直接返回失敗 237 if (comp == 0) { 238 return false; 239 } 240 241 //記錄不平衡的祖先節(jié)點 242 if (tmp.balanceFactor != '=') { 243 //如果哪個祖先節(jié)點不平衡,則記錄,當循環(huán)完后,ancestor指向的就是最近一個 244 //不平衡的祖先節(jié)點 245 ancestor = tmp; 246 } 247 248 //如果小于當前比較節(jié)點,則在其左邊插入 249 if (comp < 0) { 250 251 //如果左子樹不為空,繼續(xù)循環(huán)在左邊找插入點 252 if (tmp.left != null) { 253 tmp = tmp.left; 254 } else {//否則插入 255 tmp.left = new Entry<E>(elem, tmp); 256 //插入后要進行平衡調(diào)整 257 fixAfterInsertion(ancestor, tmp.left); 258 size++; 259 return true; 260 } 261 } else {//在右邊插入 262 263 //如果右子樹不為空,繼續(xù)循環(huán)在右邊找插入點 264 if (tmp.right != null) { 265 tmp = tmp.right; 266 } else {//否則插入 267 tmp.right = new Entry<E>(elem, tmp); 268 //插入后要進行平衡調(diào)整 269 fixAfterInsertion(ancestor, tmp.right); 270 size++; 271 return true; 272 } 273 } 274 275 } 276 } 277 } 278 279 /** 280 * 當新增節(jié)點后,會改變某些節(jié)點的平衡因子,所以添加節(jié)點后需重新調(diào)整平衡因子 281 * 282 * 根據(jù)前人們的分析與研究,可分為6種情況 283 * 284 * @param ancestor 新增元素的最近一個不平衡的祖先節(jié)點 285 * @param inserted 新增元素 286 */ 287 protected void fixAfterInsertion(Entry<E> ancestor, Entry<E> inserted) { 288 E elem = inserted.elem; 289 290 if (ancestor == null) { 291 /* 292 * 情況1:ancestor的值為null,即被插入Entry對象的每個祖先的平衡因子都是 =,此時新增節(jié)點后 293 * ,樹的高度不會發(fā)生變化,所以不需要旋轉(zhuǎn),我們要作的就是調(diào)整從根節(jié)點到插入節(jié)點的路徑上的所有 294 * 節(jié)點的平衡因子罷了 295 * 296 * 新增55后調(diào)整 297 * 50 → 50 298 * /=\ /R\ 299 * 25 70 25 70 300 * /=\ /=\ /=\ /L\ 301 * 15 30 60 90 15 30 60 90 302 * = = = = = = /L = 303 * 55 304 * = 305 */ 306 //根節(jié)點的平衡因子我們單獨拿出來調(diào)整,因為adjustPath的參數(shù)好比是一個開區(qū)間,它不包括兩頭參數(shù) 307 //本身,而是從nserted.paraent開始到to的子節(jié)點為止,所以需單獨調(diào)整,其他分支也一樣 308 if (elem.compareTo(root.elem) < 0) { 309 root.balanceFactor = 'L'; 310 } else { 311 root.balanceFactor = 'R'; 312 } 313 //再調(diào)用adjustPath方法調(diào)整新增節(jié)點的父節(jié)點到root的某子節(jié)點路徑上的所有祖先節(jié)點的 314 //平衡因子 315 adjustPath(root, inserted); 316 } else if ((ancestor.balanceFactor == 'L' && elem.compareTo(ancestor.elem) > 0) 317 || (ancestor.balanceFactor == 'R' && elem.compareTo(ancestor.elem) < 0)) { 318 /* 319 * 情況2: 320 * ancestor.balanceFactor的值為 L,且在ancestor對象的右子樹插入,或ancestor.balanceFac 321 * tor的值為 R,且在ancestor對象的左子樹插入,這兩插入方式都不會引起樹的高度發(fā)生變化,所以我們 322 * 也不需要旋轉(zhuǎn),直接調(diào)整平衡因子即可 323 * 新增55后調(diào)整 324 * ancestor → 50 → 50 325 * /L\ /=\ 326 * 25 70 25 70 327 * /R\ /=\ /R\ /L\ 328 * 15 30 60 90 15 30 60 90 329 * /L /L /L 330 * 28 28 55 331 * 新增28后調(diào)整 332 * ancestor → 50 → 50 333 * /R\ /=\ 334 * 25 70 25 70 335 * /=\ /L\ /R\ /L\ 336 * 15 30 60 90 15 30 60 90 337 * /L /L /L 338 * 55 28 55 339 */ 340 //先設置ancestor的平衡因子為 平衡 341 ancestor.balanceFactor = '='; 342 //然后按照一般策略對inserted與ancestor間的元素進行調(diào)整 343 adjustPath(ancestor, inserted); 344 } else if (ancestor.balanceFactor == 'R' 345 && elem.compareTo(ancestor.right.elem) > 0) { 346 /* 347 * 情況3: 348 * ancestor.balanceFactor的值為 R,并且被插入的Entry位于ancestor的右子樹的右子樹上, 此 349 * 種情況下會引起樹的不平衡,所以先需繞ancestor進行旋轉(zhuǎn),再進行平衡因子的調(diào)整 350 * 351 * 新增93 先調(diào)整因子再繞70左旋 352 * → 50 → 50 353 * /R\ /R\ 354 * 25 70 ← ancestor 25 90 355 * /L /R\ /L /=\ 356 * 15 60 90 15 70 98 357 * = = /=\ = /=\ /L 358 * 80 98 60 80 93 359 * = /= = = = 360 * 93 361 * = 362 */ 363 ancestor.balanceFactor = '='; 364 //圍繞ancestor執(zhí)行一次左旋 365 rotateLeft(ancestor); 366 //再調(diào)整ancestor.paraent(90)到新增節(jié)點路徑上祖先節(jié)點平衡 367 adjustPath(ancestor.parent, inserted); 368 } else if (ancestor.balanceFactor == 'L' 369 && elem.compareTo(ancestor.left.elem) < 0) { 370 /* 371 * 情況4: 372 * ancestor.balanceFactor的值為 L,并且被插入的Entry位于ancestor的左子樹的左子樹上, 373 * 此種情況下會引起樹的不平衡,所以先需繞ancestor進行旋轉(zhuǎn),再進行平衡因子的調(diào)整 374 * 375 * 新增13 先調(diào)整因子再繞50右旋 376 * → 50 ← ancestor → 20 377 * /L\ /=\ 378 * 20 70 10 50 379 * /=\ /=\ /R\ /=\ 380 * 10 30 60 90 5 15 30 70 381 * /=\ /=\= = = /L /=\ /=\ 382 * 5 15 25 35 13 25 35 60 90 383 * = /= = = = = = = = 384 * 13 385 * = 386 */ 387 ancestor.balanceFactor = '='; 388 //圍繞ancestor執(zhí)行一次右旋 389 rotateRight(ancestor); 390 //再調(diào)整ancestor.paraent(20)到新增節(jié)點路徑上祖先節(jié)點平衡 391 adjustPath(ancestor.parent, inserted); 392 } else if (ancestor.balanceFactor == 'L' 393 && elem.compareTo(ancestor.left.elem) > 0) { 394 /* 395 * 情況5: 396 * ancestor.balanceFactor的值為 L,并且被插入的Entry位于ancestor的左子樹的右子樹上。此 397 * 種情況也會導致樹不平衡,此種與第6種一樣都需要執(zhí)行兩次旋轉(zhuǎn)(執(zhí)行一次繞ancestor的左子節(jié)點左 398 * 旋,接著執(zhí)行一次繞ancestor執(zhí)行一次右旋)后,樹才平衡,最后還需調(diào)用 左-右旋 專有方法進行平衡 399 * 因子的調(diào)整 400 */ 401 rotateLeft(ancestor.left); 402 rotateRight(ancestor); 403 //旋轉(zhuǎn)后調(diào)用 左-右旋 專有方法進行平衡因子的調(diào)整 404 adjustLeftRigth(ancestor, inserted); 405 } else if (ancestor.balanceFactor == 'R' 406 && elem.compareTo(ancestor.right.elem) < 0) { 407 408 /* 409 * 情況6: 410 * ancestor.balanceFactor的值為 R,并且被插入的Entry位于ancestor的右子樹的 左子樹上,此 411 * 種情況也會導致樹不平衡,此種與第5種一樣都需要執(zhí)行兩次旋轉(zhuǎn)(執(zhí)行一次繞ancestor的右子節(jié)點右旋 412 * ,接著執(zhí)行一次繞ancestor執(zhí)行一次左旋)后,樹才平衡,最后還需調(diào)用 右-左旋 專有方法進行平衡因 413 * 子的調(diào)整 414 */ 415 rotateRight(ancestor.right); 416 rotateLeft(ancestor); 417 //旋轉(zhuǎn)后調(diào)用 右-左旋 專有方法進行平衡因子的調(diào)整 418 adjustRigthLeft(ancestor, inserted); 419 } 420 }

?

1 /** 2 * 調(diào)整指定路徑上的節(jié)點的平衡因子 3 * 4 * 注,指定的路徑上的所有節(jié)點一定是平衡的,因此如果被插入元素小于某個祖先節(jié)點, 5 * 則這個祖先節(jié)點新的平衡因子是 L,反之為 R。 6 * 7 * @param inserted 從哪里元素開始向上調(diào)整,但不包括該,即從父開始) 8 * @param to 直到哪個元素結束,但不包括該元素,一般傳進來的為ancestor 9 */ 10 protected void adjustPath(Entry<E> to, Entry<E> inserted) { 11 E elem = inserted.elem; 12 Entry<E> tmp = inserted.parent; 13 //從新增節(jié)點的父節(jié)點開始向上回溯調(diào)整,直到結尾節(jié)點to止 14 while (tmp != to) { 15 /* 16 * 插入30,則在25右邊插入,這樣父節(jié)點平衡會被打破,右子樹就會比左子樹高1,所以平衡因子為R;祖 17 * 先節(jié)點50的平衡因子也被打破,因為在50的左子樹上插入的,所以對50來說,左子樹會比右子樹高1,所 18 * 以其平衡因子為L 19 * 50 50 20 * /=\ 插入30 /L\ 21 * 25 70 → 25 70 22 * = = R\ = 23 * 30 24 * = 25 */ 26 //如果新增元素比祖先節(jié)點小,則是在祖先節(jié)點的左邊插入,則自然該祖先的左比右子樹會高1 27 if (elem.compareTo(tmp.elem) < 0) { 28 29 tmp.balanceFactor = 'L'; 30 } else { 31 //否則會插到右邊,那么祖先節(jié)點的右就會比左子樹高1 32 tmp.balanceFactor = 'R'; 33 } 34 tmp = tmp.parent;//再調(diào)整祖先的祖先 35 } 36 } 37 38 /** 39 * 進行 左-右旋轉(zhuǎn) 后平衡因子調(diào)整 40 * 分三種情況 41 * @param ancestor 42 * @param inserted 43 */ 44 protected void adjustLeftRigth(Entry<E> ancestor, Entry<E> inserted) { 45 E elem = inserted.elem; 46 if (ancestor.parent == inserted) { 47 /* 48 * 第1種,新增的節(jié)點在旋轉(zhuǎn)完成后為ancestor父節(jié)點情況: 49 * 50 * 新增40 繞30左旋 繞50右旋 51 * → 50 ← ancestor → 50 → 52 * /L /L 53 * 30 40 54 * =\ /= 55 * 40 30 56 * = = 57 * 58 * 調(diào)整平衡因子 59 * 40 → 40 60 * /=\ /=\ 61 * 30 50 30 50 62 * = L = = 63 * 64 * 注,這里的 左-右旋 是在fixAfterInsertion方法中的第5種情況中完成的,在這里只是平衡因子的 65 * 調(diào)整,圖是為了好說明問題而放在這個方法中的,下面的兩個分支也是一樣 66 */ 67 ancestor.balanceFactor = '='; 68 } else if (elem.compareTo(ancestor.parent.elem) < 0) { 69 /* 70 * 第2種,新增的節(jié)點在旋轉(zhuǎn)完成后為不為ancestor父節(jié)點,且新增節(jié)點比旋轉(zhuǎn)后ancestor的父節(jié)點要小 71 * 的情況 72 * 73 * 由于插入元素(35)比旋轉(zhuǎn)后ancestor(50)的父節(jié)點(40)要小, 所以新增節(jié)點會在其左子樹中 74 * 75 * 新增35 繞20左旋 76 * → 50 ← ancestor → 50 77 * /L\ /L\ 78 * 20 90 40 90 79 * /=\ /=\ /=\ /=\ 80 * 10 40 70 100 20 45 70 100 81 * /=\ /=\= = /=\ 82 * 5 15 30 45 10 30 83 * = = =\ = /=\ =\ 84 * 35 5 15 35 85 * = = = = 86 * 87 * 繞50右旋 調(diào)整平衡因子 88 * → 40 → 40 89 * /=\ /=\ 90 * 20 50 20 50 91 * /=\ /L\ /=\ /R\ 92 * 10 30 45 90 10 30 45 90 93 * /=\ =\ /=\ /=\ R\ /=\ 94 * 5 15 35 70 100 5 15 35 70 100 95 * = = = = = = = = = = 96 * 97 */ 98 ancestor.balanceFactor = 'R'; 99 //調(diào)整ancestor兄弟節(jié)點到插入點路徑上節(jié)點平衡因子 100 adjustPath(ancestor.parent.left, inserted); 101 } else { 102 /* 103 * 第2種,新增的節(jié)點在旋轉(zhuǎn)完成后為不為ancestor父節(jié)點,且新增節(jié)點比旋轉(zhuǎn)后ancestor的父節(jié)點要大的 104 * 情況 105 * 106 * 由于插入元素(42)比旋轉(zhuǎn)后ancestor(50)的父節(jié)點(40)要大,所以新增節(jié)點會在其右子樹中 107 * 108 * 新增42 繞20左旋 109 * → 50 ← ancestor → 50 110 * /L\ /L\ 111 * 20 90 40 90 112 * /=\ /=\ /=\ /=\ 113 * 10 40 70 100 20 45 70 100 114 * /=\ /=\= = /=\ /= 115 * 5 15 30 45 10 30 42 116 * = = = /= /=\= = 117 * 42 5 15 118 * = = = 119 * 120 * 繞50右旋 調(diào)整平衡因子 121 * → 40 → 40 122 * /=\ /=\ 123 * 20 50 20 50 124 * /=\ /L\ /L\ /=\ 125 * 10 30 45 90 10 30 45 90 126 * /=\ /= /=\ /=\ /L /=\ 127 * 5 15 42 70 100 5 15 42 70 100 128 * = = = = = = = = = = 129 * 130 */ 131 ancestor.parent.left.balanceFactor = 'L'; 132 133 ancestor.balanceFactor = '='; 134 //調(diào)整ancestor節(jié)點到插入點路徑上節(jié)點平衡因子 135 adjustPath(ancestor, inserted); 136 } 137 } 138 139 /** 140 * 進行 右-左旋轉(zhuǎn) 后平衡因子調(diào)整 141 * 142 * 與adjustLeftRigth方法一樣,也有三種情況,這兩個方法是對稱的 143 * @param ancestor 144 * @param inserted 145 */ 146 protected void adjustRigthLeft(Entry<E> ancestor, Entry<E> inserted) { 147 E elem = inserted.elem; 148 if (ancestor.parent == inserted) { 149 /* 150 * 第1種,新增的節(jié)點在旋轉(zhuǎn)完成后為ancestor父節(jié)點情況: 151 * 152 * 新增40 繞50右旋 繞30左旋 153 * → 30 ← ancestor → 30 → 154 * R\ R\ 155 * 50 40 156 * /= =\ 157 * 40 50 158 * = = 159 * 160 * 40 調(diào)整平衡因子 40 161 * /=\ → /=\ 162 * 30 50 30 50 163 * R = = = 164 * 165 * 注,這里的 右-左旋 是在fixAfterInsertion方法中的第6種情況中完成的,這里只是 平衡因子的調(diào) 166 * 整,圖是為了好說明問題而放在這個方法中的,下面的兩個分支也是一樣 167 */ 168 ancestor.balanceFactor = '='; 169 } else if (elem.compareTo(ancestor.parent.elem) > 0) { 170 /* 171 * 第2種,新增的節(jié)點在旋轉(zhuǎn)完成后為不為ancestor父節(jié)點,且新增節(jié)點比旋轉(zhuǎn)后 172 * ancestor的父節(jié)點要大的情況 173 * 174 * 由于插入元素(73)比旋轉(zhuǎn)后ancestor(50)的父節(jié)點(70)要大, 所以新增節(jié)點會 175 * 在其右子樹中 176 * 177 * 新增73 繞90右旋 178 * → 50 ← ancestor → 50 179 * /R\ /R\ 180 * 20 90 20 70 181 * /=\ /=\ /=\ /=\ 182 * 10 40 70 95 10 40 65 90 183 * = = /=\ /=\ = = = /=\ 184 * 65 75 93 97 75 95 185 * = /= = = /= /=\ 186 * 73 73 93 97 187 * = 188 * 189 * 繞50左旋 調(diào)整平衡因子 190 * → 70 → 70 191 * /=\ /=\ 192 * 50 90 50 90 193 * /R\ /=\ /L\ /=\ 194 * 20 65 75 95 20 65 75 95 195 * /=\ = /= /=\ /=\ = /L /=\ 196 * 10 40 73 93 97 10 40 73 93 97 197 * = = = = = = = = = = 198 * 199 */ 200 ancestor.balanceFactor = 'L'; 201 adjustPath(ancestor.parent.right, inserted); 202 } else { 203 /* 204 * 第2種,新增的節(jié)點在旋轉(zhuǎn)完成后為不為ancestor父節(jié)點,且新增節(jié)點比旋轉(zhuǎn)后ancestor的父節(jié)點要小 205 * 的情況 206 * 207 * 由于插入元素(73)比旋轉(zhuǎn)后ancestor(50)的父節(jié)點(70)要大, 所以新增節(jié)點會在其右子樹中 208 * 209 * 新增63 繞90右旋 210 * → 50 ← ancestor → 50 211 * /R\ /R\ 212 * 20 90 20 70 213 * /=\ /=\ /=\ /=\ 214 * 10 40 70 95 10 40 65 90 215 * = = /=\ /=\ = = /= /=\ 216 * 65 75 93 97 63 75 95 217 * /= = = = = = /=\ 218 * 63 93 97 219 * = = = 220 * 221 * 繞50左旋 調(diào)整平衡因子 222 * → 70 → 70 223 * /=\ /=\ 224 * 50 90 50 90 225 * /R\ /=\ /=\ /R\ 226 * 20 65 75 95 20 65 75 95 227 * /=\ /= = /=\ /=\ /L /=\ 228 * 10 40 63 93 97 10 40 63 93 97 229 * = = = = = = = = = = 230 */ 231 ancestor.parent.right.balanceFactor = 'R'; 232 ancestor.balanceFactor = '='; 233 adjustPath(ancestor, inserted); 234 } 235 } 236 237 /** 238 * 刪除指定節(jié)點 239 * 240 * @param elem 241 * @return boolean 242 */ 243 public boolean remove(E elem) { 244 Entry<E> e = getEntry(elem); 245 if (e == null) 246 return false; 247 deleteEntry(e); 248 return true; 249 } 250 251 private Entry<E> getEntry(E e) { 252 Entry<E> tmp = root; 253 int c; 254 while (tmp != null) { 255 c = e.compareTo(tmp.elem); 256 if (c == 0) { 257 return tmp; 258 } else if (c < 0) { 259 tmp = tmp.left; 260 } else { 261 tmp = tmp.right; 262 } 263 } 264 return null; 265 } 266 267 private void deleteEntry(Entry<E> p) { 268 if (p.left != null && p.right != null) { 269 270 Entry<E> s = successor(p); 271 272 p.elem = s.elem; 273 274 p = s; 275 } 276 277 if (p.left == null && p.right == null) { 278 279 if (p.parent == null) { 280 root = null; 281 } else if (p == p.parent.left) { 282 p.parent.left = null; 283 } else { 284 p.parent.right = null; 285 } 286 287 } else { 288 289 Entry<E> rep; 290 if (p.left != null) { 291 rep = p.left; 292 } else { 293 rep = p.right; 294 } 295 296 rep.parent = p.parent; 297 298 if (p.parent == null) { 299 root = rep; 300 } else if (p == p.parent.left) { 301 p.parent.left = rep; 302 } else { 303 p.parent.right = rep; 304 } 305 306 } 307 fixAfterDeletion(p.elem, p.parent); 308 309 p.parent = null; 310 p.left = null; 311 p.right = null; 312 313 size--; 314 } 315 316 /** 317 * 查找指定節(jié)點的中序遍歷序列的直接后繼節(jié)點,此方法的實現(xiàn)與二叉搜索樹類(BinSearchTree.java)的此方法是 318 * 一樣的,具體的思路請參考二叉搜索樹類中的相應方法 319 * 320 * @param e 需要查找哪個節(jié)點的直接后繼節(jié)點 321 * @return Entry<E> 直接后繼節(jié)點 322 */ 323 private Entry<E> successor(Entry<E> e) { 324 if (e == null) { 325 return null; 326 }//如果待找的節(jié)點有右子樹,則在右子樹上查找 327 else if (e.right != null) { 328 //默認后繼節(jié)點為右子節(jié)點(如果右子節(jié)點沒有左子樹時即為該節(jié)點) 329 Entry<E> p = e.right; 330 while (p.left != null) { 331 //注,如果右子節(jié)點的左子樹不為空,則在左子樹中查找,且后面找時要一直向左拐 332 p = p.left; 333 } 334 return p; 335 }//如果待查節(jié)點沒有右子樹,則要在祖宗節(jié)點中查找后繼節(jié)點 336 else { 337 338 //默認后繼節(jié)點為父節(jié)點(如果待查節(jié)點為父節(jié)點的左子樹,則后繼為父節(jié)點) 339 Entry<E> p = e.parent; 340 Entry<E> c = e;//當前節(jié)點,如果其父不為后繼,則下次指向父節(jié)點 341 //如果待查節(jié)點為父節(jié)點的右節(jié)點時,繼續(xù)向上找,一直要找到c為左子節(jié)點,則p才是后繼 342 while (p != null && c == p.right) { 343 c = p; 344 p = p.parent; 345 } 346 return p; 347 } 348 }

?

1 /** 2 * 刪除節(jié)點后平衡調(diào)整實現(xiàn) 3 * 4 * @param elem 被刪除節(jié)點的數(shù)據(jù)域 5 * @param ancestor 被刪除節(jié)點的祖先節(jié)點,從父節(jié)點向上迭代 6 */ 7 protected void fixAfterDeletion(E elem, Entry<E> ancestor) { 8 9 boolean heightHasDecreased = true;//樹的高度是否還需要減小 10 11 /* 12 * 1、如果刪除的是根節(jié)點,則ancestor為空,此時不需調(diào)整了,直接退出 13 * 2、如果刪除的不是根節(jié)點,且根節(jié)點都已調(diào)整,則退出 14 * 3、如果刪除的不是根節(jié)點,且樹的高度不需再減小(heightHasDecreased為false),退出 15 */ 16 while (ancestor != null && heightHasDecreased) { 17 18 int comp = elem.compareTo(ancestor.elem); 19 20 /* 21 * 當要刪除的節(jié)點有左右子樹時,comp就會等于0,比如下面要刪除33這個節(jié)點,刪除方法deleteEntry 22 * 會用36替換掉33節(jié)點中的數(shù)據(jù)的elem,刪除后會調(diào)用fixAfterDeletion(p.elem, p.parent)方 23 * 法來調(diào)整平衡因子,p又是指向的36,所以p.elem與p.parent.elem是相等的,都是36 24 * 25 * 82 26 * /L\ 27 * 42 95 28 * /=\ R\ 29 * 33 48 96 30 * /=\ /=\ 31 * 29 36 43 75 32 */ 33 34 //從ancestor的右子樹中刪除節(jié)點 35 if (comp >= 0) { 36 // ancestor 的平衡因子為 '=' 37 if (ancestor.balanceFactor == '=') { 38 39 /* 刪除15 調(diào)整因子 40 * 20 → 20 41 * /L\ /L\ 42 * → 10 50 10 50 43 * /=\ /L 44 * 5 15 5 45 */ 46 ancestor.balanceFactor = 'L'; 47 heightHasDecreased = false; 48 49 } // ancestor 的平衡因子為 'R' 50 else if (ancestor.balanceFactor == 'R') { 51 /* 刪除15 調(diào)整因子 下次循環(huán)調(diào)整20的因子 52 * 20 → → 20 ← ancestor → ... 53 * /L\ /L\ 54 * → 10 50 10 50 55 * /R\ R\ /=\ R\ 56 * 5 15 60 5 18 60 57 * R\ 58 * 18 59 */ 60 ancestor.balanceFactor = '='; 61 ancestor = ancestor.parent; 62 63 }// ancestor 的平衡因子為 'L' 64 else if (ancestor.balanceFactor == 'L') { 65 // ancestor 的左子節(jié)點平衡因子為 '=' 66 if (ancestor.left.balanceFactor == '=') { 67 68 /* 刪除60 調(diào)整因子 繞50右旋 69 * 20 → → 20 → 20 70 * /R\ / \ /R\ 71 * 10 50 ← ancestor 10 50 ← 10 45 72 * /L /L\ / /L\ /L /R\ 73 * 5 45 60 5 45 60 5 35 50 ← 74 * /=\ /R\ /L 75 * 35 48 35 48 48 76 */ 77 ancestor.left.balanceFactor = 'R'; 78 ancestor.balanceFactor = 'L'; 79 rotateRight(ancestor); 80 heightHasDecreased = false; 81 82 }// ancestor 的左子節(jié)點平衡因子為 'L' 83 else if (ancestor.left.balanceFactor == 'L') { 84 85 /* 刪除60 調(diào)整因子 繞50右旋 下次循環(huán)調(diào)整20的因子 86 * 20 → → 20 → 20 ← p → ... 87 * /R\ / \ /R\ 88 * 10 50 ← ancestor 10 50 ← 10 45 89 * /L /L\ / /=\ /L /=\ 90 * 5 45 60 5 45 60 5 35 50 ← ancestor 91 * /L /= = 92 * 35 35 93 */ 94 Entry<E> p = ancestor.parent; 95 ancestor.balanceFactor = '='; 96 ancestor.left.balanceFactor = '='; 97 rotateRight(ancestor); 98 ancestor = p; 99 100 } // ancestor 的左子節(jié)點平衡因子為 'R' 101 else if (ancestor.left.balanceFactor == 'R') { 102 103 Entry<E> p = ancestor.parent; 104 105 // ancestor 的左子節(jié)點的右子節(jié)點的平衡因子為 'L' 106 if (ancestor.left.right.balanceFactor == 'L') { 107 108 /* 刪除60 調(diào)整因子 109 * 20 → 20 110 * /R\ / \ 111 * 10 50 ← ancestor 10 50 ← ancestor 112 * /L\ /L\ / \ /R\ 113 * 5 12 45 60 5 12 45 70 114 * /L /R\ R\ / /=\ 115 * 3 42 48 70 3 42 48 116 * /L /= 117 * 46 46 118 * 119 * 繞45左旋 繞50右旋 下次循環(huán)調(diào)整20的因子 120 * → 20 → 20 ← p → ... 121 * /R\ /R\ 122 * 10 50 ← 10 48 123 * /L\ /R\ /L\ /=\ 124 * 5 12 48 70 5 12 45 50 ← ancestor 125 * /L /= /L /=\ R\ 126 * 3 45 3 42 46 70 127 * /=\ 128 * 42 46 129 */ 130 ancestor.balanceFactor = 'R'; 131 ancestor.left.balanceFactor = '='; 132 133 }// ancestor 的左子節(jié)點的右子節(jié)點的平衡因子為 'R' 134 else if (ancestor.left.right.balanceFactor == 'R') { 135 136 /* 刪除60 調(diào)整因子 137 * 20 → 20 138 * /R\ / \ 139 * 10 50 ← ancestor 10 50 ← 140 * /L\ /L\ / \ /=\ 141 * 5 12 45 60 5 12 45 70 142 * /L /R\ R\ / /L\ 143 * 3 42 48 70 3 42 48 144 * R\ =\ 145 * 49 49 146 * 147 * 繞45左旋 繞50右旋 下次循環(huán)調(diào)整20的因子 148 * → 20 → 20 ← p → ... 149 * /R\ /R\ 150 * 10 50 ← 10 48 151 * /L\ /=\ /L\ /=\ 152 * 5 12 48 70 5 12 45 50 ← ancestor 153 * /L /=\ /L /L /=\ 154 * 3 45 49 3 42 49 70 155 * /L 156 * 42 157 */ 158 ancestor.balanceFactor = '='; 159 ancestor.left.balanceFactor = 'L'; 160 161 }// ancestor 的左子節(jié)點的右子節(jié)點的平衡因子為 '=' 162 else { 163 /* 刪除60 調(diào)整因子 164 * 20 → 20 165 * /R\ / \ 166 * 10 50 ← ancestor 10 50 ← 167 * /L\ /L\ / \ /=\ 168 * 5 12 45 60 5 12 45 70 169 * /L /R\ R\ / /=\ 170 * 3 42 48 70 3 42 48 171 * /=\ /=\ 172 * 46 49 46 49 173 * 174 * 繞45左旋 繞50右旋 下次循環(huán)調(diào)整20的因子 175 * → 20 → 20 ← p → ... 176 * /R\ /R\ 177 * 10 50 ← 10 48 178 * /L\ /=\ /L\ /=\ 179 * 5 12 48 70 5 12 45 50 ← ancestor 180 * /L /=\ /L /=\ /=\ 181 * 3 45 49 3 42 46 49 70 182 * /=\ 183 * 42 46 184 */ 185 ancestor.balanceFactor = '='; 186 ancestor.left.balanceFactor = '='; 187 188 } 189 ancestor.left.right.balanceFactor = '='; 190 rotateLeft(ancestor.left); 191 rotateRight(ancestor); 192 ancestor = p; 193 } 194 } 195 196 } 197 //從ancestor的左子樹中刪除節(jié)點,與上面是對稱的 198 else if (comp < 0) { 199 200 if (ancestor.balanceFactor == '=') { 201 202 ancestor.balanceFactor = 'R'; 203 heightHasDecreased = false; 204 } else if (ancestor.balanceFactor == 'L') { 205 206 ancestor.balanceFactor = '='; 207 ancestor = ancestor.parent; 208 209 } else if (ancestor.balanceFactor == 'R') { 210 211 if (ancestor.right.balanceFactor == '=') { 212 213 ancestor.balanceFactor = 'R'; 214 ancestor.right.balanceFactor = 'L'; 215 rotateLeft(ancestor); 216 heightHasDecreased = false; 217 218 } else if (ancestor.right.balanceFactor == 'R') { 219 220 Entry<E> p = ancestor.parent; 221 ancestor.balanceFactor = '='; 222 ancestor.right.balanceFactor = '='; 223 rotateLeft(ancestor); 224 ancestor = p; 225 226 } else if (ancestor.right.balanceFactor == 'L') { 227 228 Entry<E> p = ancestor.parent; 229 if (ancestor.right.left.balanceFactor == 'R') { 230 231 ancestor.balanceFactor = 'L'; 232 ancestor.right.balanceFactor = '='; 233 234 } else if (ancestor.right.left.balanceFactor == 'L') { 235 236 ancestor.balanceFactor = '='; 237 ancestor.right.balanceFactor = 'R'; 238 239 } else { 240 241 ancestor.balanceFactor = '='; 242 ancestor.right.balanceFactor = '='; 243 244 } 245 ancestor.right.left.balanceFactor = '='; 246 rotateRight(ancestor.right); 247 rotateLeft(ancestor); 248 ancestor = p; 249 250 } 251 } 252 } 253 } 254 } 255 256 public boolean contains(E o) { 257 258 Entry<E> e = root; 259 260 int comp; 261 262 while (e != null) { 263 264 comp = o.compareTo(e.elem); 265 if (comp == 0) 266 return true; 267 else if (comp < 0) 268 e = e.left; 269 else 270 e = e.right; 271 272 } 273 return false; 274 } 275 276 //驗證樹是否是平衡二叉樹 277 public boolean isAVL() { 278 279 return checkAVL(root); 280 281 } 282 283 /** 284 * 驗證指定的樹是否是平衡二叉樹 285 * @param p 286 * @return 287 */ 288 public static <E extends Comparable<E>> boolean checkAVL(Entry<E> p) { 289 290 if (p == null) 291 return true; 292 //左子樹與右子樹絕對值不能超過 1,并且左右子樹也是平衡二叉樹 293 return (Math.abs(h(p.left) - h(p.right)) <= 1 && checkAVL(p.left) && checkAVL(p.right)); 294 295 } 296 297 /** 298 * 求指定節(jié)點的高度 299 * @param <E> 300 * @param p 301 * @return 302 */ 303 protected static <E extends Comparable<E>> int h(Entry<E> p) { 304 305 if (p == null) 306 return -1; 307 return 1 + Math.max(h(p.left), h(p.right)); 308 } 309 310 /** 311 * 樹的高度 312 * @return 313 */ 314 public int height() { 315 316 return h(root); 317 318 } 319 320 //樹的高度非遞歸求法 321 public int heightIter() { 322 323 int height = -1; 324 for (Entry<E> temp = root; temp != null; height++) 325 if (temp.balanceFactor == 'L') 326 temp = temp.left; 327 else 328 temp = temp.right; 329 return height; 330 } 331 332 @Override 333 public Iterator<E> iterator() { 334 return new TreeIterator(); 335 } 336 337 @Override 338 public int size() { 339 return size; 340 } 341 }

測試:

1 package tree.avl; 2 3 import java.util.Iterator; 4 import java.util.Random; 5 6 public class AVLTreeTest { 7 public static void main(String[] args) { 8 AVLTree myTree = new AVLTree(); 9 Random random = new Random(); 10 System.out.print("隨機產(chǎn)生的節(jié)點為:"); 11 int num = 0; 12 //直到樹的節(jié)點數(shù)為n止 13 while (myTree.size() < 10) { 14 num = new Integer(random.nextInt(100)); 15 myTree.add(num); 16 System.out.print(num + " "); 17 } 18 System.out.println(""); 19 if (myTree.isAVL()) { 20 System.out.println("這棵平衡二叉樹的總節(jié)點數(shù):" + myTree.size()); 21 System.out.println("這棵平衡二叉樹的高度是:" + myTree.height()); 22 System.out.println("在樹中查找 " + num + " 節(jié)點:" 23 + myTree.contains(new Integer(num))); 24 System.out.println("在樹中查找 100 節(jié)點:" + myTree.contains(new Integer(100))); 25 System.out.print("中序遍歷:"); 26 Iterator itr = myTree.iterator(); 27 while (itr.hasNext()) { 28 System.out.print(itr.next() + " "); 29 } 30 System.out.println(""); 31 32 myTree.remove(num); 33 System.out.print("刪除節(jié)點 " + num + " 后遍歷:"); 34 itr = myTree.iterator(); 35 while (itr.hasNext()) { 36 System.out.print(itr.next() + " "); 37 } 38 System.out.println(""); 39 40 System.out.println("使用迭代器刪除所有節(jié)點"); 41 itr = myTree.iterator(); 42 while (itr.hasNext()) { 43 itr.next(); 44 itr.remove(); 45 } 46 System.out.println("刪除后樹的總節(jié)點數(shù):" + myTree.size()); 47 } else { 48 System.out.println("failure"); 49 } 50 } 51 }

轉(zhuǎn)載于:https://www.cnblogs.com/jiangzhengjun/p/4289792.html

總結

以上是生活随笔為你收集整理的[数据结构与算法]平衡二叉树实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

高中生自慰www网站 | 波多野结衣高清一区二区三区 | 无码帝国www无码专区色综合 | 999久久久国产精品消防器材 | 人人爽人人澡人人高潮 | 色综合久久久久综合一本到桃花网 | 午夜理论片yy44880影院 | 男女猛烈xx00免费视频试看 | 欧美 亚洲 国产 另类 | 色妞www精品免费视频 | 97se亚洲精品一区 | 波多野结衣一区二区三区av免费 | 国产区女主播在线观看 | 亚洲综合无码一区二区三区 | 国产精品第一区揄拍无码 | 日本乱偷人妻中文字幕 | 婷婷丁香五月天综合东京热 | 人妻中文无码久热丝袜 | 国产精品久久国产三级国 | 日韩 欧美 动漫 国产 制服 | 真人与拘做受免费视频一 | 亚洲va中文字幕无码久久不卡 | 国产无遮挡又黄又爽免费视频 | 老熟妇乱子伦牲交视频 | 一本久久a久久精品vr综合 | 红桃av一区二区三区在线无码av | 在线а√天堂中文官网 | 一本精品99久久精品77 | 久久久久成人精品免费播放动漫 | 一本久道高清无码视频 | 曰本女人与公拘交酡免费视频 | 好男人www社区 | 日本va欧美va欧美va精品 | 色综合视频一区二区三区 | 香蕉久久久久久av成人 | 亚洲综合在线一区二区三区 | 少妇性l交大片欧洲热妇乱xxx | 国产在线精品一区二区高清不卡 | 亚洲精品国产第一综合99久久 | 国产亚洲精品久久久久久久久动漫 | 国产精品成人av在线观看 | 欧美日韩综合一区二区三区 | 性开放的女人aaa片 | 未满成年国产在线观看 | 亚洲精品久久久久avwww潮水 | 无码av中文字幕免费放 | 麻豆蜜桃av蜜臀av色欲av | 色 综合 欧美 亚洲 国产 | 正在播放老肥熟妇露脸 | 日日鲁鲁鲁夜夜爽爽狠狠 | 色诱久久久久综合网ywww | 天天拍夜夜添久久精品大 | 玩弄中年熟妇正在播放 | 中文字幕精品av一区二区五区 | 日日噜噜噜噜夜夜爽亚洲精品 | 中文字幕乱码人妻二区三区 | 亚洲区小说区激情区图片区 | 中文无码精品a∨在线观看不卡 | 乱码av麻豆丝袜熟女系列 | 亚洲国产一区二区三区在线观看 | 男人的天堂av网站 | 国产精品国产三级国产专播 | 西西人体www44rt大胆高清 | 99精品无人区乱码1区2区3区 | 久久久精品456亚洲影院 | 亚洲国产精品一区二区美利坚 | 国产超碰人人爽人人做人人添 | 中文久久乱码一区二区 | 牛和人交xxxx欧美 | 日韩av无码一区二区三区不卡 | 亚洲中文字幕在线观看 | 日本免费一区二区三区最新 | 亚洲精品久久久久中文第一幕 | av无码久久久久不卡免费网站 | 美女张开腿让人桶 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲国产成人a精品不卡在线 | 四虎永久在线精品免费网址 | 少妇久久久久久人妻无码 | 色一情一乱一伦一视频免费看 | 大肉大捧一进一出好爽视频 | 国产精品国产自线拍免费软件 | 天天综合网天天综合色 | 性欧美牲交在线视频 | 无码毛片视频一区二区本码 | 亚洲中文字幕无码中文字在线 | 毛片内射-百度 | 无码国产激情在线观看 | 亚洲色欲色欲欲www在线 | 97精品人妻一区二区三区香蕉 | 国产欧美熟妇另类久久久 | 亚洲国产午夜精品理论片 | 亚洲欧美精品aaaaaa片 | 波多野42部无码喷潮在线 | 亚洲中文字幕在线无码一区二区 | 性欧美videos高清精品 | 亚洲码国产精品高潮在线 | 亚洲成av人影院在线观看 | 少妇人妻偷人精品无码视频 | 国产亚洲精品久久久久久国模美 | 久精品国产欧美亚洲色aⅴ大片 | 久久精品国产大片免费观看 | 永久免费精品精品永久-夜色 | 亚洲精品午夜国产va久久成人 | 国产免费无码一区二区视频 | 欧美熟妇另类久久久久久多毛 | 波多野结衣av在线观看 | 国产人妻精品一区二区三区不卡 | 野外少妇愉情中文字幕 | 久久精品一区二区三区四区 | 99久久婷婷国产综合精品青草免费 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲 欧美 激情 小说 另类 | 天天拍夜夜添久久精品 | 日韩精品久久久肉伦网站 | 国产超碰人人爽人人做人人添 | 国产麻豆精品一区二区三区v视界 | 秋霞成人午夜鲁丝一区二区三区 | 欧美xxxx黑人又粗又长 | 色五月丁香五月综合五月 | 奇米影视7777久久精品 | 精品无码av一区二区三区 | 一个人免费观看的www视频 | 精品一区二区三区无码免费视频 | 无码人妻av免费一区二区三区 | 狠狠亚洲超碰狼人久久 | 久久久精品456亚洲影院 | 免费播放一区二区三区 | 国产麻豆精品一区二区三区v视界 | 国产亚洲精品久久久ai换 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲欧美综合区丁香五月小说 | 欧美成人高清在线播放 | 男女超爽视频免费播放 | 亚洲欧洲中文日韩av乱码 | 无码人妻黑人中文字幕 | 久久久久国色av免费观看性色 | 成人欧美一区二区三区黑人免费 | 亚洲欧洲中文日韩av乱码 | 狠狠噜狠狠狠狠丁香五月 | 中文亚洲成a人片在线观看 | 日本一区二区三区免费播放 | 欧美成人家庭影院 | 中文字幕乱码人妻无码久久 | 动漫av网站免费观看 | 高潮毛片无遮挡高清免费视频 | 少妇被黑人到高潮喷出白浆 | 成熟女人特级毛片www免费 | 最近免费中文字幕中文高清百度 | 久久国产精品二国产精品 | 久久精品人人做人人综合 | 极品尤物被啪到呻吟喷水 | 一本大道伊人av久久综合 | 免费国产成人高清在线观看网站 | 精品国产一区二区三区av 性色 | 妺妺窝人体色www在线小说 | 免费无码av一区二区 | 无码人妻av免费一区二区三区 | 九九在线中文字幕无码 | 久久国语露脸国产精品电影 | 精品人妻人人做人人爽夜夜爽 | 狠狠cao日日穞夜夜穞av | 色欲久久久天天天综合网精品 | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久99精品久久久久久 | 露脸叫床粗话东北少妇 | 一个人看的视频www在线 | 色婷婷欧美在线播放内射 | 成人aaa片一区国产精品 | 午夜精品一区二区三区的区别 | 性做久久久久久久免费看 | 亚洲午夜福利在线观看 | 麻豆精品国产精华精华液好用吗 | 亚洲精品国偷拍自产在线麻豆 | 久久这里只有精品视频9 | 97资源共享在线视频 | 国内综合精品午夜久久资源 | 99久久精品无码一区二区毛片 | www国产亚洲精品久久久日本 | 极品嫩模高潮叫床 | 国产精品国产自线拍免费软件 | 国产精品久久久av久久久 | 国产97色在线 | 免 | 久久久久久久人妻无码中文字幕爆 | 国产亚洲精品久久久久久久久动漫 | 久久亚洲中文字幕精品一区 | 欧美性黑人极品hd | 伊人久久大香线蕉av一区二区 | 国产人妻精品一区二区三区不卡 | 精品一区二区不卡无码av | 国产在线一区二区三区四区五区 | 少妇激情av一区二区 | 色一情一乱一伦一区二区三欧美 | 国产一区二区不卡老阿姨 | 国产一区二区不卡老阿姨 | 午夜时刻免费入口 | 人妻少妇精品久久 | 亚洲va欧美va天堂v国产综合 | 亚洲一区二区三区国产精华液 | 国产偷国产偷精品高清尤物 | 天天摸天天碰天天添 | 国产精品亚洲专区无码不卡 | 亚洲熟妇自偷自拍另类 | 国内少妇偷人精品视频免费 | 青草青草久热国产精品 | 国产真实乱对白精彩久久 | 国产美女精品一区二区三区 | 18黄暴禁片在线观看 | 国产电影无码午夜在线播放 | 99久久久国产精品无码免费 | 中文字幕乱码人妻无码久久 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲另类伦春色综合小说 | 97无码免费人妻超级碰碰夜夜 | 欧美熟妇另类久久久久久多毛 | 熟女体下毛毛黑森林 | 精品国产aⅴ无码一区二区 | 强奷人妻日本中文字幕 | 99riav国产精品视频 | 99久久久无码国产aaa精品 | 丰满岳乱妇在线观看中字无码 | 青青青手机频在线观看 | 无码人妻精品一区二区三区不卡 | 成年女人永久免费看片 | 久久久精品人妻久久影视 | 任你躁国产自任一区二区三区 | 久久精品人妻少妇一区二区三区 | 男人和女人高潮免费网站 | 理论片87福利理论电影 | 人妻少妇被猛烈进入中文字幕 | 青青青手机频在线观看 | 中国女人内谢69xxxxxa片 | 亚洲精品成人福利网站 | 久久久久亚洲精品中文字幕 | 欧美丰满少妇xxxx性 | 国产乱人无码伦av在线a | 亚洲国产精品一区二区美利坚 | 久久国产精品二国产精品 | a国产一区二区免费入口 | 麻豆成人精品国产免费 | 国产明星裸体无码xxxx视频 | 国产熟妇另类久久久久 | 精品国精品国产自在久国产87 | 国产av久久久久精东av | 国产另类ts人妖一区二区 | 久久99久久99精品中文字幕 | 又粗又大又硬毛片免费看 | 国产精品久久国产精品99 | 亚洲国产精品久久人人爱 | 国产精品第一国产精品 | 欧美国产日韩久久mv | 99久久久无码国产aaa精品 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产色视频一区二区三区 | 麻豆精品国产精华精华液好用吗 | 激情爆乳一区二区三区 | 天下第一社区视频www日本 | 国产婷婷色一区二区三区在线 | 中国女人内谢69xxxxxa片 | 国产精品99爱免费视频 | 亚洲aⅴ无码成人网站国产app | 两性色午夜视频免费播放 | 亚洲中文字幕在线无码一区二区 | 亚洲精品一区二区三区四区五区 | 妺妺窝人体色www在线小说 | av香港经典三级级 在线 | 国产电影无码午夜在线播放 | 欧美三级不卡在线观看 | 亚洲天堂2017无码中文 | 久久久久久久人妻无码中文字幕爆 | 国产成人人人97超碰超爽8 | 亚洲成a人片在线观看无码 | 免费人成在线视频无码 | 久久精品中文字幕一区 | 中文字幕久久久久人妻 | 国产无遮挡吃胸膜奶免费看 | 亚洲国产精品久久久久久 | 国产熟女一区二区三区四区五区 | 中文字幕人成乱码熟女app | 亚洲国产成人av在线观看 | 国产在线无码精品电影网 | 久久久精品欧美一区二区免费 | 久久久精品国产sm最大网站 | 国产无遮挡又黄又爽又色 | 乱码午夜-极国产极内射 | 亚洲熟悉妇女xxx妇女av | 大地资源中文第3页 | 亲嘴扒胸摸屁股激烈网站 | 又大又硬又爽免费视频 | 成人欧美一区二区三区 | 蜜桃臀无码内射一区二区三区 | 亚洲色www成人永久网址 | 精品久久久久香蕉网 | 无码人妻少妇伦在线电影 | 荫蒂被男人添的好舒服爽免费视频 | 国产亚洲日韩欧美另类第八页 | 少女韩国电视剧在线观看完整 | 人妻中文无码久热丝袜 | 国产精品对白交换视频 | 亚洲综合无码久久精品综合 | 国产精品久久久av久久久 | 亚洲日韩乱码中文无码蜜桃臀网站 | 天海翼激烈高潮到腰振不止 | 日韩精品成人一区二区三区 | 国产精品香蕉在线观看 | 99国产欧美久久久精品 | 日本一区二区更新不卡 | 国产三级久久久精品麻豆三级 | 亚洲国产av精品一区二区蜜芽 | 国产精品无码成人午夜电影 | 毛片内射-百度 | 亚洲日韩一区二区 | 国产激情无码一区二区app | 扒开双腿吃奶呻吟做受视频 | 日韩精品一区二区av在线 | 国产成人无码av一区二区 | 色五月五月丁香亚洲综合网 | 亚洲中文字幕av在天堂 | 亚洲成av人在线观看网址 | 色婷婷综合激情综在线播放 | 一本久久伊人热热精品中文字幕 | 少妇性荡欲午夜性开放视频剧场 | аⅴ资源天堂资源库在线 | 精品一区二区三区无码免费视频 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久久久99精品成人片 | 在线观看免费人成视频 | 欧美zoozzooz性欧美 | 少妇无套内谢久久久久 | 人妻aⅴ无码一区二区三区 | 久久亚洲中文字幕无码 | 国产成人精品久久亚洲高清不卡 | 久久无码中文字幕免费影院蜜桃 | 亚洲啪av永久无码精品放毛片 | 午夜福利不卡在线视频 | √天堂资源地址中文在线 | 国产精品亚洲专区无码不卡 | 中文字幕精品av一区二区五区 | 18黄暴禁片在线观看 | 亚洲欧美中文字幕5发布 | 日本一本二本三区免费 | 久久精品丝袜高跟鞋 | 久久aⅴ免费观看 | 一本色道久久综合狠狠躁 | 小泽玛莉亚一区二区视频在线 | 丰满人妻精品国产99aⅴ | 一本无码人妻在中文字幕免费 | 麻豆av传媒蜜桃天美传媒 | 麻豆国产人妻欲求不满 | 亚洲成av人片天堂网无码】 | av在线亚洲欧洲日产一区二区 | 亚洲日韩中文字幕在线播放 | 色综合久久88色综合天天 | 久久zyz资源站无码中文动漫 | 全球成人中文在线 | 中文字幕无码免费久久99 | 国产精品亚洲а∨无码播放麻豆 | 九九热爱视频精品 | 麻豆国产丝袜白领秘书在线观看 | 性欧美牲交xxxxx视频 | 女人被男人爽到呻吟的视频 | 少妇高潮喷潮久久久影院 | 国产偷抇久久精品a片69 | 午夜理论片yy44880影院 | 亚洲国产欧美国产综合一区 | 亚洲精品久久久久中文第一幕 | 色欲人妻aaaaaaa无码 | 无遮无挡爽爽免费视频 | 国产一区二区三区四区五区加勒比 | 乱人伦人妻中文字幕无码 | 国产在线无码精品电影网 | 日本熟妇大屁股人妻 | 牲欲强的熟妇农村老妇女视频 | 国产绳艺sm调教室论坛 | 无码吃奶揉捏奶头高潮视频 | 久久久久久国产精品无码下载 | 熟妇人妻无乱码中文字幕 | 亚洲综合精品香蕉久久网 | 欧美丰满少妇xxxx性 | 久久久av男人的天堂 | 丰满人妻精品国产99aⅴ | 精品乱子伦一区二区三区 | 久久视频在线观看精品 | 国产三级久久久精品麻豆三级 | 国产日产欧产精品精品app | 呦交小u女精品视频 | 亚洲色www成人永久网址 | 国内老熟妇对白xxxxhd | 丰满护士巨好爽好大乳 | 免费无码肉片在线观看 | 无码福利日韩神码福利片 | 国产成人无码a区在线观看视频app | 亚洲午夜无码久久 | 欧美丰满熟妇xxxx | 亚洲日韩精品欧美一区二区 | 国产一精品一av一免费 | 国产情侣作爱视频免费观看 | 精品久久综合1区2区3区激情 | 久久99久久99精品中文字幕 | 精品一区二区三区无码免费视频 | 色综合天天综合狠狠爱 | 亚洲 激情 小说 另类 欧美 | 377p欧洲日本亚洲大胆 | 精品日本一区二区三区在线观看 | 国产一区二区三区四区五区加勒比 | 中文字幕无码免费久久9一区9 | 人人妻人人澡人人爽人人精品 | 国产精品人人妻人人爽 | 天堂亚洲2017在线观看 | 国内揄拍国内精品少妇国语 | 色综合天天综合狠狠爱 | 成 人 网 站国产免费观看 | 黑人粗大猛烈进出高潮视频 | 亚洲国产精品美女久久久久 | 欧美自拍另类欧美综合图片区 | 亚洲精品国偷拍自产在线观看蜜桃 | 日韩av无码一区二区三区不卡 | 无套内谢老熟女 | 熟妇人妻激情偷爽文 | 亚洲а∨天堂久久精品2021 | 中文字幕无码日韩专区 | 无码任你躁久久久久久久 | 在线精品亚洲一区二区 | 亚洲一区二区三区无码久久 | 全球成人中文在线 | 成人一在线视频日韩国产 | 丰满少妇女裸体bbw | 午夜不卡av免费 一本久久a久久精品vr综合 | 欧美日韩在线亚洲综合国产人 | 亚洲成a人一区二区三区 | 亚洲中文字幕成人无码 | 丰满人妻翻云覆雨呻吟视频 | 2019nv天堂香蕉在线观看 | 300部国产真实乱 | 午夜无码区在线观看 | 无码人妻av免费一区二区三区 | 国产精品无码久久av | 亚洲 激情 小说 另类 欧美 | 色综合天天综合狠狠爱 | 精品国产国产综合精品 | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久www免费人成人片 | 国产深夜福利视频在线 | 国产精品亚洲综合色区韩国 | 1000部夫妻午夜免费 | 久久久久免费精品国产 | 色综合久久久久综合一本到桃花网 | 国产suv精品一区二区五 | 在线精品亚洲一区二区 | 亚洲一区av无码专区在线观看 | 精品无码成人片一区二区98 | 老熟妇仑乱视频一区二区 | 成在人线av无码免观看麻豆 | 日韩av无码一区二区三区 | 国内老熟妇对白xxxxhd | 精品无码成人片一区二区98 | 最近中文2019字幕第二页 | 一个人看的视频www在线 | 中文字幕 亚洲精品 第1页 | 麻豆精品国产精华精华液好用吗 | 99re在线播放 | 国产午夜福利100集发布 | 日韩av无码一区二区三区 | 国产suv精品一区二区五 | 精品日本一区二区三区在线观看 | 国产精品无码一区二区桃花视频 | 国产成人无码一二三区视频 | 超碰97人人射妻 | 久久久久久a亚洲欧洲av冫 | 亚洲自偷自偷在线制服 | 一本久久a久久精品vr综合 | 丝袜美腿亚洲一区二区 | 国内少妇偷人精品视频免费 | 好屌草这里只有精品 | 精品成在人线av无码免费看 | 日本丰满熟妇videos | 精品人妻人人做人人爽 | 在线精品国产一区二区三区 | 西西人体www44rt大胆高清 | 亚洲色欲色欲欲www在线 | 亚洲人成影院在线无码按摩店 | 98国产精品综合一区二区三区 | 亚洲va中文字幕无码久久不卡 | 日本熟妇乱子伦xxxx | 在线播放无码字幕亚洲 | 四虎国产精品免费久久 | 国产办公室秘书无码精品99 | 麻豆精产国品 | 亚洲欧美国产精品专区久久 | 少妇无套内谢久久久久 | 亚洲一区二区三区国产精华液 | 四虎影视成人永久免费观看视频 | 亚洲精品午夜国产va久久成人 | 九九久久精品国产免费看小说 | 国产高清av在线播放 | 久久久久成人片免费观看蜜芽 | 中文字幕 人妻熟女 | 国产av一区二区精品久久凹凸 | 午夜男女很黄的视频 | 成人一在线视频日韩国产 | 亚洲国产av精品一区二区蜜芽 | 中文字幕 亚洲精品 第1页 | 兔费看少妇性l交大片免费 | 久久国内精品自在自线 | 久久成人a毛片免费观看网站 | 在线观看国产午夜福利片 | 国产福利视频一区二区 | 欧美激情内射喷水高潮 | 少妇性俱乐部纵欲狂欢电影 | 免费无码av一区二区 | 久久综合狠狠综合久久综合88 | 色一情一乱一伦一视频免费看 | 欧美xxxx黑人又粗又长 | 扒开双腿疯狂进出爽爽爽视频 | 福利一区二区三区视频在线观看 | 色综合久久久无码中文字幕 | 激情国产av做激情国产爱 | 国产福利视频一区二区 | 国产成人精品三级麻豆 | 成人欧美一区二区三区黑人 | 女人高潮内射99精品 | 国产成人一区二区三区别 | 精品无人国产偷自产在线 | 99久久无码一区人妻 | 强辱丰满人妻hd中文字幕 | 亚洲精品成人福利网站 | 中文字幕无码热在线视频 | 国产口爆吞精在线视频 | 免费观看又污又黄的网站 | a在线观看免费网站大全 | 日日夜夜撸啊撸 | 亚洲中文字幕无码中文字在线 | 国语自产偷拍精品视频偷 | 偷窥村妇洗澡毛毛多 | 亚洲色www成人永久网址 | 亚洲区欧美区综合区自拍区 | 亚洲日韩av一区二区三区四区 | 欧美乱妇无乱码大黄a片 | 亚洲成a人片在线观看日本 | 成人性做爰aaa片免费看不忠 | 欧美激情内射喷水高潮 | 麻豆精品国产精华精华液好用吗 | 丁香啪啪综合成人亚洲 | 国产手机在线αⅴ片无码观看 | 亚洲 激情 小说 另类 欧美 | 欧美 丝袜 自拍 制服 另类 | 又大又黄又粗又爽的免费视频 | av无码电影一区二区三区 | 永久免费观看国产裸体美女 | 欧美兽交xxxx×视频 | 国产成人亚洲综合无码 | 亚洲中文字幕av在天堂 | 精品一区二区三区无码免费视频 | 久久精品女人天堂av免费观看 | 国内精品一区二区三区不卡 | 国产偷国产偷精品高清尤物 | 国产超碰人人爽人人做人人添 | 国语精品一区二区三区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 中文字幕乱码人妻无码久久 | 亚洲无人区午夜福利码高清完整版 | 精品乱子伦一区二区三区 | 丰满少妇弄高潮了www | 东京热男人av天堂 | 亚洲综合色区中文字幕 | 亚洲乱亚洲乱妇50p | 久9re热视频这里只有精品 | 亚洲国产高清在线观看视频 | 国产高清av在线播放 | 亚洲阿v天堂在线 | 一个人看的视频www在线 | 久久久精品国产sm最大网站 | 免费无码的av片在线观看 | 欧美zoozzooz性欧美 | 人妻有码中文字幕在线 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 日日天干夜夜狠狠爱 | 国产精品久久久久影院嫩草 | 亚洲中文无码av永久不收费 | 捆绑白丝粉色jk震动捧喷白浆 | 欧美成人家庭影院 | 最近的中文字幕在线看视频 | 色综合久久88色综合天天 | 久9re热视频这里只有精品 | 亚洲欧美国产精品久久 | 日韩少妇内射免费播放 | 日本精品久久久久中文字幕 | v一区无码内射国产 | 波多野结衣av一区二区全免费观看 | 色欲综合久久中文字幕网 | 国产乱人偷精品人妻a片 | 东京热男人av天堂 | 午夜福利一区二区三区在线观看 | 亚洲精品综合一区二区三区在线 | 国产精品久久久一区二区三区 | 国产午夜亚洲精品不卡下载 | 日韩人妻无码中文字幕视频 | 欧美乱妇无乱码大黄a片 | 亚洲 a v无 码免 费 成 人 a v | 国产亚洲美女精品久久久2020 | 丰满人妻被黑人猛烈进入 | 综合人妻久久一区二区精品 | 妺妺窝人体色www在线小说 | 一区二区三区高清视频一 | 亚洲国产av精品一区二区蜜芽 | 亚洲熟妇色xxxxx欧美老妇 | 国产手机在线αⅴ片无码观看 | 亚洲中文字幕无码中文字在线 | 亚洲精品无码国产 | 丁香啪啪综合成人亚洲 | 国产香蕉尹人综合在线观看 | 无码帝国www无码专区色综合 | 精品一二三区久久aaa片 | 天堂无码人妻精品一区二区三区 | 成人动漫在线观看 | 性欧美大战久久久久久久 | 亲嘴扒胸摸屁股激烈网站 | 久久精品女人天堂av免费观看 | 国产激情无码一区二区 | 无码精品人妻一区二区三区av | 色婷婷欧美在线播放内射 | 亚洲成a人片在线观看日本 | 丰满少妇高潮惨叫视频 | 夜夜躁日日躁狠狠久久av | 草草网站影院白丝内射 | 牲交欧美兽交欧美 | 亚洲乱码日产精品bd | 日韩精品无码一本二本三本色 | 亚洲一区二区观看播放 | 亚洲欧美日韩国产精品一区二区 | 亚洲色偷偷偷综合网 | 正在播放东北夫妻内射 | www一区二区www免费 | 四十如虎的丰满熟妇啪啪 | 国产熟妇另类久久久久 | 亚洲精品久久久久久一区二区 | 午夜福利不卡在线视频 | 亚洲日韩av一区二区三区中文 | 色婷婷香蕉在线一区二区 | 任你躁国产自任一区二区三区 | 色综合久久中文娱乐网 | 98国产精品综合一区二区三区 | 牲欲强的熟妇农村老妇女 | 亚洲无人区午夜福利码高清完整版 | 中文字幕+乱码+中文字幕一区 | 在线天堂新版最新版在线8 | 国产精品嫩草久久久久 | 牲交欧美兽交欧美 | 成人无码视频免费播放 | 99精品久久毛片a片 | 欧美性猛交xxxx富婆 | 国产色xx群视频射精 | 无码帝国www无码专区色综合 | 午夜精品久久久久久久久 | 久久国语露脸国产精品电影 | 免费无码肉片在线观看 | 麻豆精品国产精华精华液好用吗 | 亚洲国产av精品一区二区蜜芽 | 色五月五月丁香亚洲综合网 | 精品久久综合1区2区3区激情 | 国产色精品久久人妻 | 成人aaa片一区国产精品 | 在线亚洲高清揄拍自拍一品区 | 亚洲aⅴ无码成人网站国产app | 少妇性l交大片欧洲热妇乱xxx | 乱人伦人妻中文字幕无码 | 捆绑白丝粉色jk震动捧喷白浆 | 国产日产欧产精品精品app | 免费人成在线观看网站 | 综合人妻久久一区二区精品 | 久久国产劲爆∧v内射 | 国产深夜福利视频在线 | 国产美女精品一区二区三区 | 捆绑白丝粉色jk震动捧喷白浆 | 日本大香伊一区二区三区 | 三上悠亚人妻中文字幕在线 | 国产精品无码久久av | 少妇一晚三次一区二区三区 | 欧美日韩一区二区三区自拍 | 97人妻精品一区二区三区 | 激情五月综合色婷婷一区二区 | 亚洲国产高清在线观看视频 | 亚洲国产精华液网站w | 欧美丰满老熟妇xxxxx性 | 极品尤物被啪到呻吟喷水 | 亚洲最大成人网站 | 亚洲国产欧美国产综合一区 | 国产精品无码成人午夜电影 | yw尤物av无码国产在线观看 | 国产尤物精品视频 | 一本色道久久综合亚洲精品不卡 | 日本一区二区更新不卡 | 97久久国产亚洲精品超碰热 | 成人动漫在线观看 | 日本高清一区免费中文视频 | 大地资源网第二页免费观看 | 草草网站影院白丝内射 | 久久综合激激的五月天 | 国产亚洲精品久久久久久久久动漫 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲人亚洲人成电影网站色 | 无码播放一区二区三区 | 综合人妻久久一区二区精品 | 人妻少妇精品无码专区动漫 | 日本熟妇人妻xxxxx人hd | 色欲综合久久中文字幕网 | 成熟人妻av无码专区 | 日韩亚洲欧美精品综合 | 欧美性猛交xxxx富婆 | 国产在线aaa片一区二区99 | 人妻天天爽夜夜爽一区二区 | 国产另类ts人妖一区二区 | 亚洲一区二区三区含羞草 | 九九综合va免费看 | 男人扒开女人内裤强吻桶进去 | 久久综合网欧美色妞网 | 亚洲日本va中文字幕 | 成人片黄网站色大片免费观看 | 国产精品无码mv在线观看 | 亚洲国产日韩a在线播放 | 77777熟女视频在线观看 а天堂中文在线官网 | 好爽又高潮了毛片免费下载 | 自拍偷自拍亚洲精品被多人伦好爽 | 无套内谢的新婚少妇国语播放 | 亚洲精品一区国产 | 少妇人妻av毛片在线看 | 亚洲无人区午夜福利码高清完整版 | 亚洲成熟女人毛毛耸耸多 | 国产成人精品三级麻豆 | 综合人妻久久一区二区精品 | 精品少妇爆乳无码av无码专区 | 欧美刺激性大交 | 亚洲午夜福利在线观看 | 性生交片免费无码看人 | 黑人巨大精品欧美黑寡妇 | 国产亚洲tv在线观看 | 日本又色又爽又黄的a片18禁 | 国産精品久久久久久久 | 无码帝国www无码专区色综合 | 亚洲一区二区三区无码久久 | 国产 精品 自在自线 | 在线天堂新版最新版在线8 | 久久成人a毛片免费观看网站 | 午夜福利试看120秒体验区 | 亚洲国产精品成人久久蜜臀 | 欧美freesex黑人又粗又大 | 色窝窝无码一区二区三区色欲 | 婷婷五月综合缴情在线视频 | 性生交大片免费看女人按摩摩 | 国产精品亚洲综合色区韩国 | 国产人妻人伦精品1国产丝袜 | 免费男性肉肉影院 | 国产亚洲精品久久久久久国模美 | 欧美日韩久久久精品a片 | 中文字幕无线码免费人妻 | 国产va免费精品观看 | 日本在线高清不卡免费播放 | 天天摸天天透天天添 | 一本久久a久久精品vr综合 | 少妇愉情理伦片bd | 97se亚洲精品一区 | 宝宝好涨水快流出来免费视频 | 内射欧美老妇wbb | 国产乱人伦偷精品视频 | 日本免费一区二区三区最新 | 无套内谢的新婚少妇国语播放 | 亚洲色欲色欲欲www在线 | 秋霞成人午夜鲁丝一区二区三区 | 内射爽无广熟女亚洲 | 日日天日日夜日日摸 | 免费无码的av片在线观看 | 欧美人与物videos另类 | 天下第一社区视频www日本 | 大地资源中文第3页 | 小sao货水好多真紧h无码视频 | 精品无码一区二区三区的天堂 | 正在播放东北夫妻内射 | 午夜免费福利小电影 | 久久久久成人精品免费播放动漫 | 98国产精品综合一区二区三区 | 精品无码一区二区三区爱欲 | 麻豆蜜桃av蜜臀av色欲av | 澳门永久av免费网站 | 久久久久久九九精品久 | 日韩人妻无码一区二区三区久久99 | 中文字幕+乱码+中文字幕一区 | 中文字幕久久久久人妻 | 亚洲成a人片在线观看无码3d | 亚洲色在线无码国产精品不卡 | 欧美人与禽猛交狂配 | 国产激情艳情在线看视频 | 久久久久成人片免费观看蜜芽 | 国产精品福利视频导航 | 中文字幕av伊人av无码av | 丰满人妻被黑人猛烈进入 | 亚洲精品中文字幕久久久久 | 午夜精品久久久久久久 | 俄罗斯老熟妇色xxxx | 国产婷婷色一区二区三区在线 | а√天堂www在线天堂小说 | 四虎影视成人永久免费观看视频 | 日本va欧美va欧美va精品 | 亚洲精品国产第一综合99久久 | 久久亚洲日韩精品一区二区三区 | 国产精品人人爽人人做我的可爱 | 久久久久av无码免费网 | 亚洲日韩中文字幕在线播放 | 成人女人看片免费视频放人 | 午夜肉伦伦影院 | 无码成人精品区在线观看 | 无码av最新清无码专区吞精 | 免费看少妇作爱视频 | 天天爽夜夜爽夜夜爽 | 欧美人与禽zoz0性伦交 | 国产美女精品一区二区三区 | 久久精品中文字幕一区 | 美女扒开屁股让男人桶 | 久久国产劲爆∧v内射 | 成熟妇人a片免费看网站 | 亚洲精品国产品国语在线观看 | 麻豆果冻传媒2021精品传媒一区下载 | av在线亚洲欧洲日产一区二区 | 99视频精品全部免费免费观看 | 国产成人无码区免费内射一片色欲 | 国产xxx69麻豆国语对白 | 久久久久99精品成人片 | 天天综合网天天综合色 | 无遮无挡爽爽免费视频 | 欧美精品无码一区二区三区 | 丰满少妇弄高潮了www | 国产精品毛片一区二区 | 色婷婷久久一区二区三区麻豆 | 中文字幕乱码人妻二区三区 | 水蜜桃亚洲一二三四在线 | 国产激情无码一区二区app | 亚洲人成人无码网www国产 | √天堂资源地址中文在线 | 99国产精品白浆在线观看免费 | 日韩精品无码一本二本三本色 | 国产97在线 | 亚洲 | 亚洲精品一区二区三区在线观看 | 婷婷六月久久综合丁香 | 狠狠色丁香久久婷婷综合五月 | 亚洲欧美日韩综合久久久 | 中文字幕乱码中文乱码51精品 | 亚洲欧美国产精品专区久久 | 欧美 日韩 人妻 高清 中文 | 中文字幕日韩精品一区二区三区 | 亚洲 a v无 码免 费 成 人 a v | 亚洲精品一区二区三区大桥未久 | 国产电影无码午夜在线播放 | 欧美freesex黑人又粗又大 | 香蕉久久久久久av成人 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲一区av无码专区在线观看 | 成人性做爰aaa片免费看不忠 | 精品无码国产自产拍在线观看蜜 | 国产午夜手机精彩视频 | 日韩av无码中文无码电影 | 偷窥日本少妇撒尿chinese | 精品水蜜桃久久久久久久 | 免费无码午夜福利片69 | 日本乱偷人妻中文字幕 | 亚洲区小说区激情区图片区 | 真人与拘做受免费视频一 | 国产真实乱对白精彩久久 | 国精产品一品二品国精品69xx | 日本大乳高潮视频在线观看 | 国产激情无码一区二区app | 日本一卡2卡3卡四卡精品网站 | 一个人看的视频www在线 | 国色天香社区在线视频 | 300部国产真实乱 | 欧美老熟妇乱xxxxx | 日韩欧美中文字幕公布 | 欧美精品一区二区精品久久 | 人人妻人人澡人人爽精品欧美 | 白嫩日本少妇做爰 | 人人爽人人澡人人高潮 | 久久久国产精品无码免费专区 | 丰满少妇女裸体bbw | 精品久久久久香蕉网 | 久久亚洲日韩精品一区二区三区 | 97资源共享在线视频 | 国产亚洲tv在线观看 | 麻豆果冻传媒2021精品传媒一区下载 | 色欲人妻aaaaaaa无码 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲日韩一区二区 | 欧美日韩综合一区二区三区 | 成人综合网亚洲伊人 | 亚洲午夜福利在线观看 | 欧美人与禽猛交狂配 | 丝袜足控一区二区三区 | 婷婷丁香六月激情综合啪 | 色婷婷香蕉在线一区二区 | 人妻体内射精一区二区三四 | 免费无码肉片在线观看 | 狂野欧美性猛交免费视频 | 中文字幕+乱码+中文字幕一区 | 精品国产av色一区二区深夜久久 | 久久亚洲a片com人成 | 国产乱码精品一品二品 | 久在线观看福利视频 | 丰满人妻一区二区三区免费视频 | 国产精品手机免费 | 无码人妻av免费一区二区三区 | 波多野结衣av在线观看 | 色欲综合久久中文字幕网 | 中文字幕乱妇无码av在线 | 一本久久a久久精品vr综合 | 精品欧美一区二区三区久久久 | 午夜精品久久久久久久 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲精品久久久久久久久久久 | 亚洲人交乣女bbw | 成人无码精品1区2区3区免费看 | 中文字幕无码日韩欧毛 | 九九在线中文字幕无码 | 亚洲狠狠婷婷综合久久 | 国产精品美女久久久久av爽李琼 | 黑人大群体交免费视频 | 老熟妇仑乱视频一区二区 | 日日天干夜夜狠狠爱 | 国产乱人无码伦av在线a | 国产一区二区三区精品视频 | 内射欧美老妇wbb | 国产精品18久久久久久麻辣 | 人妻无码αv中文字幕久久琪琪布 | 色五月丁香五月综合五月 | 中文字幕人妻无码一夲道 | 老太婆性杂交欧美肥老太 | 国产内射老熟女aaaa | av无码不卡在线观看免费 | 日本精品高清一区二区 | 熟女体下毛毛黑森林 | 亚洲s色大片在线观看 | 亚洲国产精品毛片av不卡在线 | 久久久婷婷五月亚洲97号色 | 扒开双腿吃奶呻吟做受视频 | 亚洲日本va中文字幕 | 久久天天躁夜夜躁狠狠 | 无码播放一区二区三区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 香港三级日本三级妇三级 | 狠狠色色综合网站 | 欧美日韩一区二区综合 | 中文字幕无码日韩专区 | 亚洲综合久久一区二区 | 天天躁夜夜躁狠狠是什么心态 | 亚洲s码欧洲m码国产av | 国产偷国产偷精品高清尤物 | 特大黑人娇小亚洲女 | 天天做天天爱天天爽综合网 | 日韩精品无码一区二区中文字幕 | 人妻体内射精一区二区三四 | 亚洲色欲久久久综合网东京热 | 老熟女乱子伦 | 免费国产黄网站在线观看 | 人人妻在人人 | 午夜时刻免费入口 | 丁香花在线影院观看在线播放 | 国产香蕉尹人综合在线观看 | 亚洲 欧美 激情 小说 另类 | 国产成人精品三级麻豆 | 国产69精品久久久久app下载 | 久久久精品欧美一区二区免费 | 高潮喷水的毛片 | 久久久久成人精品免费播放动漫 | 婷婷丁香五月天综合东京热 | 无码人妻丰满熟妇区毛片18 | 亚洲日韩av一区二区三区中文 | 精品乱子伦一区二区三区 | 色婷婷欧美在线播放内射 | 狠狠综合久久久久综合网 | 曰韩无码二三区中文字幕 | 国产亚洲精品久久久久久久 | 无码毛片视频一区二区本码 | 日日碰狠狠躁久久躁蜜桃 | 亚洲国产午夜精品理论片 | 一本精品99久久精品77 | 国产精品a成v人在线播放 | 婷婷色婷婷开心五月四房播播 | 国产偷抇久久精品a片69 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产精品无码mv在线观看 | 成人无码视频免费播放 | 成人性做爰aaa片免费看不忠 | 国产内射爽爽大片视频社区在线 | 狠狠综合久久久久综合网 | 国产美女极度色诱视频www | 久久视频在线观看精品 | 成人精品一区二区三区中文字幕 | 福利一区二区三区视频在线观看 | 国产网红无码精品视频 | 国产黄在线观看免费观看不卡 | 国产人妻精品一区二区三区不卡 | 国产精品免费大片 | 国产一区二区三区四区五区加勒比 | 99麻豆久久久国产精品免费 | 国产69精品久久久久app下载 | 亚洲精品久久久久久久久久久 | 日本肉体xxxx裸交 | 内射白嫩少妇超碰 | 午夜肉伦伦影院 | 人人澡人人透人人爽 | 天下第一社区视频www日本 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲另类伦春色综合小说 | 午夜熟女插插xx免费视频 | 99在线 | 亚洲 | 久久综合香蕉国产蜜臀av | 极品尤物被啪到呻吟喷水 | 亚洲人成无码网www | 久久www免费人成人片 | 一二三四在线观看免费视频 | 欧美真人作爱免费视频 | 成人综合网亚洲伊人 | 大乳丰满人妻中文字幕日本 | 在线天堂新版最新版在线8 | 两性色午夜免费视频 | 国产成人无码区免费内射一片色欲 | 激情五月综合色婷婷一区二区 | 免费无码一区二区三区蜜桃大 | 婷婷五月综合激情中文字幕 | 国产凸凹视频一区二区 | 国产乱码精品一品二品 | 狠狠色丁香久久婷婷综合五月 | av人摸人人人澡人人超碰下载 | 性色欲网站人妻丰满中文久久不卡 | 亚洲综合色区中文字幕 | 午夜理论片yy44880影院 | 国产超碰人人爽人人做人人添 | 成人精品一区二区三区中文字幕 | 无码人妻精品一区二区三区下载 | 免费网站看v片在线18禁无码 | 在线天堂新版最新版在线8 | 亚洲呦女专区 | 亚洲小说图区综合在线 | 丰满少妇熟乱xxxxx视频 | 亚洲人交乣女bbw | 国产成人午夜福利在线播放 | 在线播放亚洲第一字幕 | 亚洲色在线无码国产精品不卡 | 永久免费观看美女裸体的网站 | 骚片av蜜桃精品一区 | 成年美女黄网站色大免费全看 | 强辱丰满人妻hd中文字幕 | 一本加勒比波多野结衣 | 国产精品办公室沙发 | 国产精品igao视频网 | 一本大道久久东京热无码av | 国产亚洲精品精品国产亚洲综合 | 人妻中文无码久热丝袜 | 欧美freesex黑人又粗又大 | 四虎永久在线精品免费网址 | 无码人妻丰满熟妇区五十路百度 | 国产精品无码久久av | 色 综合 欧美 亚洲 国产 | 国产成人无码a区在线观看视频app | 日韩少妇内射免费播放 | 久久精品中文字幕大胸 | 国产偷抇久久精品a片69 | 色狠狠av一区二区三区 | 亚洲国精产品一二二线 | 国产午夜视频在线观看 | 亚洲欧美精品aaaaaa片 | √天堂中文官网8在线 | 亚洲天堂2017无码 | 国内揄拍国内精品人妻 | 一区二区传媒有限公司 | 亚洲欧洲日本无在线码 | 性欧美牲交在线视频 | 亚洲精品国产第一综合99久久 | 日本高清一区免费中文视频 | 性生交大片免费看l | 人妻无码αv中文字幕久久琪琪布 | 欧美人与禽zoz0性伦交 | 丰满人妻精品国产99aⅴ | 日本爽爽爽爽爽爽在线观看免 | 小鲜肉自慰网站xnxx | 午夜理论片yy44880影院 | 欧美精品一区二区精品久久 | 无码精品国产va在线观看dvd | 又黄又爽又色的视频 | 国产午夜精品一区二区三区嫩草 | 国产在线精品一区二区高清不卡 | 欧美性猛交xxxx富婆 | www国产精品内射老师 | 大肉大捧一进一出视频出来呀 | 午夜理论片yy44880影院 | 国产在线无码精品电影网 | 中国大陆精品视频xxxx | 欧美精品一区二区精品久久 | 久久久成人毛片无码 | 亚洲精品一区二区三区四区五区 | 人妻无码αv中文字幕久久琪琪布 | 男人的天堂2018无码 | 国产xxx69麻豆国语对白 | 狠狠色丁香久久婷婷综合五月 | 亚洲精品成a人在线观看 | 1000部夫妻午夜免费 | 无套内谢老熟女 | 亚洲精品久久久久avwww潮水 | 99久久久无码国产精品免费 | 亚洲一区二区三区播放 | 日韩人妻系列无码专区 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 精品日本一区二区三区在线观看 | 精品久久久无码人妻字幂 | 国语精品一区二区三区 | 人人澡人人透人人爽 | 牲交欧美兽交欧美 | 国产亚洲欧美在线专区 | 性啪啪chinese东北女人 | 成人无码视频在线观看网站 | 亚洲乱码国产乱码精品精 | 无码毛片视频一区二区本码 | 中文字幕乱妇无码av在线 | 日韩视频 中文字幕 视频一区 | 久久久久久久久888 | 亚洲综合无码一区二区三区 | 真人与拘做受免费视频 | 国产精品无码mv在线观看 | 爽爽影院免费观看 | 亚洲综合色区中文字幕 | 国产精品理论片在线观看 | 亚洲色偷偷男人的天堂 | 亚洲成av人片天堂网无码】 | 国产亚洲精品精品国产亚洲综合 | 中文字幕亚洲情99在线 | 成熟人妻av无码专区 | 成熟人妻av无码专区 | 国产成人一区二区三区别 | 一本久久伊人热热精品中文字幕 | 九九热爱视频精品 | 中文字幕无码日韩欧毛 | 婷婷五月综合缴情在线视频 | 亚洲色成人中文字幕网站 | 国产在线无码精品电影网 | 亚洲男人av天堂午夜在 | 日本又色又爽又黄的a片18禁 | 熟女少妇人妻中文字幕 | 秋霞成人午夜鲁丝一区二区三区 | 精品人妻人人做人人爽 | 精品国产成人一区二区三区 | 秋霞成人午夜鲁丝一区二区三区 | 好爽又高潮了毛片免费下载 | 乱中年女人伦av三区 | 熟妇人妻无乱码中文字幕 | 亚洲精品无码人妻无码 | 乱中年女人伦av三区 | 久久这里只有精品视频9 | 国产在线精品一区二区高清不卡 | 亚洲国产午夜精品理论片 | 亚洲成av人片在线观看无码不卡 | 亚洲爆乳大丰满无码专区 | 色综合久久久无码网中文 | 白嫩日本少妇做爰 | аⅴ资源天堂资源库在线 | 免费国产成人高清在线观看网站 | 国产成人午夜福利在线播放 | v一区无码内射国产 | 日日碰狠狠躁久久躁蜜桃 | 欧美日韩色另类综合 | 精品国产乱码久久久久乱码 | 初尝人妻少妇中文字幕 | 亚洲色欲色欲欲www在线 | 西西人体www44rt大胆高清 | 亚洲精品鲁一鲁一区二区三区 | 欧美日韩人成综合在线播放 | 性色av无码免费一区二区三区 | 青青草原综合久久大伊人精品 | 四虎影视成人永久免费观看视频 | 99精品久久毛片a片 | 日韩精品成人一区二区三区 | 色综合久久88色综合天天 | 免费看男女做好爽好硬视频 | 日韩人妻无码中文字幕视频 | 性欧美疯狂xxxxbbbb | 精品欧洲av无码一区二区三区 | 国内精品一区二区三区不卡 | 亚洲乱亚洲乱妇50p | 久久精品国产日本波多野结衣 | 国产免费久久久久久无码 | 免费无码一区二区三区蜜桃大 | 国产乱人无码伦av在线a | 欧洲欧美人成视频在线 | 国内精品人妻无码久久久影院 | 波多野结衣av在线观看 | 人人妻人人澡人人爽欧美精品 | 国产精华av午夜在线观看 | 激情内射亚州一区二区三区爱妻 | 国产精品人妻一区二区三区四 | 日韩成人一区二区三区在线观看 | 国产成人一区二区三区在线观看 | 国产美女极度色诱视频www | 在线а√天堂中文官网 | 国产精品第一国产精品 | 伊人久久大香线焦av综合影院 | 国产真实夫妇视频 | 亚洲人成人无码网www国产 | 国产一区二区三区日韩精品 | 色综合久久88色综合天天 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲熟妇色xxxxx欧美老妇 | 精品国产乱码久久久久乱码 | 丰满妇女强制高潮18xxxx | 思思久久99热只有频精品66 | 国内综合精品午夜久久资源 | 亚洲精品综合五月久久小说 | 国产猛烈高潮尖叫视频免费 | 综合人妻久久一区二区精品 | 在线看片无码永久免费视频 | 久久久久久av无码免费看大片 | 小sao货水好多真紧h无码视频 | 亚洲精品成人福利网站 | 欧美日本日韩 | 国产精品亚洲а∨无码播放麻豆 | 国产精品久久国产精品99 | 人人爽人人爽人人片av亚洲 | 久久伊人色av天堂九九小黄鸭 | 亚洲 日韩 欧美 成人 在线观看 | 乱码av麻豆丝袜熟女系列 | 久久久久久a亚洲欧洲av冫 | 亚洲国产精品美女久久久久 | 天天做天天爱天天爽综合网 | 中文字幕av伊人av无码av | 无码纯肉视频在线观看 | 熟妇人妻无码xxx视频 | 樱花草在线社区www | 一本精品99久久精品77 | 精品一区二区三区无码免费视频 | 在线播放无码字幕亚洲 | 亚洲国产综合无码一区 | 成熟女人特级毛片www免费 | 久久久av男人的天堂 | 午夜男女很黄的视频 | 乱人伦中文视频在线观看 | 国产xxx69麻豆国语对白 | 精品国产一区二区三区av 性色 | 久久精品国产大片免费观看 | 国产艳妇av在线观看果冻传媒 | 真人与拘做受免费视频 | 国产高清不卡无码视频 | а√资源新版在线天堂 | 嫩b人妻精品一区二区三区 | 亚洲人成人无码网www国产 | 77777熟女视频在线观看 а天堂中文在线官网 | 沈阳熟女露脸对白视频 | 久久久精品国产sm最大网站 | 久久久久国色av免费观看性色 | 亚洲自偷自拍另类第1页 | 欧洲欧美人成视频在线 | 18禁黄网站男男禁片免费观看 | 人人妻人人澡人人爽精品欧美 | 无码国产色欲xxxxx视频 | 亚洲一区二区三区香蕉 | 奇米影视888欧美在线观看 | 久久亚洲精品成人无码 | 欧美肥老太牲交大战 | 国产av一区二区三区最新精品 | 国产人妻久久精品二区三区老狼 | 国产欧美精品一区二区三区 | aⅴ在线视频男人的天堂 | 人妻少妇精品视频专区 | 中文字幕乱码中文乱码51精品 | 久久精品女人天堂av免费观看 | 国产亚洲视频中文字幕97精品 | 欧洲欧美人成视频在线 | 成人三级无码视频在线观看 | 日本一卡2卡3卡四卡精品网站 | 2020久久超碰国产精品最新 | 最新版天堂资源中文官网 | 玩弄少妇高潮ⅹxxxyw | 大乳丰满人妻中文字幕日本 | 亚洲欧美精品aaaaaa片 | 亚洲欧美综合区丁香五月小说 | 欧美精品免费观看二区 | 国精品人妻无码一区二区三区蜜柚 | 97久久精品无码一区二区 | 欧美性猛交内射兽交老熟妇 | 亚洲精品久久久久avwww潮水 | 色婷婷综合激情综在线播放 | 欧美亚洲日韩国产人成在线播放 | 男人的天堂av网站 | 久久人人爽人人爽人人片av高清 | 日本成熟视频免费视频 | 中文字幕无码免费久久99 | 色一情一乱一伦一视频免费看 | 又大又紧又粉嫩18p少妇 | 国产无遮挡又黄又爽免费视频 | 国产精品.xx视频.xxtv | 日本又色又爽又黄的a片18禁 | 沈阳熟女露脸对白视频 | 国产成人av免费观看 | 国产精华av午夜在线观看 | 无码国模国产在线观看 | yw尤物av无码国产在线观看 | 精品偷自拍另类在线观看 | 国产成人精品优优av | 乌克兰少妇性做爰 | 熟女少妇人妻中文字幕 | 免费看男女做好爽好硬视频 | 99精品视频在线观看免费 | 国内老熟妇对白xxxxhd | 久久精品国产99精品亚洲 | 国产办公室秘书无码精品99 | 国产激情无码一区二区app | 久久久久成人精品免费播放动漫 | 亚洲aⅴ无码成人网站国产app | 风流少妇按摩来高潮 | 日韩人妻系列无码专区 | 精品 日韩 国产 欧美 视频 | 日韩人妻少妇一区二区三区 | 国产精品国产三级国产专播 | 国产农村妇女高潮大叫 | 人人妻人人澡人人爽欧美一区九九 | 日韩精品无码一本二本三本色 | 亚洲毛片av日韩av无码 | 四虎国产精品免费久久 | 又紧又大又爽精品一区二区 | 高中生自慰www网站 | 国产精品美女久久久久av爽李琼 | 蜜臀av无码人妻精品 | 国产97色在线 | 免 | 乱码av麻豆丝袜熟女系列 | 麻豆人妻少妇精品无码专区 | 中文字幕亚洲情99在线 | 久久综合激激的五月天 | 国产人妻精品一区二区三区不卡 | 国产真实伦对白全集 | 国产女主播喷水视频在线观看 | 国产艳妇av在线观看果冻传媒 | 色 综合 欧美 亚洲 国产 | 丰满人妻精品国产99aⅴ | 国产明星裸体无码xxxx视频 | 午夜理论片yy44880影院 | 精品国偷自产在线视频 | 欧美三级不卡在线观看 | 成人无码视频在线观看网站 | 成人毛片一区二区 | 国产sm调教视频在线观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 天天躁日日躁狠狠躁免费麻豆 | 国产精品自产拍在线观看 | 久久精品国产精品国产精品污 | 一个人看的www免费视频在线观看 | 国产av剧情md精品麻豆 | 婷婷综合久久中文字幕蜜桃三电影 | 精品国产一区av天美传媒 | 精品夜夜澡人妻无码av蜜桃 | 国产亚洲精品久久久久久大师 | 欧美日本日韩 | 国产亚洲日韩欧美另类第八页 | 亚洲啪av永久无码精品放毛片 | 色偷偷人人澡人人爽人人模 | 人人妻人人澡人人爽欧美一区 | 国产亚洲精品久久久久久国模美 | 精品久久久无码中文字幕 | 久久99热只有频精品8 | 色综合久久88色综合天天 | 国产在线精品一区二区三区直播 | 波多野结衣 黑人 | 久久精品国产99久久6动漫 | 国色天香社区在线视频 | 国产一区二区三区影院 | 久久99精品久久久久婷婷 | 人人妻人人澡人人爽人人精品浪潮 | 女人被爽到呻吟gif动态图视看 | 国产精品嫩草久久久久 | 国产婷婷色一区二区三区在线 | 亚洲第一无码av无码专区 | 国产精品久久国产精品99 | 国产无遮挡又黄又爽又色 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲经典千人经典日产 | 中文字幕+乱码+中文字幕一区 | 高潮毛片无遮挡高清免费视频 | 2020久久香蕉国产线看观看 | 中文亚洲成a人片在线观看 | 国产成人亚洲综合无码 | 乱码午夜-极国产极内射 | 成人免费无码大片a毛片 | 丝袜足控一区二区三区 | 久久精品国产大片免费观看 | 久久久久免费精品国产 | 网友自拍区视频精品 | 无码一区二区三区在线观看 | 亚洲一区二区三区播放 | 桃花色综合影院 | 日韩精品无码免费一区二区三区 | 综合网日日天干夜夜久久 | 日日噜噜噜噜夜夜爽亚洲精品 | 精品久久久无码中文字幕 | 欧美激情内射喷水高潮 | 人人妻在人人 | 亚洲成av人影院在线观看 | 亚洲精品成人福利网站 | 日本精品人妻无码77777 天堂一区人妻无码 | 午夜不卡av免费 一本久久a久久精品vr综合 | 欧美日韩一区二区三区自拍 | 亚洲第一网站男人都懂 | 高潮喷水的毛片 | 亚洲国产精品毛片av不卡在线 | 99国产欧美久久久精品 | 无码人妻出轨黑人中文字幕 | 欧美freesex黑人又粗又大 | 99久久精品无码一区二区毛片 | 日韩av无码中文无码电影 | 无码中文字幕色专区 | 亚洲欧洲无卡二区视頻 | 日本xxxx色视频在线观看免费 | 日韩视频 中文字幕 视频一区 | 国产一区二区三区精品视频 | 久久aⅴ免费观看 | 日韩 欧美 动漫 国产 制服 | 日本护士xxxxhd少妇 | 欧美精品在线观看 | www一区二区www免费 | 樱花草在线播放免费中文 | 国产成人无码午夜视频在线观看 | 亚洲国产综合无码一区 | 亚洲国产欧美日韩精品一区二区三区 | 久久99精品久久久久久动态图 | 成人欧美一区二区三区黑人免费 | 亚洲 激情 小说 另类 欧美 | 欧美xxxx黑人又粗又长 | 亚洲精品一区二区三区在线观看 | 午夜精品一区二区三区在线观看 | 乱中年女人伦av三区 | 97夜夜澡人人双人人人喊 | 久久人妻内射无码一区三区 | 亚洲精品一区国产 | 亚洲成av人综合在线观看 | 国产欧美精品一区二区三区 | 亚洲精品久久久久久久久久久 | 亚洲无人区一区二区三区 | 久久精品一区二区三区四区 | 色诱久久久久综合网ywww | 亚洲熟女一区二区三区 | 中文字幕无码av波多野吉衣 | 无码帝国www无码专区色综合 | 亚洲天堂2017无码中文 | 亚洲日韩中文字幕在线播放 | 午夜福利一区二区三区在线观看 | 国产精品自产拍在线观看 | 亚洲精品中文字幕 | 欧美自拍另类欧美综合图片区 | 欧美成人家庭影院 | 成人性做爰aaa片免费看不忠 | 日韩av无码一区二区三区不卡 | 四虎国产精品一区二区 | 午夜免费福利小电影 | 久久久久久av无码免费看大片 | 给我免费的视频在线观看 | av香港经典三级级 在线 | 青春草在线视频免费观看 | 在线播放无码字幕亚洲 | 永久免费观看国产裸体美女 | 亚洲成av人片在线观看无码不卡 | 亚洲另类伦春色综合小说 | 台湾无码一区二区 | 中文字幕色婷婷在线视频 | 老熟妇仑乱视频一区二区 | 日日麻批免费40分钟无码 | 欧美猛少妇色xxxxx | 无码国产激情在线观看 | 日本乱人伦片中文三区 | 亚洲日韩一区二区 | 天堂久久天堂av色综合 | 曰本女人与公拘交酡免费视频 | 熟女俱乐部五十路六十路av | 欧美大屁股xxxxhd黑色 | 97精品国产97久久久久久免费 | 天天做天天爱天天爽综合网 | 1000部啪啪未满十八勿入下载 | 无码人妻出轨黑人中文字幕 | 日韩人妻系列无码专区 | 久久五月精品中文字幕 | 亚洲日本在线电影 | 日本精品少妇一区二区三区 | 狂野欧美性猛交免费视频 | 精品国产精品久久一区免费式 | 久久久久久a亚洲欧洲av冫 | 思思久久99热只有频精品66 | 中文字幕无码人妻少妇免费 | 久久久久成人片免费观看蜜芽 | 国产真人无遮挡作爱免费视频 | 麻豆精产国品 | 国色天香社区在线视频 | 国产精品久久久久9999小说 | 欧美怡红院免费全部视频 | 成人免费视频一区二区 | 成人片黄网站色大片免费观看 | 性啪啪chinese东北女人 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 中文字幕+乱码+中文字幕一区 | 少妇久久久久久人妻无码 | 天堂无码人妻精品一区二区三区 | 狂野欧美性猛xxxx乱大交 | 亚洲综合无码久久精品综合 | 中文字幕无码日韩欧毛 | 无码吃奶揉捏奶头高潮视频 | 色综合久久久无码网中文 | 久久久亚洲欧洲日产国码αv | 97精品人妻一区二区三区香蕉 | 国产亚av手机在线观看 | 帮老师解开蕾丝奶罩吸乳网站 | 国产精品久久久久久亚洲影视内衣 | 青春草在线视频免费观看 | 中文字幕无码av波多野吉衣 | 亚洲日韩一区二区三区 | 国产欧美亚洲精品a | 国产成人精品三级麻豆 | 亚洲成在人网站无码天堂 | 荫蒂添的好舒服视频囗交 | 色婷婷欧美在线播放内射 | 成人免费视频一区二区 | 国产精品免费大片 | 俺去俺来也在线www色官网 | 久久亚洲国产成人精品性色 | 中国女人内谢69xxxx | 激情内射日本一区二区三区 | 国产超碰人人爽人人做人人添 | 国产真实乱对白精彩久久 | 亚洲一区二区三区无码久久 | 国产在线aaa片一区二区99 | 国产精品福利视频导航 | 精品无码国产自产拍在线观看蜜 | 久久99精品国产麻豆蜜芽 | 一本久道高清无码视频 | 国产熟妇高潮叫床视频播放 | 日产国产精品亚洲系列 | 亚洲 a v无 码免 费 成 人 a v | 欧美精品免费观看二区 | 成人精品天堂一区二区三区 | 国产精品久久精品三级 | 97久久国产亚洲精品超碰热 | 亚洲国产高清在线观看视频 | 蜜桃臀无码内射一区二区三区 | 天天躁夜夜躁狠狠是什么心态 | 东京无码熟妇人妻av在线网址 | 少妇人妻av毛片在线看 | 国产成人精品久久亚洲高清不卡 | 久精品国产欧美亚洲色aⅴ大片 | 无码一区二区三区在线观看 | 亚洲 欧美 激情 小说 另类 | 香港三级日本三级妇三级 | 无码毛片视频一区二区本码 | 强辱丰满人妻hd中文字幕 | 国产精品毛片一区二区 | 亚洲中文字幕av在天堂 | 无码午夜成人1000部免费视频 | av无码久久久久不卡免费网站 | 一二三四在线观看免费视频 | 亚洲国产欧美国产综合一区 | 欧洲vodafone精品性 | 精品少妇爆乳无码av无码专区 | 性欧美熟妇videofreesex | 97夜夜澡人人双人人人喊 | 无码人妻精品一区二区三区下载 | 兔费看少妇性l交大片免费 | 中文字幕中文有码在线 | 欧美成人高清在线播放 | 日韩少妇白浆无码系列 | 亚洲成av人片在线观看无码不卡 | 精品久久久久久人妻无码中文字幕 | 丰满少妇熟乱xxxxx视频 | 久久久久久a亚洲欧洲av冫 | 亚洲日韩精品欧美一区二区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产办公室秘书无码精品99 | 日韩精品成人一区二区三区 | 无码任你躁久久久久久久 | 国产极品美女高潮无套在线观看 | 日韩 欧美 动漫 国产 制服 | 日本一区二区更新不卡 | 亚洲经典千人经典日产 | 精品国产福利一区二区 | 无码毛片视频一区二区本码 | 最新版天堂资源中文官网 | 亚洲国产av精品一区二区蜜芽 | 黑人粗大猛烈进出高潮视频 | 丝袜足控一区二区三区 | 亚洲码国产精品高潮在线 | 中文字幕无线码免费人妻 | 牲交欧美兽交欧美 | 久久精品无码一区二区三区 | 国产办公室秘书无码精品99 | 人人澡人摸人人添 | 久久综合九色综合欧美狠狠 | 久久亚洲精品成人无码 | 欧洲精品码一区二区三区免费看 | 国产精品久久久久9999小说 | 国产精品资源一区二区 | 国产av一区二区精品久久凹凸 | 日韩精品成人一区二区三区 | 熟女少妇在线视频播放 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产日产欧产精品精品app | 55夜色66夜色国产精品视频 | 久久精品人妻少妇一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 国产国语老龄妇女a片 | 国内揄拍国内精品人妻 | 国产性生大片免费观看性 | 日本饥渴人妻欲求不满 | 伊人久久大香线蕉亚洲 | 中文字幕人妻无码一夲道 | 午夜成人1000部免费视频 | 亚洲国产av美女网站 | 东京热一精品无码av | 国产超级va在线观看视频 | 欧美熟妇另类久久久久久不卡 | 国产成人一区二区三区别 | 国产人妖乱国产精品人妖 | 亚洲毛片av日韩av无码 | 又大又硬又黄的免费视频 | 国产在线一区二区三区四区五区 | 国产综合在线观看 | 国产又粗又硬又大爽黄老大爷视 | 久久亚洲日韩精品一区二区三区 | 国产小呦泬泬99精品 | 中文亚洲成a人片在线观看 | 波多野结衣高清一区二区三区 | 国产成人无码av在线影院 | 图片区 小说区 区 亚洲五月 | 亚欧洲精品在线视频免费观看 | 东京热无码av男人的天堂 | 国产精品手机免费 | 国产精品久久久久久久9999 | 日本一区二区三区免费播放 | 欧美乱妇无乱码大黄a片 | 国产亚洲精品久久久久久 | 久久久久久久人妻无码中文字幕爆 | 波多野结衣高清一区二区三区 | 国产精品久久久久7777 | 久久zyz资源站无码中文动漫 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产精品igao视频网 | 国产精品va在线观看无码 | 黑人粗大猛烈进出高潮视频 | 乱人伦人妻中文字幕无码久久网 | 婷婷五月综合激情中文字幕 | 国产精品久久久久7777 | 性开放的女人aaa片 | 熟女少妇在线视频播放 | 全球成人中文在线 | 国产凸凹视频一区二区 | 色噜噜亚洲男人的天堂 | 亚洲精品久久久久中文第一幕 | 成人精品天堂一区二区三区 | 女人被男人躁得好爽免费视频 | 午夜无码区在线观看 | 中文字幕无码热在线视频 | 欧美喷潮久久久xxxxx | 欧美第一黄网免费网站 | 2020最新国产自产精品 | 亚洲a无码综合a国产av中文 | 免费国产成人高清在线观看网站 | 2019nv天堂香蕉在线观看 | 亚洲熟妇自偷自拍另类 | 少妇性荡欲午夜性开放视频剧场 | 无码国模国产在线观看 | 国产午夜手机精彩视频 | 一个人看的www免费视频在线观看 | 精品国产精品久久一区免费式 | 亚洲国产精品久久久久久 | 精品无码国产自产拍在线观看蜜 | 亚洲精品一区三区三区在线观看 | 十八禁视频网站在线观看 | 亚洲 激情 小说 另类 欧美 | 亚洲乱码中文字幕在线 | 亚洲精品中文字幕久久久久 | 中文字幕精品av一区二区五区 |