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

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

生活随笔

當(dāng)前位置: 首頁(yè) >

2021-10-11 二叉树,二叉搜索树及其相关23个操作 C++实现笔记(复习用,含C指针复习)

發(fā)布時(shí)間:2025/3/20 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2021-10-11 二叉树,二叉搜索树及其相关23个操作 C++实现笔记(复习用,含C指针复习) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

學(xué)數(shù)據(jù)結(jié)構(gòu)到現(xiàn)在寫的最久的一部分,簡(jiǎn)單總結(jié)一下這一周
1.考慮到未來(lái)考試要求,實(shí)現(xiàn)語(yǔ)言從java換成了C++,沒(méi)想到意外的順利
2.沒(méi)別的了,干就完了
3.代碼肯定有錯(cuò)誤的地方,雖然我自認(rèn)為是完美主義者,但都是為了效率沒(méi)辦法啦

//! *指針變量,例如:int b = *p; *代表取值運(yùn)算符,返回地址指向的值(不是地址本身,p是地址本身) //! 做個(gè)比喻*p就是找到地址為p的箱子,然后*打開(kāi)箱子取出里面的東西,然后把東西賦值給b //! 定義指針變量,例如:int *p = &a; 中的int*p只是表明p是一個(gè)指針變量,變量類型為int*(int類型指針變量),不要和別的*p整混 //! &代表取地址符,&a就是拿到變量a的地址//! **指針變量,也稱二重指針,例如:int *p = a; int **q = &p; //! 二重指針就是指指向一個(gè)指針類型變量的地址的指針,這里p存放a的地址,q存放的就是p的地址 此時(shí) *q = p; //! 同理int ***m = &q; 稱為三重指針,就是存放二重指針q的地址的,此時(shí) *m = q; //! *p = a = **q = *(*q)= ***m = *(*(*m)) ; 知道了上面的原理這個(gè)不難推出來(lái)把//! 結(jié)構(gòu)體指針變量,例如:Node *node = new Node(10); 此時(shí)訪問(wèn)node的成員變量element有兩種等同的方法: //! (*node).element 或 node -> element ,所謂 ->運(yùn)算符就是結(jié)構(gòu)體指針訪問(wèn)其指向的結(jié)構(gòu)體成員變量專用的,這樣就不用*node了 //! node此時(shí)就是一個(gè)結(jié)構(gòu)體指針變量,普通結(jié)構(gòu)體訪問(wèn)成員變量只需要node.element就可以了,但此時(shí)node是指針,我們是new出來(lái)的//! 遞歸:在函數(shù)和子過(guò)程內(nèi)部,直接或間接地調(diào)用自己(比如在函數(shù)定義內(nèi)部出現(xiàn)了自己的函數(shù)名) //! 遞歸思想:把問(wèn)題轉(zhuǎn)化成同類的規(guī)模更小的子問(wèn)題,先解決子問(wèn)題,再通過(guò)相同的求解步驟逐步解決更高層次的問(wèn)題,最終得到最終解 //! 公式表達(dá):x0 -> (x1 = f(x0)) -> x2 = f(x1) -> x3 = f(x2) ...->xn = f(x(n-1)) xn為最終解 (文字表達(dá)好抽象,不如畫(huà)圖看視頻) //! 因?yàn)槲覀兪前汛髥?wèn)題逐步分解為小問(wèn)題,再由最小小問(wèn)題開(kāi)始逐步回到大問(wèn)題,所以我們需要記住大問(wèn)題和中間小問(wèn)題,因?yàn)闂>哂杏洃浶?#xff0c;先進(jìn)后出,遞歸就是應(yīng)用了系統(tǒng)棧 //! 棧內(nèi)部:{f(x(n-1)),f(x(n-2))....f(x1),f(x0)} 問(wèn)題從f(x(n-1))開(kāi)始依次push進(jìn)去,然后從數(shù)組尾部依次pop即使是一個(gè)有序數(shù)組,插入和刪除元素的時(shí)間復(fù)雜度也只能做到O(n) //而使用二叉搜索樹(shù),插入刪除和搜索的最壞時(shí)間復(fù)雜度均可優(yōu)化至O(logn)//二叉搜索樹(shù):一棵二叉樹(shù),任何結(jié)點(diǎn)的左子結(jié)點(diǎn)小于該節(jié)點(diǎn),右子節(jié)點(diǎn)大于該節(jié)點(diǎn) //二叉搜索樹(shù)沒(méi)有索引index(下標(biāo))一說(shuō),因?yàn)樗饕驮氐拇笮『臀恢枚紵o(wú)關(guān),沒(méi)有意義//前序遍歷(Preorder Traversal) //訪問(wèn)順序:根結(jié)點(diǎn),前序遍歷左子樹(shù),前序遍歷右子樹(shù)//中序遍歷(Inorder Traversal) //訪問(wèn)順序:中序遍歷左子樹(shù),根節(jié)點(diǎn),中序遍歷右子樹(shù)(先右后左也可以,只要根節(jié)點(diǎn)在中間訪問(wèn),都叫中序遍歷,同理前序后序) //二叉搜索樹(shù)進(jìn)行中序遍歷,會(huì)使元素以升序或降序呈現(xiàn)//后序遍歷(Postorder Traversal) //訪問(wèn)順序:后序遍歷左子樹(shù),后序遍歷右子樹(shù),根節(jié)點(diǎn)//層序遍歷(Levelorder Traversal) //訪問(wèn)順序:一層一層訪問(wèn)結(jié)點(diǎn)//頭文件版的二叉搜索樹(shù),直接在頭文件里寫類的定義就行//!二叉搜索樹(shù)的添加刪除,搜索操作的時(shí)間復(fù)雜度跟樹(shù)的高度有關(guān),為O(h)(相比線性表的O(n)搜索以及添加的話) //! 滿二叉樹(shù)的高度基本是logn,所以滿的二叉搜索樹(shù)的時(shí)間復(fù)雜度也接近O(logn) //! 但是如果二叉搜索樹(shù)建立的順序,輸入是一個(gè)有序數(shù)組的話,比如1,2,3,4,5,。。。n這樣建立的二叉搜索樹(shù)高度就等于n //! 也就是最壞時(shí)間復(fù)雜度等于O(n),被稱為二叉搜索樹(shù)退化為鏈表 //! 所以我們要盡力維持時(shí)間復(fù)雜度在O(h)而不是O(n)//! 平衡的概念:二叉樹(shù)結(jié)點(diǎn)數(shù)量固定,左右子樹(shù)高度越接近就越平衡,完全二叉樹(shù)和滿二叉樹(shù)是最平衡的//! 所以如何改進(jìn)我們的二叉搜索樹(shù)?? //! 1.改變添加刪除的元素順序,簡(jiǎn)介控制樹(shù)的高度 2.改善添加元素后的二叉樹(shù),使之更平衡 //! 我們?cè)O(shè)計(jì)的二叉搜索樹(shù)是給別人用的,所以添加刪除的順序,我們無(wú)法改變,所以我們只能從添加后的二叉樹(shù)的平衡改進(jìn)入手 //! 一顆達(dá)到適度平衡的二叉搜索樹(shù) ,我們稱之為平衡二叉搜索樹(shù) 比如:AVL樹(shù),紅黑樹(shù) //! AVL樹(shù)是以其發(fā)明者命名的,發(fā)明者是一個(gè)蘇聯(lián)科學(xué)家,AVL樹(shù)是最早發(fā)明的自平衡二叉搜索樹(shù)之—,搜索、添加、刪除的時(shí)間復(fù)雜度是O(logn)O(logn) //! 平衡因子:該結(jié)點(diǎn)平衡因子等于左子樹(shù)高度減去右子樹(shù)高度,絕對(duì)值小于等于1,即超過(guò)1或小于-1,即為失衡,就要自動(dòng)調(diào)整#include <iostream> #include "queue" #include "stack" #include <string> #include <algorithm> using namespace std;class Node { public:int element;Node *left;Node *right;Node *parent;Node(){this->element = 0;this->left = nullptr;this->right = nullptr;this->parent = nullptr;}Node(int element){this->element = element;this->left = nullptr;this->right = nullptr;this->parent = nullptr;} };class BinarySearchTreesZH { private:int size;public://我這里把根節(jié)點(diǎn)寫成public了,主要后面寫一些函數(shù)可以方便點(diǎn)Node *root = nullptr;void add(int element); //添加元素Node *searchBST(int element, Node *root); //二叉樹(shù)搜索bool isEmpty(); //是否為空void clear(); //清空void clear(Node *node); //清空以node為根結(jié)點(diǎn)的子樹(shù)void preorderTraversal(Node *root); //前序遍歷遞歸void inorderTraversal(Node *root); //中序遍歷遞歸void postorderTraversal(Node *root); //后序遍歷遞歸void levelorderTraversal(Node *root); //層序遍歷(隊(duì)列)void preorderTraversalNoRecursion(Node *root); //前序遍歷迭代(模擬棧)void inorderTraversalNoRecursion(Node *root); //中序遍歷迭代(模擬棧)void postorderTraversalNoRecursion(Node *root); //后序遍歷迭代(模擬棧)int height(Node *node); //求樹(shù)高度迭代int heightNoRecursion(Node *node); //求樹(shù)高度迭代(層序遍歷)bool isCompleteTree(Node *node); //完全性檢驗(yàn)(層序遍歷)Node *invertTreePreOrder(Node *node); //翻轉(zhuǎn)二叉樹(shù)(前序遍歷)Node *invertTreeInOrder(Node *node); //翻轉(zhuǎn)二叉樹(shù)(中序遍歷)Node *invertTreePostOrder(Node *node); //翻轉(zhuǎn)二叉樹(shù)(后序遍歷)Node *invertTreeLeverOrder(Node *node); //翻轉(zhuǎn)二叉樹(shù)(層序遍歷)Node *searchNode(int key, Node *node); //查找結(jié)點(diǎn)(前序遍歷)Node *predecessor(Node *node); //找前驅(qū)結(jié)點(diǎn)Node *successor(Node *node); //找后繼節(jié)點(diǎn)void remove(Node *node); //刪除節(jié)點(diǎn) };bool BinarySearchTreesZH::isEmpty() {if (size == 0){return true;}else{return false;} }void BinarySearchTreesZH::add(int element) {Node *node = new Node(element); // 新new一個(gè)結(jié)點(diǎn)在堆區(qū),存儲(chǔ)輸入的數(shù)值//! 要記得new傳送回來(lái)的是對(duì)象在堆區(qū)的地址,一定要用指針變量來(lái)接收if (root == nullptr){ //如果樹(shù)目前為空,則使之成為根結(jié)點(diǎn)root = node;size++;return;}//通過(guò)二叉搜索樹(shù)的特性,查找需要插入的位置Node *nextCompare = root;//代表需要進(jìn)行比較的結(jié)點(diǎn),比它大則移動(dòng)到它的右結(jié)點(diǎn),比他小就移動(dòng)到它的左結(jié)點(diǎn),進(jìn)行下一次比較Node *parent = root;//記錄移動(dòng)前的nextCompare,即nextCompare循環(huán)到null時(shí),它的父結(jié)點(diǎn),也是插入位置的父結(jié)點(diǎn)while (nextCompare != nullptr){parent = nextCompare;if (node->element < nextCompare->element){nextCompare = nextCompare->left;}else if (node->element > nextCompare->element){nextCompare = nextCompare->right;}else if (node->element = nextCompare->element) //若已有相同元素,直接return{return;}}if (node->element < parent->element) //與找到的父結(jié)點(diǎn)進(jìn)行比較,并插入{parent->left = node;}else if (node->element > parent->element){parent->right = node;}//這里不用delete nextCompare 和parent ,因?yàn)椴皇莕ew出來(lái)的,隨著成員函數(shù)執(zhí)行完就自動(dòng)銷毀了size++;return; } //二叉搜索樹(shù)搜索元素 Node *BinarySearchTreesZH::searchBST(int element, Node *root) {if (root == nullptr){return nullptr;}Node *node = root;while (node != nullptr){if (element == node->element){return node;}if (element < node->element){node = node->left;}if (element > node->element){node = node->right;}}cout<<"Not Found"<<endl;return nullptr; }//前序遍歷,遞歸版本,三個(gè)遍歷的遞歸寫法思想都一致,唯一區(qū)別就是在什么時(shí)候訪問(wèn)根結(jié)點(diǎn) //畫(huà)個(gè)圖和棧更好理解,這里不多解釋 void BinarySearchTreesZH::preorderTraversal(Node *node) {if (node == nullptr){return;}cout << node->element << " ";preorderTraversal(node->left);preorderTraversal(node->right); } //! 簡(jiǎn)單理解遞歸遍歷二叉樹(shù),把遍歷整個(gè)二叉樹(shù)這個(gè)大問(wèn)題,轉(zhuǎn)化為遍歷根節(jié)點(diǎn)的無(wú)數(shù)個(gè)子樹(shù) //! 因?yàn)楸闅v一個(gè)只有三個(gè)結(jié)點(diǎn)的二叉樹(shù)的解決方式是一樣的,比如中序遍歷,先訪問(wèn)左子節(jié)點(diǎn),根節(jié)點(diǎn)就在中間訪問(wèn),然后訪問(wèn)右子結(jié)點(diǎn) //! 而遞歸只不過(guò)是把訪問(wèn)子結(jié)點(diǎn)這個(gè)過(guò)程變成了先訪問(wèn)一顆以這個(gè)子結(jié)點(diǎn)為根結(jié)點(diǎn)的三個(gè)結(jié)點(diǎn)的子樹(shù)的過(guò)程,然后把過(guò)程結(jié)果返回,當(dāng)作該子結(jié)點(diǎn)的訪問(wèn)結(jié)果 //! 深入理解就是棧的思想,畫(huà)圖//中序遍歷,遞歸版本 void BinarySearchTreesZH::inorderTraversal(Node *node) {if (node == nullptr){return;}inorderTraversal(node->left);cout << node->element << " "; //! 就是根節(jié)點(diǎn)在中間訪問(wèn),先訪問(wèn)左子樹(shù),然后根節(jié)點(diǎn),然后右子樹(shù),對(duì)于子樹(shù)的訪問(wèn)也是一樣在中間訪問(wèn)根節(jié)點(diǎn)inorderTraversal(node->right); }//后序遍歷,遞歸版本 void BinarySearchTreesZH::postorderTraversal(Node *node) {if (node == nullptr){return;}postorderTraversal(node->left);postorderTraversal(node->right);cout << node->element << " "; }//! 層序遍歷,很重要,精髓在于對(duì)于隊(duì)列的應(yīng)用 void BinarySearchTreesZH::levelorderTraversal(Node *node) {queue<Node *> list; //創(chuàng)建結(jié)構(gòu)體指針隊(duì)列,數(shù)據(jù)類型Node*,但是層序遍歷不用指針也可以if (node == nullptr){return;}else{list.push(node); //把根節(jié)點(diǎn)push進(jìn)去}while (list.size() != 0) //只要隊(duì)列不為空就一直出隊(duì)進(jìn)隊(duì){cout << list.front()->element << " ";//這里就是把隊(duì)首的元素的左右子節(jié)點(diǎn)進(jìn)隊(duì),然后彈出隊(duì)首元素,就可以把二叉樹(shù)中所有節(jié)點(diǎn)一層一層的按次序進(jìn)隊(duì)和出隊(duì)//還是畫(huà)圖比較好理解if (list.front()->left != nullptr){list.push(list.front()->left);}if (list.front()->right != nullptr){list.push(list.front()->right);}list.pop();} }//! 前序遍歷的非遞歸版本,精髓在于用棧模擬遞歸的過(guò)程,但實(shí)際進(jìn)棧出棧順序與遞歸并不一樣, //! 比較抽象,建議畫(huà)圖理解,比較重要 void BinarySearchTreesZH::preorderTraversalNoRecursion(Node *node) {stack<Node *> stk;if (node == nullptr){return;}stk.push(node);while (stk.size() != 0){Node *top = stk.top();cout << stk.top()->element << " ";stk.pop();//! 注意前序遍歷是中左右,出棧順序是先左后右,進(jìn)棧就要先右后左if (top->right != nullptr){stk.push(top->right);}if (top->left != nullptr){stk.push(top->left);}} }//! 中序遍歷,非遞歸版,跟上一個(gè)前序遍歷的非遞歸版比,思路相同,但是實(shí)現(xiàn)方法和過(guò)程完全不同 //! 比較抽象,依然建議畫(huà)圖理解 //! 巧妙地改變了入棧順序?qū)崿F(xiàn)了中序遍歷 void BinarySearchTreesZH::inorderTraversalNoRecursion(Node *node) {if (node == nullptr){return;}stack<Node *> stk;stk.push(node);while (stk.size() != 0){while (node->left != nullptr){stk.push(node->left);node = node->left;}//! 整體思路為遇到根節(jié)點(diǎn),就遍歷左子樹(shù)的所有左節(jié)點(diǎn),并全部入棧,然后挨個(gè)出棧,//! 出棧中檢測(cè)是否有右節(jié)點(diǎn),如果有則以右節(jié)點(diǎn)為根結(jié)點(diǎn),再次遍歷全部左結(jié)點(diǎn),全部入棧,然后挨個(gè)出棧Node *top = stk.top();cout << top->element << " ";stk.pop();if (top->right != nullptr){node = top->right;stk.push(top->right);}} }//! 后序遍歷,非遞歸版,可以通過(guò)改變前序遍歷非遞歸版中左右結(jié)點(diǎn)的入棧順序,和翻轉(zhuǎn)數(shù)組的想法實(shí)現(xiàn) void BinarySearchTreesZH::postorderTraversalNoRecursion(Node *node) {if (node == nullptr){return;}string s = " ";stack<Node *> stk;stk.push(node);Node *top = stk.top();while (stk.size() != 0){top = stk.top();stk.pop();s = s + to_string(top->element) + " ";if (top->left != nullptr){ //! 整體思路和前序遍歷相同,入棧順序自己想想前序中左右,和后序左右中,就明白了stk.push(top->left);}if (top->right != nullptr){stk.push(top->right);}}reverse(s.begin(), s.end()); //reverse函數(shù)反轉(zhuǎn)字符串cout << s; }//! 求二叉樹(shù)的高度,遞歸版本 //! 遞歸的精髓就在于,把大問(wèn)題分解為解答過(guò)程相同的小問(wèn)題 //! 既然我們要求根節(jié)點(diǎn)的高度,根節(jié)點(diǎn)的高度又等于其子節(jié)點(diǎn)的最大高度加一 //! 那么問(wèn)題就轉(zhuǎn)化為了求每個(gè)節(jié)點(diǎn)及其子節(jié)點(diǎn)的高度,而最小問(wèn)題就是葉節(jié)點(diǎn)的子節(jié)點(diǎn)為空,高度為0 int BinarySearchTreesZH::height(Node *node) {int nodeHeight = 0;int leftSonHeight = 0; //代表左子節(jié)點(diǎn)高度int rightSonHeight = 0; //代表右子節(jié)點(diǎn)高度if (node == nullptr){ //如果到了空結(jié)點(diǎn),則其高度為0nodeHeight = 0;return nodeHeight;}leftSonHeight = height(node->left);rightSonHeight = height(node->right);if (leftSonHeight >= rightSonHeight) //當(dāng)前結(jié)點(diǎn)的高度等于其左右子節(jié)點(diǎn)最大高度+1{nodeHeight = leftSonHeight + 1;}else{nodeHeight = rightSonHeight + 1;}return nodeHeight; }//! 求二叉樹(shù)的高度,迭代版本 //! 所謂二叉樹(shù)的高度就是二叉樹(shù)有多少層,所以在層序遍歷里加一個(gè)層數(shù)計(jì)數(shù)就可以了 //! 但這個(gè)層數(shù)計(jì)數(shù)反倒是難想,其實(shí)在層序遍歷的隊(duì)列中,上一層全部出隊(duì)后,下一層有多少元素,就是隊(duì)列的size() int BinarySearchTreesZH::heightNoRecursion(Node *node) {queue<Node *> list; //創(chuàng)建結(jié)構(gòu)體指針隊(duì)列,數(shù)據(jù)類型Node*,但是層序遍歷不用指針也可以if (node == nullptr){return 0;}else{list.push(node); //把根節(jié)點(diǎn)push進(jìn)去}int height = 0;int nextCengNum = 1; //! 第一層元素?cái)?shù)為1int j = 0; //! 循環(huán)計(jì)數(shù)器,每一層循環(huán)nextCengNum次就會(huì)清零,并高度+1while (list.size() != 0) //只要隊(duì)列不為空就一直出隊(duì)進(jìn)隊(duì){//這里就是把隊(duì)首的元素的左右子節(jié)點(diǎn)進(jìn)隊(duì),然后彈出隊(duì)首元素,就可以把二叉樹(shù)中所有節(jié)點(diǎn)一層一層的按次序進(jìn)隊(duì)和出隊(duì)//還是畫(huà)圖比較好理解if (list.front()->left != nullptr){list.push(list.front()->left);}if (list.front()->right != nullptr){list.push(list.front()->right);}list.pop();j++;if (j == nextCengNum){height++;nextCengNum = list.size();j = 0;}}return height; }//! 檢驗(yàn)二叉樹(shù)是否為完全二叉樹(shù) //! 層序遍歷每一個(gè)結(jié)點(diǎn),有三種情況,分情況討論 bool BinarySearchTreesZH::isCompleteTree(Node *node) {if (node == nullptr){return false;}queue<Node *> list;list.push(node);while (list.size() != 0) //! 大遍歷{Node *front = list.front();if (front->left != nullptr && front->right != nullptr) //! 若該結(jié)點(diǎn)同時(shí)擁有左右子結(jié)點(diǎn),則繼續(xù)出隊(duì)入隊(duì){list.pop();if (front->left != nullptr){list.push(front->left);}if (front->right != nullptr){list.push(front->right);}}else if (front->left == nullptr && front->right != nullptr) //! 若該結(jié)點(diǎn)沒(méi)有左只有右,直接返回false{return false;}else //! 若該結(jié)點(diǎn)沒(méi)有左右子結(jié)點(diǎn),或只有左子結(jié)點(diǎn),則子節(jié)點(diǎn)入隊(duì)后,隊(duì)列該結(jié)點(diǎn)后面所有結(jié)點(diǎn)都是葉結(jié)點(diǎn)(沒(méi)有子節(jié)點(diǎn)){if (front->left != nullptr){list.push(front->left);}list.pop(); //把當(dāng)前符合規(guī)則的這個(gè)先pop出去while (list.size() != 0) //檢驗(yàn)后面的是不是都是葉結(jié)點(diǎn),若不是return false{front = list.front();if (front->left != nullptr || front->right != nullptr){return false;}list.pop();}}}//每次檢驗(yàn)都通過(guò),返回truereturn true; }//! 二叉樹(shù)的翻轉(zhuǎn):本質(zhì)就是二叉樹(shù)的遍歷的應(yīng)用 //! 以任意形式遍歷二叉樹(shù)的每一個(gè)結(jié)點(diǎn),訪問(wèn)每一個(gè)結(jié)點(diǎn)的同時(shí)調(diào)換其左右子樹(shù) //! 中序遍歷額外注意一下調(diào)換后的參數(shù)問(wèn)題 Node *BinarySearchTreesZH::invertTreePreOrder(Node *node) {if (node == nullptr){return node;}Node *tmp = node->left;node->left = node->right;node->right = tmp;invertTreePreOrder(node->left); //!這里遍歷的主要目的是遍歷過(guò)程中的副作用。即翻轉(zhuǎn)invertTreePreOrder(node->right); //! 所以這里不return,要靈活運(yùn)用遍歷框架return node; } Node *BinarySearchTreesZH::invertTreeInOrder(Node *node) {if (node == nullptr){return node;}invertTreeInOrder(node->left);Node *tmp = node->left;node->left = node->right;node->right = tmp;//! 中序遍歷的特殊點(diǎn):由于調(diào)換了左右子樹(shù),所以第二個(gè)遞歸參數(shù)應(yīng)該是現(xiàn)在的左子樹(shù)才是原來(lái)的右子樹(shù)invertTreeInOrder(node->left);return node; } Node *BinarySearchTreesZH::invertTreePostOrder(Node *node) {if (node == nullptr){return node;}invertTreePostOrder(node->left);invertTreePostOrder(node->right);Node *tmp = node->left;node->left = node->right;node->right = tmp;return node; } Node *BinarySearchTreesZH::invertTreeLeverOrder(Node *node) {if (node == nullptr){return node;}queue<Node *> list;list.push(node);while (list.size() != 0){Node *front = list.front();list.pop();Node *tmp = front->left;front->left = front->right;front->right = tmp;if (front->left != nullptr){list.push(front->left);}if (front->right != nullptr){list.push(front->right);}}return node; }//! 查找某個(gè)結(jié)點(diǎn)的前驅(qū)或后繼結(jié)點(diǎn)(要求結(jié)點(diǎn)要有parent指針) //! 前驅(qū)結(jié)點(diǎn)定義:中序遍歷中的前一個(gè)結(jié)點(diǎn),而不是二叉樹(shù)結(jié)構(gòu)中的上一個(gè)母結(jié)點(diǎn) Node *BinarySearchTreesZH::predecessor(Node *node) {if (node == nullptr){return node;}//! 前驅(qū)結(jié)點(diǎn)是左子樹(shù)中的最右結(jié)點(diǎn)if (node->left != nullptr){node = node->left;while (node->right != nullptr){node = node->right;}return node;}else{while (node->parent != nullptr && node->parent->right != node){node = node->parent;}//! 此時(shí)到這里有兩種可能//! node->parent = nullptr(即沒(méi)有前驅(qū)結(jié)點(diǎn)) 或 node->parent ->right = node(即前驅(qū)結(jié)點(diǎn)是node->parent)//! 無(wú)論哪種 直接返回parent都可以return node->parent;} } //! 查找某個(gè)結(jié)點(diǎn)的后繼結(jié)點(diǎn)(要求結(jié)點(diǎn)要有parent指針) //! 后繼結(jié)點(diǎn)定義:中序遍歷中的后一個(gè)結(jié)點(diǎn) Node *BinarySearchTreesZH::successor(Node *node) {if (node == nullptr){return node;}//! 前驅(qū)結(jié)點(diǎn)是右子樹(shù)中的最左結(jié)點(diǎn)if (node->right != nullptr){node = node->right;while (node->left != nullptr){node = node->left;}return node;}else{while (node->parent != nullptr && node->parent->left != node){node = node->left;}//! 此時(shí)到這里有兩種可能//! node->parent = nullptr(即沒(méi)有前驅(qū)結(jié)點(diǎn)) 或 node->parent ->left = node(即前驅(qū)結(jié)點(diǎn)是node->parent)//! 無(wú)論哪種 直接返回parent都可以return node->parent;} }//! 刪除結(jié)點(diǎn) void BinarySearchTreesZH::remove(Node *node) {if (node->left != nullptr && node->right != nullptr) //! 把刪除度為2 的結(jié)點(diǎn)的問(wèn)題轉(zhuǎn)化為刪除{node->element = predecessor(node)->element;remove(predecessor(node));}else if (node->left == nullptr && node->right == nullptr) //! 刪除度為0的結(jié)點(diǎn){if (node->parent == nullptr) //! 若結(jié)點(diǎn)是根結(jié)點(diǎn)直接置空{node = nullptr;}if (node == node->parent->left) //!結(jié)點(diǎn)時(shí)葉結(jié)點(diǎn)時(shí)的置空{node->parent->left = nullptr;}if (node == node->parent->right){node->parent->right = nullptr;}//!我覺(jué)得這里直接全都node = nullptr應(yīng)該是一樣的}else{//! 刪除度為1的結(jié)點(diǎn)if (node->parent == nullptr) //!若結(jié)點(diǎn)是根結(jié)點(diǎn),用其子結(jié)點(diǎn)替代成為根結(jié)點(diǎn){if (node->left != nullptr){root = node->left;}else if (node->right != nullptr){root = node->right;}}else if (node == node->parent->left){ //! 結(jié)點(diǎn)是父結(jié)點(diǎn)的左子結(jié)點(diǎn)或右子結(jié)點(diǎn)時(shí),改動(dòng)雙向指針,和雙向鏈表刪除結(jié)點(diǎn)操作一樣if (node->left != nullptr){node->parent->left = node->left;node->left->parent = node->parent;}else if (node->right != nullptr){node->parent->left = node->left;node->left->parent = node->parent;}}else if (node == node->parent->right){if (node->left != nullptr){node->parent->right = node->left;node->left->parent = node->parent;}else if (node->right != nullptr){node->parent->right = node->left;node->left->parent = node->parent;}}} } //!用值在以node為根節(jié)點(diǎn)的樹(shù)中查找結(jié)點(diǎn) Node *BinarySearchTreesZH::searchNode(int key, Node *node) {if (node == nullptr){return node;}if (node->element == key){cout << "find finished" << endl;return node;}return searchNode(key, node->left); //!這里遍歷的主要目的是遍歷的同時(shí)比較結(jié)點(diǎn)值,并返回找到的結(jié)點(diǎn)return searchNode(key, node->right); //! 所以這里要記得return,把找到的結(jié)點(diǎn)return出來(lái),要靈活運(yùn)用框架return nullptr; }//銷毀整個(gè)二叉樹(shù) void BinarySearchTreesZH::clear() {if (root == nullptr){return;}if (root->left != nullptr){return clear(root->left);}if (root->right != nullptr){return clear(root->right);}size = 0;delete this; }//銷毀以某結(jié)點(diǎn)為根結(jié)點(diǎn)的子樹(shù) void BinarySearchTreesZH::clear(Node *root) {if (root == nullptr){return;}if (root->left != nullptr){return clear(root->left);}if (root->right != nullptr){return clear(root->right);}delete root; }

總結(jié)

以上是生活随笔為你收集整理的2021-10-11 二叉树,二叉搜索树及其相关23个操作 C++实现笔记(复习用,含C指针复习)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

青青河边草免费视频 | 国产一级不卡视频 | 国产区av在线 | 国产又粗又硬又长又爽的视频 | 欧美精品亚洲精品日韩精品 | 91大神一区二区三区 | 美女国内精品自产拍在线播放 | 国产丝袜美腿在线 | 久久精品人人做人人综合老师 | 精品在线一区二区 | 又黄又刺激又爽的视频 | 91精品国产三级a在线观看 | 超碰国产在线观看 | 国产综合精品久久 | 麻花传媒mv免费观看 | 在线免费观看欧美日韩 | 色av色av色av | 狠狠色噜噜狠狠狠狠2022 | 亚洲精品啊啊啊 | 狠狠色狠狠综合久久 | 青青河边草免费观看完整版高清 | 成人一区二区在线观看 | 国产成人性色生活片 | 日韩特黄一级欧美毛片特黄 | 91激情 | 国产日韩欧美在线一区 | 日韩v欧美v日本v亚洲v国产v | 欧美 日韩 视频 | 91九色丨porny丨丰满6 | 久久精品婷婷 | 999电影免费在线观看 | 午夜久久成人 | 免费观看黄 | 国产免费又黄又爽 | 久草| 日韩精品久久一区二区 | 国产一级电影网 | 在线免费国产 | 欧美与欧洲交xxxx免费观看 | 丁香综合激情 | 亚洲va在线va天堂va偷拍 | 在线观看成人av | 久久婷婷一区二区三区 | 久久免费视频99 | 婷香五月| 六月婷色| 精品毛片久久久久久 | 久久久久久久影院 | 国产精品18久久久久久久网站 | 特级a老妇做爰全过程 | 亚洲专区一二三 | 国产三级午夜理伦三级 | 久久激五月天综合精品 | 久久免费观看少妇a级毛片 久久久久成人免费 | 亚洲精品国产精品国自产观看 | 日日夜精品 | 手机av网站 | 精品在线看 | 99精品视频播放 | 亚洲一区二区三区miaa149 | 免费网站黄 | 黄色中文字幕在线 | www91在线观看 | 欧美午夜激情网 | 国产精品资源网 | 免费观看性生活大片 | 一区二区三区高清不卡 | 在线看一区二区 | 天天操天天操天天操天天 | 日韩av快播电影网 | 天天狠狠干 | 色综合久久久久综合 | 国产字幕av | 亚洲精品视频免费 | 开心激情五月婷婷 | 久久综合久久综合这里只有精品 | 亚洲h色精品| 欧美久久久久久久久中文字幕 | 亚洲欧美999| 亚洲精品一区二区三区四区高清 | 97超碰在线久草超碰在线观看 | 亚洲精品视频在线播放 | 国产精品一区免费观看 | 成人在线黄色电影 | 在线a人v观看视频 | 丁香六月激情 | 成人在线视频你懂的 | 久久久亚洲电影 | 9在线观看免费高清完整版在线观看明 | 国产原创中文在线 | 日本黄色特级片 | 亚洲成a人片在线观看网站口工 | 国产97在线播放 | 久草免费在线 | 婷婷六月丁香激情 | 最近日本mv字幕免费观看 | 一级片在线 | 美女国内精品自产拍在线播放 | 亚洲欧美日韩一二三区 | 91丨九色丨首页 | 国产黄色视 | 欧美另类人妖 | 97免费中文视频在线观看 | 天天爱天天色 | 天天综合成人 | 天天综合网在线观看 | 中文字幕精品一区二区三区电影 | 日本在线观看一区二区三区 | 国产成人黄色 | 九色91在线视频 | 久久免费视频网站 | 亚av在线| 色片网站在线观看 | 狠狠色伊人亚洲综合网站野外 | 午夜久久美女 | 91社区国产高清 | 五月综合激情 | 国产剧在线观看片 | 亚洲一区美女视频在线观看免费 | 日本美女xx| 色综久久 | 超碰人人草人人 | 国产三级视频 | 亚洲精品视频在线 | 91日韩在线视频 | 夜夜骑天天操 | 久草在线免费播放 | 国产午夜精品一区二区三区在线观看 | 欧美一区二区在线免费看 | 国产精品自产拍在线观看网站 | 亚洲激情av | 免费看毛片网站 | 中文字幕一区二区三区乱码不卡 | a√国产免费a | 黄色影院在线免费观看 | 国产精品久久久久久久久久99 | a在线观看免费视频 | 久久国产一区二区 | 久久久国产网站 | 久草在线视频网 | 人成在线免费视频 | www.婷婷色| 日韩欧美在线视频一区二区三区 | 人人超碰人人 | 最近能播放的中文字幕 | 国产一区精品在线观看 | 国产日韩欧美在线一区 | 国产免费人成xvideos视频 | 国产精品亚洲片在线播放 | 亚洲欧美日韩一区二区三区在线观看 | 黄色成品视频 | 国产精品久久久 | 成人免费网视频 | 国产欧美日韩视频 | 99r在线播放 | 日韩视频一二三区 | 99热这里是精品 | 在线观看日韩精品视频 | 国产亚洲视频中文字幕视频 | 久久综合亚洲鲁鲁五月久久 | 丝袜制服天堂 | 九九热视频在线 | 免费观看性生交大片3 | 精品在线观看一区二区三区 | 午夜少妇av| 天天爽人人爽 | 天天操天天操天天操天天操 | 久久国产午夜精品理论片最新版本 | 中文字幕在线精品 | 婷婷天天色 | 欧美激情综合五月色丁香 | 有码中文字幕 | 国产精品久久久 | 成人一级电影在线观看 | 欧美精品中文字幕亚洲专区 | 欧美韩国日本在线观看 | 中文字幕亚洲欧美日韩 | 国产高清在线免费 | 激情综合狠狠 | 在线观看资源 | 青草草在线视频 | 亚洲一区美女视频在线观看免费 | 久久黄色网页 | 亚洲免费国产视频 | 99爱这里只有精品 | 在线综合 亚洲 欧美在线视频 | 日韩视频欧美视频 | 国产精品免费一区二区 | 欧美福利在线播放 | 国产日韩高清在线 | 色97在线| 在线看成人 | 麻豆视频91 | 欧美国产大片 | 精品久久久久久综合日本 | 在线香蕉视频 | 亚洲精品乱码久久久久久久久久 | 男女视频国产 | 亚洲免费成人av电影 | 91精品视频在线免费观看 | 青青河边草观看完整版高清 | 国产高清在线a视频大全 | 久久精品视频播放 | 国产三级国产精品国产专区50 | 亚洲成人精品av | 91 在线视频播放 | 欧美精品久久久久久久久免 | 久久久免费在线观看 | 久久久电影网站 | 久久a久久| 在线观看午夜av | 五月天免费网站 | 中文亚洲欧美日韩 | 国产精品一区二区三区在线看 | 深夜福利视频在线观看 | 菠萝菠萝蜜在线播放 | 麻豆视频在线观看 | 国产三级香港三韩国三级 | 97在线免费视频 | 精品三级av | 99国内精品久久久久久久 | 国产免费又粗又猛又爽 | 欧美日韩在线播放一区 | 欧美专区国产专区 | 911亚洲精品第一 | 超碰人人乐 | 黄色电影在线免费观看 | 国产成人免费观看久久久 | 手机av在线网站 | 国产高清视频在线播放一区 | 国产小视频你懂的在线 | 国产成人av一区二区三区在线观看 | 国产小视频在线观看免费 | 在线小视频国产 | 久久久久成人精品 | 色综合天天综合在线视频 | sesese图片 | 黄色免费观看网址 | 337p日本欧洲亚洲大胆裸体艺术 | 91精品视频在线免费观看 | 三级黄色大片在线观看 | 婷婷色中文字幕 | av中文在线 | 亚洲播放一区 | 69国产盗摄一区二区三区五区 | 国内精品久久久久久久97牛牛 | 久草在线视频中文 | 免费观看第二部31集 | 一区二区欧美日韩 | 在线导航av | 日韩电影一区二区在线观看 | 免费看色的网站 | 亚洲视频网站在线观看 | 久久草在线精品 | 日韩欧美综合视频 | 国产又粗又猛又爽 | 91片网| 五月开心六月伊人色婷婷 | 狠狠干干| 国产精品久久 | 日韩精品中文字幕有码 | 色婷婷国产精品 | 亚洲国产精品免费 | 天天摸天天舔天天操 | 中文字幕资源站 | 91av视频免费在线观看 | 亚洲免费视频在线观看 | 午夜三级理论 | 久久国产成人午夜av影院宅 | 国产大尺度视频 | 91在线视频在线观看 | 久久综合色一综合色88 | 久久撸在线视频 | 国产精品一区二区三区在线看 | 日韩精品一区二区三区高清免费 | 丰满少妇在线观看网站 | 日韩在线观看视频中文字幕 | 免费在线激情电影 | 在线免费观看黄色 | 国产精品久久久久免费 | 色综合五月 | 成人久久久精品国产乱码一区二区 | 91女子私密保健养生少妇 | 福利av影院| 亚洲播放一区 | 久操视频在线播放 | 99精品视频在线观看 | 在线播放一区二区三区 | 色综合天 | 成人av免费播放 | 激情婷婷av | 国内精品久久影院 | 91自拍视频在线观看 | 国产乱码精品一区二区三区介绍 | 国际精品久久 | 欧美成人在线网站 | 免费观看国产精品视频 | 午夜精品久久久久久久99水蜜桃 | 国产成人精品在线播放 | 日韩中文字幕在线不卡 | 中文字幕乱在线伦视频中文字幕乱码在线 | 日日干美女| 亚洲一区二区黄色 | 久久久久激情 | 日韩精品一区二区三区在线播放 | 伊人婷婷色 | 欧美尹人 | 亚洲黄色av网址 | 人交video另类hd | 久久av电影| 免费观看www7722午夜电影 | 久久99精品久久久久久三级 | 免费看黄视频 | 在线一二三四区 | 欧美日韩国产亚洲乱码字幕 | 激情大尺度视频 | 91在线入口| 日韩视频精品在线 | 亚洲影视九九影院在线观看 | 色欧美日韩 | 精品欧美日韩 | 狠狠躁夜夜av | 麻豆国产露脸在线观看 | 在线观看一区视频 | 激情大尺度视频 | 九九免费在线观看视频 | 国产精品乱码高清在线看 | 久久久五月婷婷 | 97超碰成人在线 | 2022久久国产露脸精品国产 | 九色91福利 | 欧美性视频网站 | 激情综合中文娱乐网 | 99久久久久久久久久 | 在线看一区二区 | 欧洲精品一区二区 | 成人影片在线免费观看 | 成人精品久久久 | 亚洲国产三级在线 | 国产精品一区二区三区在线看 | 久久亚洲私人国产精品va | 999久久久久久 | 久草在线视频国产 | 在线成人一区二区 | 麻豆国产网站入口 | 欧美一区二区视频97 | 视频一区二区在线观看 | 国产一区二区中文字幕 | 午夜视频在线观看一区二区三区 | 日韩三级视频在线观看 | 国产美女网站在线观看 | 欧美一级日韩免费不卡 | 最新色站 | 不卡中文字幕在线 | 亚洲伊人成综合网 | 国产精品日韩高清 | 久久免费视频在线观看6 | 国产中文字幕在线观看 | av福利电影| 亚洲免费高清视频 | 在线视频观看你懂的 | 最近高清中文字幕 | 成人影视免费看 | 狠狠色丁香久久婷婷综 | 久久麻豆精品 | 亚洲闷骚少妇在线观看网站 | 色综合久久精品 | 亚洲三级在线免费观看 | 在线a人片免费观看视频 | 九九热免费在线观看 | 欧美日韩3p | 美女在线黄 | 国产高清中文字幕 | 一级大片在线观看 | 奇米影视777影音先锋 | 日韩精品不卡 | 欧美黑人xxxx猛性大交 | 808电影免费观看三年 | 五月婷婷综合在线 | 五月综合婷 | 免费看高清毛片 | 嫩草91影院| 国产va饥渴难耐女保洁员在线观看 | 黄色网址中文字幕 | 日韩精品免费一区 | 亚洲永久av | 色综合久 | 成人黄大片视频在线观看 | 日韩成人精品 | 特级黄色一级 | 日本一区二区不卡高清 | 亚洲一区二区观看 | 亚洲黄色成人网 | av色综合网 | 国产综合小视频 | 色狠狠久久av五月综合 | 婷婷丁香av| 亚洲欧洲日韩 | 五月天婷婷视频 | 国产精品第10页 | 国产成人专区 | 亚洲三级黄 | 人人精久 | 亚洲乱码国产乱码精品天美传媒 | 日韩有码在线观看视频 | 六月激情 | 国产精品久久久久久久久久白浆 | 国产高清在线观看 | 日韩成人免费电影 | 久草久草在线 | 色网免费观看 | 国产无遮挡又黄又爽在线观看 | 国产成人av一区二区三区在线观看 | 国产五月天婷婷 | 天天干 天天摸 天天操 | 99热这里只有精品国产首页 | 婷婷精品国产欧美精品亚洲人人爽 | 国内精自线一二区永久 | 国产一区欧美一区 | 日韩中文字幕免费看 | 国产流白浆高潮在线观看 | 五月天色婷婷丁香 | 久久久久伦理电影 | 丁香花中文在线免费观看 | 久久你懂的 | 尤物97国产精品久久精品国产 | 国产精品久久久免费看 | 亚洲三级黄 | 一区二区三区在线免费观看视频 | 久久激情综合网 | 中文字幕一区二区三区乱码不卡 | 伊人电影在线观看 | 黄色免费看片网站 | 国产精品美女在线观看 | 97碰碰视频| 99热国产在线观看 | 婷婷伊人网 | 又粗又长又大又爽又黄少妇毛片 | 午夜av免费观看 | 国产精品毛片一区视频 | 国产精品区免费视频 | 亚洲视频久久久久 | 国产成人精品免费在线观看 | 在线看黄色的网站 | 一本一道久久a久久精品蜜桃 | 综合国产视频 | 国产亚洲欧美在线视频 | 夜夜婷婷| 国产美女网站视频 | 欧美成人在线网站 | 成人污视频在线观看 | 日韩特级黄色片 | 久草免费在线视频观看 | 91系列在线 | 免费碰碰 | aa级黄色大片 | 久久激情久久 | 91视频88av| 欧美性黑人 | 国产精品久久久久久久毛片 | 久久国产精品99久久久久久丝袜 | 一区二区三区精品在线视频 | 日韩毛片精品 | 国产丝袜制服在线 | 久久精品女人毛片国产 | 天天射天天色天天干 | 91精品国产99久久久久 | 久久久999精品视频 国产美女免费观看 | 久久综合精品国产一区二区三区 | 日韩欧美电影在线 | 好看的国产精品视频 | 久久久久久久久久久高潮一区二区 | 在线 成人| 中文字幕视频播放 | 天天天天爱天天躁 | 99婷婷 | 精品国产一区二区三区免费 | 日本久久久久久久久久久 | 天天射天天爱天天干 | 91人人人 | 97在线观看免费高清完整版在线观看 | 欧美一级片在线 | 久久天堂亚洲 | 国产精品美女久久久久久2018 | 日韩欧美xxxx | 日韩专区在线播放 | 免费日韩精品 | 国产精品永久免费在线 | 久久成年人视频 | av一区在线| 国产精品黑丝在线观看 | 超碰在线98 | 久久有精品 | 欧美一级片免费在线观看 | 奇米网网址 | 成人午夜毛片 | 91视频啪 | 91免费高清视频 | www.激情五月.com | 狠狠色狠狠综合久久 | 天天综合网 天天 | 91成人网在线观看 | 色婷婷视频在线观看 | 狠狠狠狠狠狠 | 在线你懂的视频 | 奇米四色影狠狠爱7777 | 婷婷免费视频 | 中文一区在线观看 | 又爽又黄又无遮挡网站动态图 | 久久精品一区二区三区中文字幕 | 奇米7777狠狠狠琪琪视频 | 探花视频在线观看免费 | av免费电影网站 | 五月婷婷六月丁香激情 | 高清久久久久久 | 国产午夜剧场 | 又黄又色又爽 | 欧美激情综合五月 | 激情av一区二区 | 看片黄网站 | 伊人天天综合 | 久久久天堂| 日韩大片在线免费观看 | 国产91精品一区二区麻豆亚洲 | 亚洲一区美女视频在线观看免费 | 亚洲精品456在线播放第一页 | 黄在线免费观看 | 精品一区二区亚洲 | 尤物九九久久国产精品的分类 | 国产 日韩 欧美 自拍 | 午夜精品福利一区二区三区蜜桃 | 美女视频a美女大全免费下载蜜臀 | 亚洲精品乱码久久久久久9色 | 91在线视频在线观看 | 天天爽人人爽夜夜爽 | 天堂av色婷婷一区二区三区 | 国产日韩欧美在线看 | 午夜精品99久久免费 | 人人艹视频 | 日韩精品 在线视频 | 人人爽人人爱 | 99国产成+人+综合+亚洲 欧美 | 精品免费在线视频 | 91网在线观看 | 成人丝袜| 精品美女国产在线 | 久久国产成人午夜av影院宅 | 亚洲一级二级三级 | 久久人人爽人人人人片 | 狠狠色丁香婷婷综合基地 | 91久久一区二区 | 国产一二区视频 | 日韩三级免费观看 | av天天在线观看 | 麻豆传媒一区二区 | 日本久久视频 | 丝袜美腿在线播放 | 日韩久久精品一区二区三区 | 激情久久伊人 | 亚洲精品视频在线观看网站 | 国产成人精品999在线观看 | 色偷偷88888欧美精品久久久 | 日韩高清在线观看 | 亚洲精品在线观看的 | 日韩乱码在线 | 日日干网址 | 一区二区三区四区五区六区 | 亚洲激情电影在线 | 中文字幕久久亚洲 | 国产精品免费久久 | 欧美日视频 | 黄色精品免费 | 欧美日韩免费网站 | 日日干影院 | 久久国产影院 | 在线观看aaa | 久久综合免费视频影院 | 97超碰在线久草超碰在线观看 | 日韩中文在线视频 | 在线观看成人福利 | 国产在线久草 | 最近免费中文字幕 | 午夜av免费在线观看 | 玖玖精品在线 | 一区二区精品 | 99热最新精品 | 国产精品久久久久婷婷二区次 | 超碰在线日韩 | 日韩精品一区二区三区在线播放 | 久久国产网站 | 国产精品久久久久久久久久久久 | 92国产精品久久久久首页 | 99国产精品久久久久久久久久 | 天天爱天天操天天射 | 欧美日韩久久一区 | 成人久久久精品国产乱码一区二区 | 久草在线免费电影 | 婷婷在线免费视频 | 日韩在线免费小视频 | 在线观看av网站 | 亚洲国产三级在线 | 99久久99久久精品国产片果冰 | av成人在线播放 | 夜夜澡人模人人添人人看 | 欧美精品亚州精品 | 粉嫩一二三区 | 日韩三级精品 | 国产精品成人自产拍在线观看 | 福利视频导航网址 | 国产精品手机在线 | 久久亚洲综合国产精品99麻豆的功能介绍 | www免费黄色| 天天久久夜夜 | 日韩精品在线播放 | 久久久免费少妇 | 中文字幕免费高清 | 在线免费观看麻豆视频 | 夜夜爱av| 亚洲三级av | 婷婷 中文字幕 | 成人中文字幕+乱码+中文字幕 | 欧美经典久久 | 丁香电影小说免费视频观看 | 日本中文字幕一二区观 | 国内99视频 | 综合五月| 少妇高潮冒白浆 | 99久久综合国产精品二区 | 91人人插 | 国产精品一区二区久久久 | 在线观看亚洲a | 91成人亚洲| 麻豆手机在线 | 天堂av在线免费观看 | 久久国产精品小视频 | 久久国产精品色av免费看 | 午夜精品一区二区三区可下载 | 日本在线h| 久久免费看视频 | 激情丁香久久 | 91亚洲影院 | 婷婷成人在线 | 国产精品久久久久久久久久 | av免费网| 欧美一级看片 | 不卡视频国产 | 国产精品毛片一区二区 | 在线视频一区二区 | 视频99爱| 欧美日韩视频在线播放 | 在线最新av| 免费福利视频网 | 在线观看视频亚洲 | 久久99精品一区二区三区三区 | 国产在线免费观看 | 成人国产精品一区二区 | 欧美一级电影在线观看 | 精品一区二区影视 | 人人澡人人添人人爽一区二区 | 欧美日韩国产二区三区 | 免费特级黄毛片 | 国产精品久久久久一区二区国产 | 亚洲精品乱码久久久久久蜜桃欧美 | 九九视频精品免费 | 日韩中文字幕亚洲一区二区va在线 | 美女福利视频网 | 国产精品美乳一区二区免费 | 国产精品人人做人人爽人人添 | 日日操夜 | 精品国产电影一区 | 97韩国电影 | 久久视频在线 | 福利久久| 久久久国产视频 | 黄色av免费 | 久久视频精品在线观看 | 免费网站黄色 | 中文字幕影片免费在线观看 | 欧美另类亚洲 | 国产视频久久久久 | 国内精品久久久久影院日本资源 | a天堂免费 | 欧美一级电影片 | 免费网址你懂的 | 久久久亚洲麻豆日韩精品一区三区 | 天天干人人干 | 国产日韩欧美在线观看视频 | 91中文字幕网 | 91精品国产成人 | 一区三区视频 | 99在线观看免费视频精品观看 | 99免在线观看免费视频高清 | a电影在线观看 | www.97视频 | 国产精品去看片 | 国产一区二区免费 | 成人久久综合 | 狠狠做深爱婷婷综合一区 | av中文在线 | 精品字幕在线 | 国产免费成人av | 超碰成人av | 天天弄天天干 | 精品一区二区亚洲 | free,性欧美| 久久高清 | av色影院| 91av视频免费观看 | 中文字幕在线观看三区 | www视频在线观看 | 狠狠干五月天 | 国产精品一区二区三区四 | 91高清视频 | 亚洲1区在线 | 天天操天天拍 | 免费性网站 | 久久精品99国产精品酒店日本 | 不卡中文字幕在线 | 久爱精品在线 | 99久久精品免费看国产麻豆 | 久久婷亚洲五月一区天天躁 | 麻豆免费在线播放 | 国产视频一区精品 | 波多野结衣久久资源 | av+在线播放在线播放 | 久久影院中文字幕 | 精品综合久久 | 玖玖在线免费视频 | 天天操人人要 | 国产一级免费视频 | 国产精品手机看片 | 一区二区三区免费在线 | 黄污在线观看 | 91麻豆产精品久久久久久 | 中文字幕av在线播放 | 操综合| 久久久久亚洲国产精品 | 日韩免费在线视频 | 久久久免费观看完整版 | 91黄色成人| 97精品视频在线 | 天天做夜夜做 | 亚洲国产精品va在线看 | 九九热精品视频在线播放 | 国内精品久久久久国产 | 日韩精品久久一区二区 | 日韩在线观看网站 | 国内外成人在线 | 91久久精 | 日韩中文字幕电影 | 日韩色一区二区三区 | 国产色视频网站2 | 一区二区三区免费在线观看视频 | 国产精品电影在线 | 韩国视频一区二区三区 | 中文字幕 婷婷 | 国产精品99久久久久久大便 | 毛片的网址 | 91久久国产露脸精品国产闺蜜 | 亚洲精品国偷拍自产在线观看蜜桃 | 超碰在线97免费 | 在线小视频 | 天天干天天操天天拍 | 在线免费观看不卡av | 超碰免费在线公开 | 五月天婷婷在线观看视频 | 有没有在线观看av | 黄色大全在线观看 | 国产精品欧美一区二区 | 99久久精品日本一区二区免费 | 久久久久久久久国产 | 亚洲国产影院av久久久久 | 亚洲免费婷婷 | 久久亚洲精品电影 | 六月丁香在线视频 | 99精品在线免费观看 | 成人在线视频一区 | 日日夜夜天天干 | 成人午夜剧场在线观看 | 精品国产一区二区三区噜噜噜 | 天天天干 | 中文字幕一区二区三区久久蜜桃 | 国产精品igao视频网网址 | 黄网站色视频免费观看 | 超碰成人网 | 久久国产精品久久精品国产演员表 | 亚洲一级免费电影 | 亚洲视频中文 | 精品亚洲午夜久久久久91 | 日一日操一操 | 91一区啪爱嗯打偷拍欧美 | 99精品视频精品精品视频 | 久久视奸| 狠狠插天天干 | 玖玖在线播放 | 日韩av偷拍| 精品三级av | 九九精品视频在线看 | 欧美性极品xxxx做受 | 亚洲精品免费播放 | 日韩视频在线不卡 | 四虎影视精品永久在线观看 | av丝袜天堂 | 国产一级片一区二区三区 | 97免费视频在线播放 | av线上看| 成年人在线播放视频 | 欧美午夜性| 黄色午夜网站 | 一区二区三区高清在线观看 | 国产原创中文在线 | 成人免费看视频 | 五月天中文在线 | 国产精品你懂的在线观看 | 91天天视频 | 人人舔人人爽 | www国产精品com | 欧美日本一区 | 2020天天干天天操 | 在线欧美a | 国产另类xxxxhd高清 | 麻豆视传媒官网免费观看 | 免费看高清毛片 | 美国av片在线观看 | 91精品在线免费观看视频 | caobi视频 | 色视频 在线 | 日韩在观看线 | a级国产乱理论片在线观看 特级毛片在线观看 | 日韩特级黄色片 | 久久视频中文字幕 | 成人午夜免费剧场 | 在线а√天堂中文官网 | www.日日操.com| 91高清完整版在线观看 | 亚洲网站在线 | 精品国产乱码久久久久久1区二区 | 五月激情久久 | 91成人在线视频 | 欧美最爽乱淫视频播放 | 日韩系列在线观看 | 日韩在线视频网址 | 日韩电影中文字幕 | 91精品国产综合久久福利 | 好看的国产精品视频 | 天天干天天在线 | 亚洲专区欧美专区 | 国产成人精品一区二区三区在线观看 | av在线小说| 国产日韩精品一区二区三区 | 天天曰天天爽 | 久久婷婷视频 | 在线免费观看国产精品 | 国产成人久 | 久久这里只有精品久久 | 中国一级特黄毛片大片久久 | 成人久久免费 | 日韩在线观看你懂的 | 欧美91精品国产自产 | 久久成人人人人精品欧 | 伊人看片 | 亚洲视频专区在线 | 国产精品久久久久久久久久久久久 | 欧美色888 | 亚洲一区 av | 天天操天天干天天插 | 午夜丁香视频在线观看 | 欧美一级片播放 | 欧美精品生活片 | 国产精品va视频 | 在线亚洲精品 | 99精品国产aⅴ | 亚洲精品小视频 | 国产亚洲精品久久久久久电影 | 91视频 - x99av | 日韩免费福利 | 婷婷黄色片 | www.久久视频 | 亚洲国产大片 | 亚洲精品综合一二三区在线观看 | 国产精品毛片久久久久久久 | 成人天堂网 | 国产一二三四在线观看视频 | 国产精品99在线播放 | 国产高清专区 | 在线精品亚洲一区二区 | 国产小视频在线免费观看视频 | 在线视频 91 | 超碰人人舔 | 免费成人av在线看 | 91亚洲国产成人 | 麻豆视频在线播放 | 中文字幕999| 奇米导航| 一区二区三区视频 | 亚洲人成免费网站 | 91精品日韩 | 国产精品久久久久久高潮 | 天天婷婷 | 91在线影视 | 日本系列中文字幕 | 日韩免费在线网站 | 91免费高清| 亚洲爽爽网| 五月婷婷综合色拍 | 成人在线一区二区 | 久久久精品影视 | 丰满少妇一级片 | 亚洲精品自拍视频在线观看 | 久久视频精品在线观看 | 国产精品高潮在线观看 | 亚洲区精品 | 日韩二三区 | 亚洲动漫在线观看 | 国产成人精品三级 | 91精选在线 | 国产91对白在线播 | 精品国产1区 | 国产一区二区高清 | 午夜av在线 | 狠狠干网址 | 91精品国产成人观看 | 狠狠干夜夜爽 | 999久久久免费视频 午夜国产在线观看 | 久久美女精品 | 日韩欧美一区视频 | 国产精品久久一区二区无卡 | 久草在线视频网站 | 亚洲三级黄| 久久久国产精品亚洲一区 | 国产精品久久久久久久免费观看 | 亚洲国产精品500在线观看 | 欧美一区二区在线刺激视频 | 五月宗合网 | 国产精品乱码在线 | 国产精品99久久久久久小说 | 免费国产在线精品 | 手机在线黄色网址 | 91麻豆精品国产91久久久久久久久 | 国产美女精品 | 五月婷婷,六月丁香 | 97国产一区二区 | 视频二区在线视频 | 成人福利在线观看 | 成人午夜电影在线 | 综合久久久 | www.啪啪.com| www免费视频com| 九九天堂 | 国产在线精品福利 | 久久久国产精品免费 | 免费激情在线电影 | 涩涩网站在线播放 | 亚洲一区日韩精品 | 久久夜视频 | 午夜视频在线瓜伦 | 天天爱天天色 | 在线免费国产视频 | 日韩欧美国产免费播放 | 在线激情网| 日韩精品久久久久久中文字幕8 | 国产精品一区二区视频 | 一区二区三区精品在线视频 | 国产一在线精品一区在线观看 | 欧美在线资源 | 99高清视频有精品视频 | 国产视频在线看 | 成年人看片 | 特级大胆西西4444www | 国产精品欧美一区二区 | 亚洲精品在线视频观看 | 亚洲精品午夜久久久久久久 | 最新中文字幕在线观看视频 | 中文字幕美女免费在线 | 一区二区精 | 九九日九九操 | 91麻豆精品国产91久久久久久久久 | 亚洲经典在线 | 久草在线免费资源站 | 久久国产香蕉视频 | 国内视频| 亚洲精品中文字幕在线 | 久久国产精品久久w女人spa | 美女中文字幕 | 黄色av网站在线免费观看 | 欧美国产高清 | 一区二区三区四区在线免费观看 | 中文字幕一区二区三区视频 | 九九免费视频 | 日本女人b| 中文字幕在线视频第一页 | 91精品视频一区二区三区 | 成年人免费在线播放 | 涩涩爱夜夜爱 | 亚洲高清资源 | 亚洲v欧美v国产v在线观看 | 中文字幕亚洲在线观看 | 亚洲精品乱码久久久久v最新版 |