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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

一文读懂 AVL 树

發布時間:2023/12/4 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 一文读懂 AVL 树 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


背景


AVL 樹是一棵平衡的二叉查找樹,于 1962 年,G. M. Adelson-Velsky 和 E. M. Landis 在他們的論文《An algorithm for the organization of information》中發表。


所謂的平衡之意,就是樹中任意一個結點下左右兩個子樹的高度差不超過 1。(本文對于樹的高度約定為:空結點高度是 0,葉子結點高度是 1。)



那 AVL 樹和普通的二叉查找樹有何區別呢?如圖,如果我們插入的是一組有序上升或下降的數據,則一棵普通的二叉查找樹必然會退化成一個單鏈表,其查找效率就降為 O(n)。而 AVL 樹因其平衡的限制,可以始終保持 O(logn) 的時間復雜度。


具體實現與代碼分析


在我們進行完插入或刪除操作后,很可能會導致某個結點失去平衡,那么我們就需要把失衡結點旋轉一下,使其重新恢復平衡。


經過分析,不管是插入還是刪除,它們都會有四種失衡的情況:左左失衡,右右失衡,左右失衡,右左失衡。因此每次遇到失衡時,我們只需判斷一下是哪個失衡,再對其進行相對應的恢復平衡操作即可。


好,下面以插入操作為例,來看下這四種失衡的廬山真面目。(以下統一約定:紅色結點為新插入結點,y 結點為失衡結點)


(1)左左失衡



所謂的左左,即 "失衡結點" 的左子樹比右子樹高 2,左孩子下的左子樹比右子樹高 1。


我們只需對 "以 y 為根的子樹" 進行 "左左旋轉 (ll_rotate)" 即可。一次旋轉后,恢復平衡。


Node * AVL::ll_rotate(Node * y)

{

? ? Node * x = y->left;

? ? y->left = x->right;

? ? x->right = y;

? ? y->height = max(get_height(y->left), get_height(y->right)) + 1;

? ? x->height = max(get_height(x->left), get_height(x->right)) + 1;

? ? return x;

}


(2)右右失衡



所謂的右右,即 "失衡結點" 的右子樹比左子樹高 2,右孩子下的右子樹比左子樹高 1。


我們只需對 "以 y 為根的子樹" 進行 "右右旋轉 (rr_rotate)" 即可。一次旋轉后,恢復平衡。


Node * AVL::rr_rotate(Node * y)

{

? ? Node * x = y->right;

? ? y->right = x->left;

? ? x->left = y;

? ? y->height = max(get_height(y->left), get_height(y->right)) + 1;

? ? x->height = max(get_height(x->left), get_height(x->right)) + 1;

? ? return x;

}


(3)左右失衡



所謂的左右,即 "失衡結點" 的左子樹比右子樹高 2,左孩子下的右子樹比左子樹高 1。


觀察發現,若先對 "以 x 為根的子樹" 進行 "右右旋轉 (rr_rotate)",此時 "以 y 為根的子樹" 恰好符合 "左左失衡",所以再進行一次 "左左旋轉 (ll_rotate)"。兩次旋轉后,恢復平衡。


Node * AVL::lr_rotate(Node * y)

{

? ? Node * x = y->left;

? ? y->left = rr_rotate(x);

? ? return ll_rotate(y);

}


(4)右左失衡



所謂的右左,即 "失衡結點" 的右子樹比左子樹高 2,右孩子下的左子樹比右子樹高 1。


觀察發現,若先對 "以 x 為根的子樹" 進行 "左左旋轉 (ll_rotate)",此時 "以 y 為根的子樹" 恰好符合 "右右失衡",所以再進行一次 "右右旋轉 (rr_rotate)"。兩次旋轉后,恢復平衡。


Node * AVL::rl_rotate(Node * y)

{

? ? Node * x = y->right;

? ? y->right = ll_rotate(x);

? ? return rr_rotate(y);

}


插入操作


插入成功后,在遞歸回溯時依次對經過的結點判斷是否失衡,若失衡就需要對其進行對應的旋轉操作使其恢復平衡,在這期間,原先作為一棵子樹的根結點就會因為旋轉被替換,因此設置insert_real( )返回的是新根結點,這樣就可以實時更新根結點。


插入操作實現代碼如下:


int AVL::get_height(Node * node)

{

? ? if (node == nullptr)

? ? ? ? return 0;

? ? return node->height;

}


int AVL::get_balance(Node * node)

{

? ? if (node == nullptr)

? ? ? ? return 0;

? ? return get_height(node->left) - get_height(node->right);

}


Node * AVL::insert_real(int key, Node * node)

{

? ? if (node == nullptr)

? ? ? ? return new Node(key);


? ? if (key < node->key)

? ? ? ? node->left = insert_real(key, node->left);

? ? else if (key > node->key)

? ? ? ? node->right = insert_real(key, node->right);

? ? else

? ? ? ? return node;


? ? node->height = max(get_height(node->left), get_height(node->right)) + 1;


? ? int balance = get_balance(node);


? ? // 左左失衡

? ? if (balance > 1 && get_balance(node->left) > 0)

? ? ? ? return ll_rotate(node);


? ? // 右右失衡

? ? if (balance < -1 && get_balance(node->right) < 0)

? ? ? ? return rr_rotate(node);


? ? // 左右失衡

? ? if (balance > 1 && get_balance(node->left) < 0)

? ? ? ? return lr_rotate(node);


? ? // 右左失衡

? ? if (balance < -1 && get_balance(node->right) > 0)

? ? ? ? return rl_rotate(node);


? ? return node;

}


void AVL::insert(int key)

{

? ? header->left = insert_real(key, header->left);

}


查找操作


Node * AVL::find_real(int key, Node * node)

{

? ? if (node == nullptr)

? ? ? ? return nullptr;


? ? if (key < node->key)

? ? ? ? return find_real(key, node->left);

? ? else if (key > node->key)

? ? ? ? return find_real(key, node->right);

? ? else

? ? ? ? return node;

}


Node * AVL::find(int key)

{

? ? return find_real(key, header->left);

}


刪除操作


刪除操作的四種失衡情況和插入操作一樣,讀者可以參考前文。下面是刪除操作的實現代碼:


Node * AVL::erase_real(int key, Node * node)

{

? ? if (node == nullptr)

? ? ? ? return node;


? ? if (key < node->key)

? ? ? ? node->left = erase_real(key, node->left);

? ? else if (key > node->key)

? ? ? ? node->right = erase_real(key, node->right);

? ? else

? ? {

? ? ? ? if (node->left && node->right)

? ? ? ? {

? ? ? ? ? ? // 找到后繼結點

? ? ? ? ? ? Node * x = node->right;

? ? ? ? ? ? while (x->left)

? ? ? ? ? ? ? ? x = x->left;


? ? ? ? ? ? // 后繼直接復制

? ? ? ? ? ? node->key = x->key;


? ? ? ? ? ? // 轉化為刪除后繼

? ? ? ? ? ? node->right = erase_real(x->key, node->right);

? ? ? ? }

? ? ? ? else

? ? ? ? {

? ? ? ? ? ? Node * t = node;

? ? ? ? ? ? node = node->left ? node->left : node->right;

? ? ? ? ? ? delete t;

? ? ? ? ? ? if (node == nullptr)

? ? ? ? ? ? ? ? return nullptr;

? ? ? ? }

? ? }


? ? node->height = max(get_height(node->left), get_height(node->right)) + 1;


? ? int balance = get_balance(node);


? ? // 左左失衡

? ? if (balance > 1 && get_balance(node->left) >= 0) // 需要加等號

? ? ? ? return ll_rotate(node);


? ? // 右右失衡

? ? if (balance < -1 && get_balance(node->right) <= 0) // 需要加等號

? ? ? ? return rr_rotate(node);


? ? // 左右失衡

? ? if (balance > 1 && get_balance(node->left) < 0)

? ? ? ? return lr_rotate(node);


? ? // 右左失衡

? ? if (balance < -1 && get_balance(node->right) > 0)

? ? ? ? return rl_rotate(node);


? ? return node;

}


void AVL::erase(int key)

{

? ? header->left = erase_real(key, header->left);

}


完整代碼


/**

?*

?* author : 劉毅(Limer)

?* date? ?: 2017-08-17

?* mode? ?: C++

?*/


#include <iostream>

#include <algorithm>


using namespace std;


struct Node

{

? ? int key;

? ? int height;

? ? Node * left;

? ? Node * right;

? ? Node(int key = 0)

? ? {

? ? ? ? this->key = key;

? ? ? ? this->height = 1;

? ? ? ? this->left = this->right = nullptr;

? ? }

};


class AVL

{

private:

? ? Node * header;

private:

? ? Node * ll_rotate(Node * y);

? ? Node * rr_rotate(Node * y);

? ? Node * lr_rotate(Node * y);

? ? Node * rl_rotate(Node * y);

? ? void destroy(Node * node);

? ? int get_height(Node * node);

? ? int get_balance(Node * node);

? ? Node * insert_real(int key, Node * node);

? ? Node * find_real(int key, Node * node);

? ? Node * erase_real(int key, Node * node);

? ? void in_order(Node * node);

public:

? ? AVL();

? ? ~AVL();

? ? void insert(int key);

? ? Node * find(int key);

? ? void erase(int key);

? ? void print();

};


Node * AVL::ll_rotate(Node * y)

{

? ? Node * x = y->left;

? ? y->left = x->right;

? ? x->right = y;


? ? y->height = max(get_height(y->left), get_height(y->right)) + 1;

? ? x->height = max(get_height(x->left), get_height(x->right)) + 1;


? ? return x;

}


Node * AVL::rr_rotate(Node * y)

{

? ? Node * x = y->right;

? ? y->right = x->left;

? ? x->left = y;


? ? y->height = max(get_height(y->left), get_height(y->right)) + 1;

? ? x->height = max(get_height(x->left), get_height(x->right)) + 1;


? ? return x;

}


Node * AVL::lr_rotate(Node * y)

{

? ? Node * x = y->left;

? ? y->left = rr_rotate(x);

? ? return ll_rotate(y);

}


Node * AVL::rl_rotate(Node * y)

{

? ? Node * x = y->right;

? ? y->right = ll_rotate(x);

? ? return rr_rotate(y);

}


void AVL::destroy(Node * node)

{

? ? if (node == nullptr)

? ? ? ? return;

? ? destroy(node->left);

? ? destroy(node->right);

? ? delete node;

}


int AVL::get_height(Node * node)

{

? ? if (node == nullptr)

? ? ? ? return 0;

? ? return node->height;

}


int AVL::get_balance(Node * node)

{

? ? if (node == nullptr)

? ? ? ? return 0;

? ? return get_height(node->left) - get_height(node->right);

}


Node * AVL::insert_real(int key, Node * node)

{

? ? if (node == nullptr)

? ? ? ? return new Node(key);


? ? if (key < node->key)

? ? ? ? node->left = insert_real(key, node->left);

? ? else if (key > node->key)

? ? ? ? node->right = insert_real(key, node->right);

? ? else

? ? ? ? return node;


? ? node->height = max(get_height(node->left), get_height(node->right)) + 1;


? ? int balance = get_balance(node);


? ? // 左左失衡

? ? if (balance > 1 && get_balance(node->left) > 0)

? ? ? ? return ll_rotate(node);


? ? // 右右失衡

? ? if (balance < -1 && get_balance(node->right) < 0)

? ? ? ? return rr_rotate(node);


? ? // 左右失衡

? ? if (balance > 1 && get_balance(node->left) < 0)

? ? ? ? return lr_rotate(node);


? ? // 右左失衡

? ? if (balance < -1 && get_balance(node->right) > 0)

? ? ? ? return rl_rotate(node);


? ? return node;

}


Node * AVL::find_real(int key, Node * node)

{

? ? if (node == nullptr)

? ? ? ? return nullptr;


? ? if (key < node->key)

? ? ? ? return find_real(key, node->left);

? ? else if (key > node->key)

? ? ? ? return find_real(key, node->right);

? ? else

? ? ? ? return node;

}


Node * AVL::erase_real(int key, Node * node)

{

? ? if (node == nullptr)

? ? ? ? return node;


? ? if (key < node->key)

? ? ? ? node->left = erase_real(key, node->left);

? ? else if (key > node->key)

? ? ? ? node->right = erase_real(key, node->right);

? ? else

? ? {

? ? ? ? if (node->left && node->right)

? ? ? ? {

? ? ? ? ? ? // 找到后繼結點

? ? ? ? ? ? Node * x = node->right;

? ? ? ? ? ? while (x->left)

? ? ? ? ? ? ? ? x = x->left;


? ? ? ? ? ? // 后繼直接復制

? ? ? ? ? ? node->key = x->key;


? ? ? ? ? ? // 轉化為刪除后繼

? ? ? ? ? ? node->right = erase_real(x->key, node->right);

? ? ? ? }

? ? ? ? else

? ? ? ? {

? ? ? ? ? ? Node * t = node;

? ? ? ? ? ? node = node->left ? node->left : node->right;

? ? ? ? ? ? delete t;

? ? ? ? ? ? if (node == nullptr)

? ? ? ? ? ? ? ? return nullptr;

? ? ? ? }

? ? }


? ? node->height = max(get_height(node->left), get_height(node->right)) + 1;


? ? int balance = get_balance(node);


? ? // 左左失衡

? ? if (balance > 1 && get_balance(node->left) >= 0) // 需要加等號

? ? ? ? return ll_rotate(node);


? ? // 右右失衡

? ? if (balance < -1 && get_balance(node->right) <= 0) // 需要加等號

? ? ? ? return rr_rotate(node);


? ? // 左右失衡

? ? if (balance > 1 && get_balance(node->left) < 0)

? ? ? ? return lr_rotate(node);


? ? // 右左失衡

? ? if (balance < -1 && get_balance(node->right) > 0)

? ? ? ? return rl_rotate(node);


? ? return node;

}


void AVL::in_order(Node * node)

{

? ? if (node == nullptr)

? ? ? ? return;


? ? in_order(node->left);

? ? cout << node->key << " ";

? ? in_order(node->right);

}


AVL::AVL()

{

? ? header = new Node(0);

}


AVL::~AVL()

{

? ? destroy(header->left);

? ? delete header;

? ? header = nullptr;

}


void AVL::insert(int key)

{

? ? header->left = insert_real(key, header->left);

}


Node * AVL::find(int key)

{

? ? return find_real(key, header->left);

}


void AVL::erase(int key)

{

? ? header->left = erase_real(key, header->left);

}


void AVL::print()

{

? ? in_order(header->left);

? ? cout << endl;

}


int main()

{

? ? AVL avl;


? ? // test "insert"

? ? avl.insert(7);

? ? avl.insert(2);

? ? avl.insert(1); avl.insert(1);

? ? avl.insert(5);

? ? avl.insert(3);

? ? avl.insert(6);

? ? avl.insert(4);

? ? avl.insert(9);

? ? avl.insert(8);

? ? avl.insert(11); avl.insert(11);

? ? avl.insert(10);

? ? avl.insert(12);

? ? avl.print(); // 1 2 3 4 5 6 7 8 9 10 11 12


? ? // test "find"

? ? Node * p = nullptr;

? ? cout << ((p = avl.find(2)) ? p->key : -1) << endl;? ?//? 2

? ? cout << ((p = avl.find(100)) ? p->key : -1) << endl; // -1


? ? // test "erase"

? ? avl.erase(1);

? ? avl.print(); // 2 3 4 5 6 7 8 9 10 11 12

? ? avl.erase(9);

? ? avl.print(); // 2 3 4 5 6 7 8 10 11 12

? ? avl.erase(11);

? ? avl.print(); // 2 3 4 5 6 7 8 10 12


? ? return 0;

}


起初構造的 AVL 樹為下圖:



總結


和二叉查找樹相比,AVL 樹的特點是時間復雜度更穩定,但缺點也是很明顯的。


插入操作中,至多需要一次恢復平衡操作,遞歸回溯的量級為 O(logn)。有一點需要我們注意,在對第一個失衡結點進行恢復平衡后,遞歸回溯就應該立即停止(因為失衡結點的父親及其祖先們肯定都是處于平衡狀態的)。


但讓 "遞歸的回溯" 中途停止,不好實現,所以我上面的編碼程序都不可避免的會繼續回溯,直到整棵樹的根結點,而這些回溯都是沒有必要的。(謝謝 LLL 的提醒,若在結點中增設父親結點,就可以解決遞歸回溯的問題)


刪除操作中,若存在失衡,則至少需要一次恢復平衡操作,遞歸回溯的量級亦為 O(logn)。與插入操作不同,當對第一個失衡結點恢復平衡后,它的父親或者是它的祖先們也可能是非平衡的(見下圖,刪除 1),所以刪除操作的回溯很有必要。



沒有參照物對比的探討是沒有意義的,所以此文就止于此吧,有興趣的朋友可以看下我后面《紅黑樹》及《AVL 樹與紅黑樹的對比》的文章。


參考文獻


維基百科. AVL 樹.


GeeksforGeeks. AVL Tree | Set 1 (Insertion).


GeeksforGeeks. AVL Tree | Set 2 (Deletion).


總結

以上是生活随笔為你收集整理的一文读懂 AVL 树的全部內容,希望文章能夠幫你解決所遇到的問題。

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

免费亚洲黄色 | 成人小视频在线免费观看 | 日本午夜免费福利视频 | 伊人黄 | 国产黄在线看 | 免费日韩一区二区 | 成人网色| 日日操狠狠干 | 亚洲成人精品在线观看 | 粉嫩一区二区三区粉嫩91 | 99 色| 亚洲精品国产自产拍在线观看 | 99久久精品免费看国产一区二区三区 | 免费观看完整版无人区 | 国产精品福利在线 | 麻豆一级视频 | 天天操天天色天天射 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 天天草天天干天天 | 中文网丁香综合网 | 久久综合色一综合色88 | 亚洲欧美激情精品一区二区 | 亚洲动漫在线观看 | 在线观看成年人 | 摸bbb搡bbb搡bbbb | 91完整视频 | 亚洲精品美女久久久久网站 | 91高清在线 | av大片免费 | 国产精品久久久网站 | 五月天激情综合 | 菠萝菠萝蜜在线播放 | 日韩av一区二区三区在线观看 | 99久久精品国产一区二区三区 | 婷婷国产在线观看 | 国产成人在线精品 | 五月婷婷色| 爱射综合 | 探花视频在线观看免费版 | 国产高清av免费在线观看 | 伊人久久精品久久亚洲一区 | 久久婷婷开心 | 日韩久久久久久久久久 | 国内视频1区 | 九九视频精品在线 | 久久久久久久久久久久久久免费看 | 精品视频久久 | 午夜一级免费电影 | 国产精品久久伊人 | 黄色免费电影网站 | 亚洲婷婷在线视频 | 97电影手机版 | 亚洲乱码在线 | 国产精品日韩欧美一区二区 | 蜜臀91丨九色丨蝌蚪老版 | av五月婷婷| 天天天天干 | www黄色| 欧美国产一区在线 | 六月丁香在线视频 | 在线黄色免费 | av免费观看高清 | 免费观看性生交 | 一本色道久久综合亚洲二区三区 | 91完整版观看 | 亚洲一区免费在线 | 一区二区三区电影 | 久久久免费精品国产一区二区 | 日韩国产欧美在线播放 | 色99之美女主播在线视频 | 精品一区中文字幕 | 久久亚洲区 | 91私密保健| 国产中文字幕网 | 伊人天天干 | 天天天天天天操 | 视频在线播放国产 | 国产精品毛片久久久 | 96视频免费在线观看 | 欧美性黄网官网 | 69精品| 国产精品欧美在线 | 国产欧美精品在线观看 | 97超碰人人澡人人爱学生 | av一本久道久久波多野结衣 | 18性欧美xxxⅹ性满足 | 国产在线播放观看 | 免费三级骚| av电影av在线 | 九九热免费在线观看 | 在线国产中文 | 亚洲国内精品视频 | 97视频网址| 91专区在线观看 | 色网av| 日韩av电影中文字幕在线观看 | 国产亚洲欧美精品久久久久久 | 色综合久 | 三上悠亚一区二区在线观看 | 亚洲精品啊啊啊 | 欧美日韩一区二区视频在线观看 | av福利网址导航 | 一区二区三区四区五区在线视频 | av丝袜美腿 | 日韩乱码中文字幕 | 日韩中文字幕在线不卡 | 精品久久久久久综合日本 | 91亚洲精品久久久蜜桃网站 | 婷婷婷国产在线视频 | 久久久久精 | 天天做日日爱夜夜爽 | 国产精品人成电影在线观看 | 六月丁香婷婷在线 | 在线а√天堂中文官网 | 成人国产精品av | 欧美精品xxx | 日韩av电影手机在线观看 | 成人av在线一区二区 | 福利网址在线观看 | 天堂在线一区二区 | av中文字幕第一页 | 最新久久免费视频 | 欧美日韩高清在线 | www.夜夜操.com | 久久99热国产 | 国产精品99久久久久久小说 | 日韩精品视频网站 | 人人澡人人爱 | 999久久久 | 综合久久一本 | 成人一区影院 | 国产一级二级三级视频 | 玖草影院| 激情动态| 精品一区二区日韩 | 久草在线费播放视频 | 成人av片免费观看app下载 | 99在线精品视频观看 | 国产精品一区二区三区99 | 亚洲精品国产精品国产 | 精品视频99 | 精品一二三四五区 | 一区二区三区在线免费观看视频 | 最新久久久 | 中文字幕av网站 | 97操碰 | 91精品久久久久久综合五月天 | 麻豆久久久 | 日本婷婷色 | 97精品国产97久久久久久免费 | 免费观看的黄色 | 亚洲高清视频在线观看免费 | 国产精品久久久久久久久久99 | 99久久精品午夜一区二区小说 | 五月激情av | 少妇高潮冒白浆 | 狠狠色丁香久久婷婷综合_中 | 国产福利中文字幕 | 亚洲色图色| 久久久久久久影视 | av免费看在线 | 高清不卡毛片 | 婷婷视频导航 | 久久免费看视频 | 久久久久久久久艹 | 亚洲国产精品500在线观看 | 国产精品美女免费视频 | 日韩手机视频 | 中文字幕在线网 | 草久中文字幕 | 天天射狠狠干 | 久精品在线观看 | 午夜123| 99久久精品免费看国产四区 | 91片黄在线观看 | 日韩精品一区二区免费视频 | 日本精品一区二区三区在线播放视频 | 国产精品久久久久久久午夜 | 日韩免费大片 | 狠狠躁夜夜a产精品视频 | 亚洲一区二区视频 | 91大神免费在线观看 | 在线观看av麻豆 | 97看片吧 | 国产裸体视频网站 | 在线观看中文字幕视频 | 天天操夜 | 日韩免费观看一区二区三区 | 国产精品一区二区62 | 婷婷色av | 亚洲美女免费精品视频在线观看 | 久久国产美女视频 | 在线观看深夜福利 | 久久9精品 | 精品国产乱码一区二区三区在线 | 97超碰总站 | 国产精品久久久影视 | 韩日精品中文字幕 | 狠狠操导航| 色综合天天爱 | 亚洲欧美视频在线 | 精品国内 | 久久精品一区二区国产 | 色婷婷久久 | 亚洲国产中文字幕 | 国产成人精品久久久 | 欧美一级淫片videoshd | 在线天堂日本 | 91激情小视频 | 成人黄色影片在线 | 99久久精品费精品 | 色综合久久久久久久 | 一区二区三区在线免费观看视频 | 日韩欧美一区二区三区黑寡妇 | 日日精品 | 免费观看v片在线观看 | 欧美做受69| 久操伊人 | 成人播放器 | 久久综合综合久久综合 | 黄色片免费电影 | 亚洲精品在线免费 | 国产日韩精品视频 | 在线中文字幕观看 | 婷婷六月天在线 | 亚洲精品国产综合99久久夜夜嗨 | 在线视频黄 | 九九热视频在线播放 | www久久国产 | 国产一级视频在线 | 日韩欧美在线观看 | 香蕉97视频观看在线观看 | 午夜久久久久久久久久影院 | 国产高清免费在线观看 | 中国一区二区视频 | 天天干夜夜夜 | 最新国产在线 | 区一区二在线 | 国产免费黄视频在线观看 | 亚洲天堂网站 | 国产免费久久久久 | 91精品在线播放 | 色综合久久久久久久久五月 | 精品国产视频一区 | 五月黄色 | 亚洲国产精品成人女人久久 | 欧美精品在线观看免费 | 日韩高清免费无专码区 | 综合网欧美| 又黄又爽的免费高潮视频 | 亚洲色图 校园春色 | 香蕉视频免费看 | 91九色porny蝌蚪主页 | www欧美日韩 | 99久久精品无码一区二区毛片 | a在线观看国产 | 四虎在线视频免费观看 | 精品a视频| 69av在线播放| 欧美日韩中文在线观看 | 热久久精品在线 | 超碰在线日本 | 久久久久激情电影 | 国产精品不卡在线播放 | 亚洲影视九九影院在线观看 | 色哟哟国产精品 | 国产手机在线 | 四虎成人免费观看 | 亚州精品在线视频 | www.五月婷婷 | 日韩大片在线免费观看 | 在线观看亚洲视频 | 成人一区在线观看 | 免费视频久久久久久久 | 97电影院网 | 免费三级黄 | 国产精品毛片一区二区三区 | 五月天色婷婷丁香 | 日韩美女av在线 | 日韩av伦理片 | 日韩在线理论 | 成人丁香花 | 国产一级特黄电影 | 欧美在线观看视频一区二区三区 | 一二三区av | 婷婷色婷婷 | 精品国产精品久久 | 欧美二区在线播放 | 黄色毛片观看 | 韩国av一区二区三区 | 中文字幕之中文字幕 | 精品久久久久久一区二区里番 | 黄色在线观看www | 97人人添人澡人人爽超碰动图 | 国产免费观看高清完整版 | 中文国产在线观看 | 一区二区三区在线免费 | 韩国av一区二区三区在线观看 | 九草视频在线 | 亚洲毛片一区二区三区 | 91精品成人 | 丝袜+亚洲+另类+欧美+变态 | 亚洲日韩中文字幕 | 欧美午夜精品久久久久久浪潮 | 国产日韩欧美在线播放 | 欧美九九视频 | 在线v | 中文字幕乱码日本亚洲一区二区 | 精产嫩模国品一二三区 | 日韩精品一区二区三区免费视频观看 | 亚洲免费一级电影 | 69国产盗摄一区二区三区五区 | 国产精品久久久久久五月尺 | 婷婷久久综合网 | 蜜臀久久99精品久久久无需会员 | 丝袜美女视频网站 | 三级毛片视频 | 中国一级片免费看 | 国产精品免费一区二区三区在线观看 | 色欲综合视频天天天 | 深爱开心激情网 | 日本成人免费在线观看 | 国产999精品久久久久久绿帽 | 五月天婷亚洲天综合网鲁鲁鲁 | 天天草天天干天天 | 91精品国产成人观看 | а天堂中文最新一区二区三区 | 欧美少妇的秘密 | 国产91全国探花系列在线播放 | 日韩黄视频 | 丁香婷婷综合激情五月色 | 国产男女无遮挡猛进猛出在线观看 | 国产裸体永久免费视频网站 | 中文在线字幕免 | 国产高清在线a视频大全 | 亚州国产精品 | 国产精品久久久久三级 | 天天干天天搞天天射 | 中文字幕2021 | 国产成人精品av | 国产不卡av在线 | 国产精品18久久久久久久 | 精品在线观看一区二区 | 久久精品久久精品久久39 | 国产中出在线观看 | 久久久久99精品国产片 | 成人免费网站在线观看 | 国产精品第十页 | 精品1区二区 | 亚洲精品久久久久中文字幕二区 | 久久99精品一区二区三区三区 | 一区二区中文字幕在线观看 | 欧美 亚洲 另类 激情 另类 | 国产免费区 | 91视频在线播放视频 | 亚洲欧洲精品一区 | 亚洲激情六月 | 欧美一二三四在线 | av资源在线看 | 中文字幕色在线视频 | 国产精品综合久久久 | 五月天综合色激情 | 久久免费电影网 | 欧美日韩国产一区二区三区在线观看 | 美女久久久久久 | www麻豆视频| 成年人在线免费看片 | 久久久九色精品国产一区二区三区 | 国产小视频在线看 | 亚洲午夜精品福利 | 日韩高清久久 | 免费在线视频一区二区 | 男女啪啪视屏 | 日韩精品一区二区三区不卡 | 亚洲v欧美v国产v在线观看 | 最新中文字幕在线观看视频 | 成人免费看片网址 | 免费在线观看成人 | 91久久国产自产拍夜夜嗨 | a视频免费在线观看 | 免费在线色视频 | 国产香蕉视频在线播放 | 韩国一区二区av | 国产综合91| 天天干天天操天天拍 | 免费十分钟 | 国产亚洲日 | 国产精品资源在线 | 国产传媒中文字幕 | 精品国产99国产精品 | 国产丝袜网站 | 波多野结衣在线播放一区 | 国产永久免费观看 | 日韩在线资源 | 日韩欧美网址 | 日本在线h | 亚洲国产中文字幕在线观看 | 狂野欧美激情性xxxx | 西西444www大胆无视频 | 国产精品成人av在线 | 亚洲国产精品激情在线观看 | 黄网站色视频 | 伊人天天色| 日日日日干 | 国产高清久久 | 精品av在线播放 | 在线观看av的网站 | 9797在线看片亚洲精品 | 欧美激情精品久久久 | 国产一区黄色 | 国产二区视频在线 | 亚洲区另类春色综合小说校园片 | 一区二区三区在线视频111 | 怡红院av| 丁香花中文在线免费观看 | 久久综合久久鬼 | 国产精品久久99综合免费观看尤物 | 天天干人人插 | 天天天干 | 九九热免费精品视频 | 久香蕉 | 在线激情影院一区 | 国产精品 亚洲精品 | 久久综合成人网 | av中文字幕日韩 | 精品视频免费 | 伊人av综合 | 久久免费在线观看视频 | 在线免费观看黄网站 | 亚洲妇女av| 日韩视频一区二区 | 中文字幕在线观 | 日本精品在线看 | av久久在线 | 国产精品久久久久久久久久直播 | 2019中文最近的2019中文在线 | 亚洲精品乱码久久久一二三 | 亚洲a网 | 久久夜av| 深爱婷婷网 | 96久久 | x99av成人免费 | 超碰在线观看av.com | 欧美a级成人淫片免费看 | 日韩xxx视频| 国产精品视频久久久 | www日韩欧美 | 精品国内自产拍在线观看视频 | av成人免费在线 | 日本久久久影视 | 精品欧美乱码久久久久久 | 欧美特一级片 | 久草在线免费在线观看 | 日本韩国精品一区二区在线观看 | 在线视频 一区二区 | 亚洲精品国产成人av在线 | 色综合久久久网 | 亚洲精品乱码久久久久久蜜桃欧美 | 91热精品 | 国产精品美女久久久久久网站 | 日韩欧美99| 亚洲欧洲精品一区二区精品久久久 | 欧美色图亚洲图片 | 国产精品久久久久久久久费观看 | 99视频免费观看 | 久久9999久久免费精品国产 | 久久婷婷综合激情 | 国产精品专区h在线观看 | 国产在线观看免费 | 69久久夜色精品国产69 | 91少妇精拍在线播放 | 久久国产精品色av免费看 | 免费日韩av片| 99热播精品 | 欧美激情综合网 | 日本精品中文字幕 | 午夜黄色影院 | 欧美国产一区二区 | 亚洲免费不卡 | 日韩视频1区 | 欧美91精品久久久久国产性生爱 | 在线精品观看国产 | 国产精品视频你懂的 | 欧美精品一区二区免费 | 99视频国产精品免费观看 | 国产一区视频在线 | 一级片免费在线 | 日本mv大片欧洲mv大片 | 日韩av一区二区在线 | 在线国产一区二区三区 | 国产精成人品免费观看 | 婷婷六月天天 | 成人国产精品久久久春色 | 久草久热 | 国产a级片免费观看 | 久久看看| 久久九九久久精品 | 日韩久久久久久久 | 91片黄在线观 | 亚洲一二三在线 | 青青河边草免费直播 | 久爱精品在线 | 玖玖玖国产精品 | 天天操天天干天天爱 | 最新av在线播放 | 九色精品免费永久在线 | 亚洲 欧美 综合 在线 精品 | 日本免费久久高清视频 | 国产精品久久久久久久久久新婚 | 国产无遮挡又黄又爽在线观看 | 久久久久亚洲精品成人网小说 | 久草色在线观看 | 国产综合精品一区二区三区 | 国产喷水在线 | 在线天堂日本 | 亚洲日日夜夜 | 久久久国产影院 | 国产无遮挡又黄又爽在线观看 | 看片网站黄 | 亚洲精品午夜视频 | www.久热| 精品国产理论 | 我要看黄色一级片 | 日韩在线视频网 | 激情综合网色播五月 | 亚洲妇女av | 天天爱天天操天天射 | 欧美一区二区三区在线 | 夜色资源网 | 日日夜夜中文字幕 | 婷婷伊人综合 | 狠狠狠狠狠干 | 91久久精品一区二区二区 | 手机看片1042 | 久久99久久99精品中文字幕 | 亚洲成av人片在线观看无 | 精品视频久久 | 欧美一二三区在线观看 | 日韩欧美国产激情在线播放 | 国产明星视频三级a三级点| 久草精品视频 | 久久黄页 | 日韩在线视 | 日本公乱妇视频 | 国产在线国偷精品产拍 | 日韩精品高清视频 | 综合网天天射 | 久久精品5| 九九99| 亚洲精品久久久久999中文字幕 | 一区二区三区日韩在线 | 中国一级片在线播放 | 亚洲欧美视频在线观看 | 国产一二区视频 | 国产精品网址在线观看 | 国产精品久久久久一区 | 日韩精品一二三 | 精品国产一区二区三区不卡 | 国产激情小视频在线观看 | 久久精品视频在线观看免费 | 99人成在线观看视频 | 国内亚洲精品 | 成人丝袜 | 一区二区在线不卡 | 亚洲亚洲精品在线观看 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产一区在线不卡 | av 一区二区三区四区 | 日日激情| 国产香蕉在线 | 中文字幕色网站 | 国产精品va在线播放 | 免费一级片观看 | 亚洲涩涩涩 | 中国一级片视频 | 六月丁香伊人 | 久草在线网址 | 国产99在线播放 | 久久综合九色综合欧美狠狠 | 中文字幕一区在线观看视频 | www在线免费观看 | www.97视频| 涩涩色亚洲一区 | 欧美日韩精品在线观看视频 | 久久久久久久久福利 | 国产日产精品久久久久快鸭 | 婷婷激情影院 | 精品国内自产拍在线观看视频 | 色在线免费视频 | 久九视频 | 亚洲一片黄 | 亚洲精品五月天 | 天天操天天爽天天干 | 天堂网av 在线 | 国产精品区二区三区日本 | 永久免费视频国产 | 久久日韩精品 | 国内久久久久 | a级国产乱理论片在线观看 特级毛片在线观看 | 国产黄色看片 | 日韩av在线高清 | 91免费版成人 | 亚洲日本成人 | 在线免费日韩 | 国产天天爽 | 欧美另类巨大 | 亚洲国产中文字幕在线视频综合 | 精品少妇一区二区三区在线 | 香蕉影院在线播放 | 午夜私人影院 | 天天曰天天曰 | 国产精品久久久久久久久久久久久久 | 国产视频在线一区二区 | 日韩av网址在线 | 91亚洲精品久久久久图片蜜桃 | 成人网444ppp| 91视频久久久久 | 三级小视频在线观看 | 九色精品 | 99久久99久久综合 | 欧美午夜寂寞影院 | 久久只精品99品免费久23小说 | 超碰国产人人 | 在线国产小视频 | 亚洲国产视频a | 国产不卡在线观看 | 超碰97在线看 | 欧美一区二区三区在线看 | 五月婷av| 99中文视频在线 | 天天草天天干 | 国模一二三区 | 日韩乱色精品一区二区 | 九九热久久免费视频 | 欧美日韩国产二区 | 久久大视频 | 正在播放五月婷婷狠狠干 | 亚州欧美视频 | 成年人黄色免费视频 | 天天玩天天干 | 精品久久久久久久久久岛国gif | 狠狠综合久久 | 免费成人在线网站 | 国产手机在线视频 | 国产香蕉av | 国产91免费观看 | 色婷婷99| 国产精品久久久久久超碰 | 日本三级大片 | 久久99国产综合精品 | 欧美日韩国产三级 | 免费av高清 | 一区二区三区在线观看免费 | 国产四虎影院 | 8x成人免费视频 | 黄a在线看 | 日本精品二区 | 日本黄色片一区二区 | 国产精品乱码高清在线看 | 国产69精品久久99不卡的观看体验 | 日本黄色一级电影 | 国产精品久久伊人 | 精壮的侍卫呻吟h | 久久久久久久久电影 | 二区三区在线观看 | 国产精品成人在线 | 欧美最猛性xxx | 亚洲专区视频在线观看 | 蜜臀一区二区三区精品免费视频 | 在线视频日韩欧美 | 天天插伊人 | 日批在线观看 | 六月激情| 日韩视频中文字幕 | 国产美女免费观看 | 色综合天天天天做夜夜夜夜做 | 日日夜夜综合网 | 久久经典国产视频 | 正在播放一区二区 | 亚洲视频每日更新 | 日韩欧美在线免费观看 | 精品91在线| 精品国产免费人成在线观看 | 亚洲乱亚洲乱亚洲 | 四虎国产精品免费 | 99riav1国产精品视频 | 在线观看免费国产小视频 | 中文字幕在线日 | 人人草网站 | 91色欧美 | 国产精品久久久久久久久免费 | 久久激情电影 | 99精品在线视频播放 | 久久tv视频 | 狠狠网 | 日韩成人黄色 | 福利视频一区二区 | 中文字幕在线观看的网站 | 欧美 国产 视频 | 中文字幕精| 中文字幕免费不卡视频 | 国产精品久久久久久久久久久免费 | 久久久综合九色合综国产精品 | 婷婷在线观看视频 | 久久精品欧美一区二区三区麻豆 | 日韩一区二区三区在线看 | 国产精品成人国产乱一区 | 免费中午字幕无吗 | 国产精品成人一区 | 国产成人99久久亚洲综合精品 | 免费看日韩片 | 亚洲黄色成人网 | 国产夫妻av在线 | 四虎在线免费观看 | 在线中文字幕网站 | 国产美女网站在线观看 | 啪啪免费视频网站 | 久久久人人人 | 欧美无极色 | 黄色小说视频在线 | www.av免费 | 中国一级片免费看 | 91最新中文字幕 | 一级一片免费看 | 国产婷婷| 激情 一区二区 | 午夜美女福利 | 天天爽天天摸 | 日韩成人精品一区二区三区 | 久艹视频在线免费观看 | 91香蕉视频污在线 | 欧美一级免费黄色片 | 日韩激情视频在线 | 中文字幕在线视频一区二区 | 国产特黄色片 | 又湿又紧又大又爽a视频国产 | 亚洲专区免费观看 | 国产精品永久免费在线 | 婷婷激情五月综合 | 一级性av| 久久www免费人成看片高清 | 天天干,天天射,天天操,天天摸 | 91av视频播放 | 插综合网 | 免费观看日韩av | 久久综合九色欧美综合狠狠 | 黄色三级在线观看 | 最新国产一区二区三区 | 国产福利免费在线观看 | 天天干夜夜想 | 成人精品久久久 | 国产高清视频在线观看 | 久草色在线观看 | 黄色日视频| 黄色午夜| 91亚洲精品久久久蜜桃网站 | 911在线| 精品产品国产在线不卡 | 国产aaa大片 | 国内外成人免费在线视频 | 99爱视频在线观看 | 国产精品久久人 | 99视频精品全部免费 在线 | 九九视频免费在线观看 | 狠狠插狠狠操 | 亚洲经典视频在线观看 | 91精品天码美女少妇 | av中文天堂在线 | 91中文字幕在线视频 | 国产永久免费 | 五月婷婷一区 | 黄网站www| 六月婷婷久香在线视频 | 丁香婷婷激情啪啪 | 超碰在线日本 | 亚洲va综合va国产va中文 | 国产精品mv| 中文字幕在线免费看线人 | 91香蕉视频污在线 | 99精品视频免费观看视频 | 日本公妇色中文字幕 | 久久精品国产一区二区三区 | 欧美日韩有码 | www.黄色 | 久草国产精品 | 97精品超碰一区二区三区 | 天天射天天干天天插 | 国产精品久久久久一区 | 国产亚洲成av片在线观看 | 日韩久久午夜一级啪啪 | 91中文字幕在线观看 | 99久久成人| 欧美日韩中文国产 | 午夜av不卡 | 国产精品视频线看 | 99久久久久久久久久 | 欧美久久久久久久 | h视频在线看 | 国内毛片毛片 | 最新精品视频在线 | 久久99精品久久久久久三级 | 天天色天天| 亚洲理论在线观看 | 色婷婷视频 | 日韩精品免费一区二区在线观看 | 国产无套视频 | 91人人爽人人爽人人精88v | 97人人模人人爽人人喊网 | 2021国产精品 | 亚洲精品国产精品国自 | 日韩免费一区二区在线观看 | 成人小视频在线 | 国产999精品久久久影片官网 | 国产成人精品一区二区三区免费 | 岛国大片免费视频 | 国产精品国产三级国产不产一地 | 亚洲乱亚洲乱妇 | 视频精品一区二区三区 | 国产一区二区高清 | 国产黄色观看 | 日韩精品2区 | 国产黄在线免费观看 | 亚洲一区二区三区精品在线观看 | 五月婷婷免费 | 69精品视频在线观看 | 西西人体4444www高清视频 | 国产xx视频 | 国产精品一区二区三区免费视频 | 天天躁天天狠天天透 | 欧美午夜一区二区福利视频 | 国产一区二区视频在线播放 | 最近中文字幕免费av | 精品久久久成人 | 成人免费大片黄在线播放 | 久久久久久久久久久电影 | 欧美另类xxxx | 婷婷色 亚洲 | 激情大尺度视频 | 国产人在线成免费视频 | 欧美成人性网 | 天堂网一区二区 | adn—256中文在线观看 | 日韩动漫免费观看高清完整版在线观看 | 天天操夜夜曰 | 91丨九色丨蝌蚪丨对白 | 草久久久 | 热久精品 | 免费视频黄 | 九九九九免费视频 | 最新av观看 | 久久久夜色| av官网 | 欧美性另类 | 51精品国自产在线 | 日韩高清不卡一区二区三区 | 日日摸日日添夜夜爽97 | 国产精品久久99综合免费观看尤物 | 亚洲第一香蕉视频 | 久久手机精品视频 | 手机成人av| 超碰激情在线 | 久久只有精品 | 亚洲va综合va国产va中文 | 成人av在线观 | 国产成人精品一区二区三区福利 | 日韩最新在线视频 | 99国产一区二区三精品乱码 | 永久免费视频国产 | 日本黄色免费看 | 久久久久久激情 | 99免费在线视频 | 日韩剧| av电影一区二区三区 | 亚洲黄色免费在线看 | 五月婷婷中文网 | 日韩在线一二三区 | 成人一级影视 | 伊人五月天 | 久久久免费观看 | 国产精品一区二区在线免费观看 | 黄色a一级片 | 久久av免费 | 国产99在线免费 | 国产又粗又猛又爽又黄的视频先 | 免费黄色看片 | 国产1区2区3区精品美女 | 婷婷av综合 | 亚洲免费观看视频 | 欧美一级黄色视屏 | 国产精品视频免费在线观看 | 亚洲黄色一级电影 | 99国内精品久久久久久久 | 中文字幕在线观看免费高清完整版 | 日韩有码第一页 | 人人看人人做人人澡 | 天天综合网久久 | 97在线资源 | 国产三级午夜理伦三级 | 亚洲午夜不卡 | 亚洲日本色| 五月视频 | 黄色av电影免费观看 | 午夜视频免费在线观看 | 婷婷丁香激情五月 | 国产成人黄色网址 | 激情黄色av| 久久呀| 免费av观看网站 | 日韩欧美精品在线视频 | 亚洲中字幕 | 91成人破解版 | 亚洲天堂自拍视频 | 五月天丁香 | 精品久久1| 91在线网址 | 国产精品99久久久久久久久久久久 | 国外调教视频网站 | 丁香六月在线观看 | 久久久2o19精品 | av在线进入 | 日韩视频区 | japanese黑人亚洲人4k | 国产日本亚洲高清 | av在线免费不卡 | 婷婷综合亚洲 | 超碰在线98| 丁香婷婷久久久综合精品国产 | 国产视频2区 | 国产精品theporn | 九九日九九操 | 久久不卡国产精品一区二区 | 久草在线观看视频免费 | 亚洲精品国产精品国自 | 天天天干| 成人av影院在线观看 | 黄色在线观看网站 | 手机版av在线| 午夜免费福利视频 | 国产成人91| 亚洲欧美国产视频 | 日韩视频欧美视频 | 丁香影院在线 | 另类五月激情 | avlulu久久精品 | 久久资源在线 | 91天堂在线观看 | 亚洲精品日韩一区二区电影 | 欧美五月婷婷 | 成人av高清在线 | 麻豆影视网 | 欧美伦理一区 | 国产精品久久久久久久久久久久午夜 | 亚洲乱码久久久 | 91男人影院| 欧美精品久久久久久久免费 | 欧美精品亚洲精品日韩精品 | 欧美激情第八页 | 中文字幕字幕中文 | 久久精品亚洲一区二区三区观看模式 | 色 中文字幕 | 中文字幕黄色网址 | 五月香视频在线观看 | 911av视频 | 国产剧情av在线播放 | 激情久久伊人 | 亚洲乱码中文字幕综合 | 亚洲精品国精品久久99热 | 涩涩网站在线观看 | 韩国在线一区二区 | 欧美性天天| 999男人的天堂 | 亚洲日本在线视频观看 | 久久9精品 | 国产系列在线观看 | av电影免费在线看 | 国产日韩精品在线观看 | 色婷婷国产精品一区在线观看 | 欧美一区二区精美视频 | 91九色视频国产 | 九九久久久 | av短片在线观看 | 韩国av一区二区三区 | 超碰在线97国产 | 欧美在线观看视频免费 | 亚洲国产中文字幕在线 | 天天狠狠操 | 六月丁香激情综合色啪小说 | 亚洲资源 | 在线观看免费视频 | 黄色av一区二区三区 | 精品国产亚洲在线 | 亚洲首页 | jizz18欧美18| 亚洲成人在线免费 | 欧美一级欧美一级 | 亚洲精品久久久久58 | 天天干天天摸天天操 | 久久综合亚洲鲁鲁五月久久 |