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

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

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

数据结构与算法(3)——树(二叉、二叉搜索树)

發(fā)布時(shí)間:2025/3/21 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据结构与算法(3)——树(二叉、二叉搜索树) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

前言:題圖無(wú)關(guān),現(xiàn)在開(kāi)始來(lái)學(xué)習(xí)學(xué)習(xí)樹(shù)相關(guān)的知識(shí)

前序文章:

  • 數(shù)據(jù)結(jié)構(gòu)與算法(1)——數(shù)組與鏈表(https://www.jianshu.com/p/7b93b3570875)
  • 數(shù)據(jù)結(jié)構(gòu)與算法(2)——棧和隊(duì)列(https://www.jianshu.com/p/5087c751cb42)

樹(shù)

什么是樹(shù)

樹(shù)是一種類似于鏈表的數(shù)據(jù)結(jié)構(gòu),不過(guò)鏈表的結(jié)點(diǎn)是以線性方式簡(jiǎn)單地指向其后繼結(jié)點(diǎn),而樹(shù)的一個(gè)結(jié)點(diǎn)可以指向許多個(gè)結(jié)點(diǎn);數(shù)是一種典型的非線性結(jié)構(gòu);樹(shù)結(jié)構(gòu)是以表達(dá)具有層次特性的圖結(jié)構(gòu)的一種方法;

相關(guān)術(shù)語(yǔ)

  • 根節(jié)點(diǎn):根節(jié)點(diǎn)是一個(gè)沒(méi)有雙親結(jié)點(diǎn)的結(jié)點(diǎn),一棵樹(shù)中最多有一個(gè)根節(jié)點(diǎn)(如上圖的結(jié)點(diǎn)A就是根節(jié)點(diǎn));
  • 邊:邊表示從雙親結(jié)點(diǎn)到孩子結(jié)點(diǎn)的鏈接(如上圖中所有的鏈接);
  • 葉子結(jié)點(diǎn):沒(méi)有孩子結(jié)點(diǎn)的結(jié)點(diǎn)叫作葉子結(jié)點(diǎn)(如E、J、K、H和I);
  • 兄弟結(jié)點(diǎn):擁有相同雙親結(jié)點(diǎn)的所有孩子結(jié)點(diǎn)叫作兄弟結(jié)點(diǎn)(B、C、D是A的兄弟結(jié)點(diǎn),E、F是B的兄弟結(jié)點(diǎn));
  • 祖先結(jié)點(diǎn):如果存在一條從根節(jié)點(diǎn)到結(jié)點(diǎn)q的路徑,其結(jié)點(diǎn)p出現(xiàn)在這條路徑上,那么就可以吧結(jié)點(diǎn)p叫作結(jié)點(diǎn)q的祖先結(jié)點(diǎn),結(jié)點(diǎn)q也叫做p的子孫結(jié)點(diǎn)(例如,A、C和G是K的祖先結(jié)點(diǎn));
  • 結(jié)點(diǎn)的大小:結(jié)點(diǎn)的大小是指子孫的個(gè)數(shù),包括其自身。(子樹(shù)C的大小為3);
  • 樹(shù)的層:位于相同深度的所有結(jié)點(diǎn)的集合叫作樹(shù)的層(B、C和D具有相同的層,上圖的結(jié)構(gòu)有0/1/2/3四個(gè)層);
  • 結(jié)點(diǎn)的深度:是指從根節(jié)點(diǎn)到該節(jié)點(diǎn)的路徑長(zhǎng)度(G點(diǎn)的深度為2,A—C—G);
  • 結(jié)點(diǎn)的高度:是指從該節(jié)點(diǎn)到最深節(jié)點(diǎn)的路徑長(zhǎng)度,樹(shù)的高度是指從根節(jié)點(diǎn)到書中最深結(jié)點(diǎn)的路徑長(zhǎng)度,只含有根節(jié)點(diǎn)的樹(shù)的高度為0。(B的高度為2,B—F—J);
  • 樹(shù)的高度:是樹(shù)中所有結(jié)點(diǎn)高度的最大值,樹(shù)的深度是樹(shù)中所有結(jié)點(diǎn)深度的最大值,對(duì)于同一棵樹(shù),其深度和高度是相同的,但是對(duì)于各個(gè)結(jié)點(diǎn),其深度和高度不一定相同;

二叉樹(shù)

如果一棵樹(shù)中的每個(gè)結(jié)點(diǎn)有0,1或者2個(gè)孩子結(jié)點(diǎn),那么這棵樹(shù)就稱為二叉樹(shù);空樹(shù)也是一顆有效的二叉樹(shù),一顆二叉樹(shù)可以看做是由根節(jié)點(diǎn)和兩棵不相交的子樹(shù)(分別稱為左子樹(shù)和右子樹(shù))組成,如下圖所示。

二叉樹(shù)的類型

嚴(yán)格二叉樹(shù):二叉樹(shù)中的每個(gè)節(jié)點(diǎn)要么有兩個(gè)孩子結(jié)點(diǎn),要么沒(méi)有孩子結(jié)點(diǎn)

滿二叉樹(shù):二叉樹(shù)中的每個(gè)結(jié)點(diǎn)恰好有兩個(gè)孩子結(jié)點(diǎn)且所有葉子結(jié)點(diǎn)都在同一層

完全二叉樹(shù):在定義完全二叉樹(shù)之前,假定二叉樹(shù)的高度為h;對(duì)于完全二叉樹(shù),如果將所有結(jié)點(diǎn)從根節(jié)點(diǎn)開(kāi)始從左至右,從上至下,依次編號(hào)(假定根節(jié)點(diǎn)的編號(hào)為1),那么僵得到從1~n(n為結(jié)點(diǎn)總數(shù))的完整序列,在遍歷過(guò)程中對(duì)于空指針也賦予編號(hào),如果所有伽椰子結(jié)點(diǎn)的深度為h或h-1,且在結(jié)點(diǎn)編號(hào)序列中沒(méi)有漏掉任何數(shù)字,那么這樣的二叉樹(shù)叫作完全二叉樹(shù)。

二叉樹(shù)的應(yīng)用

  • 編譯器中的表達(dá)式樹(shù);
  • 用于數(shù)據(jù)壓縮算法中的赫夫曼編碼樹(shù);
  • 支持在集合中查找、插入和刪除,其平均時(shí)間復(fù)雜度為O(lognn)的二叉搜索樹(shù)(BST);
  • 優(yōu)先隊(duì)列(PQ),它支持以對(duì)數(shù)時(shí)間(最壞情況下)對(duì)集合中的最小(或最大)數(shù)據(jù)元素進(jìn)行搜索和刪除;

二叉樹(shù)的遍歷

訪問(wèn)樹(shù)中所有結(jié)點(diǎn)的過(guò)程叫作樹(shù)的遍歷,在遍歷過(guò)程中,每個(gè)結(jié)點(diǎn)只能被處理一次,盡管其有可能被訪問(wèn)多次;根據(jù)結(jié)點(diǎn)處理順序的不同,。可以定義不同的遍歷方法,遍歷分類可以根據(jù)當(dāng)前節(jié)點(diǎn)被處理的順序來(lái)劃分:

前序遍歷

在前序遍歷中,每個(gè)結(jié)點(diǎn)都是在它的子樹(shù)遍歷之前進(jìn)行處理,這是最容易理解的便利方法,然而,盡管每個(gè)結(jié)點(diǎn)在其子樹(shù)之前進(jìn)行了處理,但在向下移動(dòng)的過(guò)程仍然需要保留一些信息,以上圖為例,首先訪問(wèn)結(jié)點(diǎn)1,隨后遍歷其左子樹(shù),最后遍歷其右子樹(shù),因此當(dāng)左子樹(shù)遍歷完后,必須要返回到其右子樹(shù)來(lái)繼續(xù)遍歷;為了能夠在左子樹(shù)遍歷完成后移動(dòng)到右子樹(shù),必須保留根節(jié)點(diǎn)的信息,能夠?qū)崿F(xiàn)該信息存儲(chǔ)的抽象數(shù)據(jù)類型顯而易見(jiàn)是棧,由于它是LIFO的結(jié)構(gòu),所以它可以以逆序來(lái)匯過(guò)去該信息并返回到右子樹(shù);

前序遍歷可以如下定義:

  • 訪問(wèn)根節(jié)點(diǎn);
  • 按前序遍歷方式遍歷左子樹(shù);
  • 按前序遍歷方式遍歷右子樹(shù);

利用前序遍歷方法上圖所示的樹(shù)的輸出序列為:1 2 4 5 3 6 7

void preOrder(BinaryTreeNode root) {if (null != root) {System.out.println(root.getData());preOrder(root.getLeft());preOrder(root.getRight());} }

中序遍歷

在中序遍歷中,根節(jié)點(diǎn)的訪問(wèn)在兩棵子樹(shù)的遍歷中間完成,中序遍歷如下定義:

  • 按中序遍歷方式遍歷左子樹(shù);
  • 訪問(wèn)根節(jié)點(diǎn);
  • 按中序遍歷方式遍歷右子樹(shù);

基于中序遍歷,上圖所示樹(shù)的中序遍歷輸出順序?yàn)?#xff1a;4 2 5 1 6 3 7

void inOrder(BinaryTreeNode root) {if (null != root) {inOrder(root.getLeft());System.out.println(root.getData());inOrder(root.getRight());} }

后序遍歷

在后續(xù)遍歷中,根節(jié)點(diǎn)的訪問(wèn)是在其兩棵子樹(shù)都遍歷完成后進(jìn)行的,后續(xù)遍歷如下定義:

  • 按后序遍歷左子樹(shù);
  • 按后序遍歷右子樹(shù);
  • 訪問(wèn)根節(jié)點(diǎn);

對(duì)上圖所示的二叉樹(shù),后續(xù)遍歷產(chǎn)生的輸出序列為:4 5 2 6 7 3 1

void postOrder(BinaryTreeNode root) {if (null != root) {postOrder(root.getLeft());postOrder(root.getRight());System.out.println(root.getData());} }

層次遍歷

層次遍歷的定義如下:

  • 訪問(wèn)根節(jié)點(diǎn);
  • 在訪問(wèn)第l層時(shí),將l+1層的節(jié)點(diǎn)按順序保存在隊(duì)列中;
  • 進(jìn)入下一層并訪問(wèn)該層的所有結(jié)點(diǎn);
  • 重復(fù)上述操作直至所有層都訪問(wèn)完;

對(duì)于上圖所示的二叉樹(shù),層次遍歷產(chǎn)生的輸出序列為:1 2 3 4 5 6 7

void levelOrder(BinaryTreeNode root) {BinaryTreeNode temp;LoopQueue Q = new LoopQueue();if (null == root) {return;}Q.enqueue(root);while (!Q.isEmpty()) {temp = Q.dequeue();// 處理當(dāng)前節(jié)點(diǎn)System.out.println(temp.getData());if (temp.getLeft()) {Q.enqueue(temp.getLeft());}if (temp.getRight()) {Q.enqueue(temp.getRight());}}// 刪除隊(duì)列中的所有數(shù)據(jù)Q.deletequeue(); }

二叉搜索樹(shù)

在二叉搜索樹(shù)中,所有左子樹(shù)結(jié)點(diǎn)的元素小于根節(jié)點(diǎn)的數(shù)據(jù),所有右子樹(shù)結(jié)點(diǎn)的元素大于根節(jié)點(diǎn)數(shù)據(jù),注意,樹(shù)中的每個(gè)結(jié)點(diǎn)都應(yīng)滿足這個(gè)性質(zhì);

實(shí)現(xiàn)自己的二叉搜索樹(shù)

其中包含了常用的一些方法,包括幾種遍歷方法還有查詢、刪除等,僅供參考:

public class BST<E extends Comparable<E>> {private class Node{public E e;public Node left, right;public Node(E e){this.e = e;left = null;right = null;}}private Node root;private int size;public BST(){root = null;size = 0;}public int size(){return size;}public boolean isEmpty(){return size == 0;}// 向二分搜索樹(shù)中添加新的元素epublic void add(E e){root = add(root, e);}// 向以node為根的二分搜索樹(shù)中插入元素e,遞歸算法// 返回插入新節(jié)點(diǎn)后二分搜索樹(shù)的根private Node add(Node node, E e){if(node == null){size ++;return new Node(e);}if(e.compareTo(node.e) < 0)node.left = add(node.left, e);else if(e.compareTo(node.e) > 0)node.right = add(node.right, e);return node;}// 看二分搜索樹(shù)中是否包含元素epublic boolean contains(E e){return contains(root, e);}// 看以node為根的二分搜索樹(shù)中是否包含元素e, 遞歸算法private boolean contains(Node node, E e){if(node == null)return false;if(e.compareTo(node.e) == 0)return true;else if(e.compareTo(node.e) < 0)return contains(node.left, e);else // e.compareTo(node.e) > 0return contains(node.right, e);}// 二分搜索樹(shù)的前序遍歷public void preOrder(){preOrder(root);}// 前序遍歷以node為根的二分搜索樹(shù), 遞歸算法private void preOrder(Node node){if(node == null)return;System.out.println(node.e);preOrder(node.left);preOrder(node.right);}// 二分搜索樹(shù)的非遞歸前序遍歷public void preOrderNR(){Stack<Node> stack = new Stack<>();stack.push(root);while(!stack.isEmpty()){Node cur = stack.pop();System.out.println(cur.e);if(cur.right != null)stack.push(cur.right);if(cur.left != null)stack.push(cur.left);}}// 二分搜索樹(shù)的中序遍歷public void inOrder(){inOrder(root);}// 中序遍歷以node為根的二分搜索樹(shù), 遞歸算法private void inOrder(Node node){if(node == null)return;inOrder(node.left);System.out.println(node.e);inOrder(node.right);}// 二分搜索樹(shù)的后序遍歷public void postOrder(){postOrder(root);}// 后序遍歷以node為根的二分搜索樹(shù), 遞歸算法private void postOrder(Node node){if(node == null)return;postOrder(node.left);postOrder(node.right);System.out.println(node.e);}// 二分搜索樹(shù)的層序遍歷public void levelOrder(){Queue<Node> q = new LinkedList<>();q.add(root);while(!q.isEmpty()){Node cur = q.remove();System.out.println(cur.e);if(cur.left != null)q.add(cur.left);if(cur.right != null)q.add(cur.right);}}// 尋找二分搜索樹(shù)的最小元素public E minimum(){if(size == 0)throw new IllegalArgumentException("BST is empty!");return minimum(root).e;}// 返回以node為根的二分搜索樹(shù)的最小值所在的節(jié)點(diǎn)private Node minimum(Node node){if(node.left == null)return node;return minimum(node.left);}// 尋找二分搜索樹(shù)的最大元素public E maximum(){if(size == 0)throw new IllegalArgumentException("BST is empty");return maximum(root).e;}// 返回以node為根的二分搜索樹(shù)的最大值所在的節(jié)點(diǎn)private Node maximum(Node node){if(node.right == null)return node;return maximum(node.right);}// 從二分搜索樹(shù)中刪除最小值所在節(jié)點(diǎn), 返回最小值public E removeMin(){E ret = minimum();root = removeMin(root);return ret;}// 刪除掉以node為根的二分搜索樹(shù)中的最小節(jié)點(diǎn)// 返回刪除節(jié)點(diǎn)后新的二分搜索樹(shù)的根private Node removeMin(Node node){if(node.left == null){Node rightNode = node.right;node.right = null;size --;return rightNode;}node.left = removeMin(node.left);return node;}// 從二分搜索樹(shù)中刪除最大值所在節(jié)點(diǎn)public E removeMax(){E ret = maximum();root = removeMax(root);return ret;}// 刪除掉以node為根的二分搜索樹(shù)中的最大節(jié)點(diǎn)// 返回刪除節(jié)點(diǎn)后新的二分搜索樹(shù)的根private Node removeMax(Node node){if(node.right == null){Node leftNode = node.left;node.left = null;size --;return leftNode;}node.right = removeMax(node.right);return node;}// 從二分搜索樹(shù)中刪除元素為e的節(jié)點(diǎn)public void remove(E e){root = remove(root, e);}// 刪除掉以node為根的二分搜索樹(shù)中值為e的節(jié)點(diǎn), 遞歸算法// 返回刪除節(jié)點(diǎn)后新的二分搜索樹(shù)的根private Node remove(Node node, E e){if( node == null )return null;if( e.compareTo(node.e) < 0 ){node.left = remove(node.left , e);return node;}else if(e.compareTo(node.e) > 0 ){node.right = remove(node.right, e);return node;}else{ // e.compareTo(node.e) == 0// 待刪除節(jié)點(diǎn)左子樹(shù)為空的情況if(node.left == null){Node rightNode = node.right;node.right = null;size --;return rightNode;}// 待刪除節(jié)點(diǎn)右子樹(shù)為空的情況if(node.right == null){Node leftNode = node.left;node.left = null;size --;return leftNode;}// 待刪除節(jié)點(diǎn)左右子樹(shù)均不為空的情況// 找到比待刪除節(jié)點(diǎn)大的最小節(jié)點(diǎn), 即待刪除節(jié)點(diǎn)右子樹(shù)的最小節(jié)點(diǎn)// 用這個(gè)節(jié)點(diǎn)頂替待刪除節(jié)點(diǎn)的位置Node successor = minimum(node.right);successor.right = removeMin(node.right);successor.left = node.left;node.left = node.right = null;return successor;}}@Overridepublic String toString(){StringBuilder res = new StringBuilder();generateBSTString(root, 0, res);return res.toString();}// 生成以node為根節(jié)點(diǎn),深度為depth的描述二叉樹(shù)的字符串private void generateBSTString(Node node, int depth, StringBuilder res){if(node == null){res.append(generateDepthString(depth) + "null\n");return;}res.append(generateDepthString(depth) + node.e +"\n");generateBSTString(node.left, depth + 1, res);generateBSTString(node.right, depth + 1, res);}private String generateDepthString(int depth){StringBuilder res = new StringBuilder();for(int i = 0 ; i < depth ; i ++)res.append("--");return res.toString();} }

LeetCode相關(guān)題目整理

94.二叉樹(shù)的中序遍歷

我的答案:(1ms)

public List<Integer> inorderTraversal(TreeNode root) {List result = new ArrayList();if (null != root) {result.addAll(inorderTraversal(root.left));result.add(root.val);result.addAll(inorderTraversal(root.right));}return result; }

參考答案:(0ms)

public List<Integer> inorderTraversal(TreeNode root) {List<Integer> list=new ArrayList<>();traversal(root, list);return list; }public void traversal(TreeNode root,List<Integer> list) {if(root!=null){traversal(root.left, list);list.add(root.val);traversal(root.right, list);} }

98. 驗(yàn)證二叉搜索樹(shù)

我的答案:(53ms)

private static int INT_MIN = Integer.MIN_VALUE; private static int INT_MAX = Integer.MAX_VALUE;public boolean isValidBST(TreeNode root) {// 如果節(jié)點(diǎn)為空則滿足二叉搜索樹(shù)條件if (null == root) {return true;}// 如果左孩子結(jié)點(diǎn)大于了根節(jié)點(diǎn)則返回falseif (null != root.left && findMax(root.left) > root.val) {return false;}// 如果右孩子結(jié)點(diǎn)小于了根節(jié)點(diǎn)則返回falseif (null != root.right && findMin(root.right) < root.val) {return false;}// 遞歸判斷左子樹(shù)和右子樹(shù),若其中有一顆不是BST樹(shù),則返回falseif (!isValidBST(root.left) || !isValidBST(root.right)) {return false;}// 通過(guò)所有判斷則是一顆BST樹(shù)return true; }/*** 找到一顆非空樹(shù)中的最大值** @param root* @return*/ private int findMax(TreeNode root) {int maxVal = INT_MIN;int leftMaxVal = INT_MIN;int rightMaxVal = INT_MIN;if (null != root) {// 最大值默認(rèn)等于當(dāng)前節(jié)點(diǎn)值maxVal = root.val;leftMaxVal = findMax(root.left);rightMaxVal = findMax(root.right);// maxVal等于當(dāng)前maxVal與leftMaxVal中較大的一個(gè)maxVal = maxVal > leftMaxVal ? maxVal : leftMaxVal;// maxVal等于當(dāng)前maxVal與rightMaxVal中較大的一個(gè)maxVal = maxVal > rightMaxVal ? maxVal : rightMaxVal;}return maxVal; }/*** 找到一顆非空樹(shù)的最小值** @param root* @return*/ private int findMin(TreeNode root) {int minVal = INT_MAX;int leftMinVal = INT_MAX;int rightMinVal = INT_MAX;if (null != root) {// 最小值默認(rèn)為當(dāng)前節(jié)點(diǎn)值minVal = root.val;leftMinVal = findMin(root.left);rightMinVal = findMin(root.right);// minVal等于當(dāng)前minVal與leftMinVal中較小的一個(gè)minVal = minVal < leftMinVal ? minVal : leftMinVal;// minVal等于當(dāng)前minVal與rightMinVal中較小的一個(gè)minVal = minVal < rightMinVal ? minVal : rightMinVal;}return minVal; }

自己寫的時(shí)候提交錯(cuò)了很多次..沒(méi)有掌握到二分搜索樹(shù)的精髓..

參考答案:(2ms)

public boolean isValidBST(TreeNode root) {if (root == null) return true;return valid(root, Long.MIN_VALUE, Long.MAX_VALUE); } public boolean valid(TreeNode root, long low, long high) {if (root == null) return true;if (root.val <= low || root.val >= high) return false;return valid(root.left, low, root.val) && valid(root.right, root.val, high); }

這答案寫得我服了..真服..

101. 對(duì)稱二叉樹(shù)(劍指Offer面試題28)

參考答案:(12ms)

public boolean isSymmetric(TreeNode root) {return isSymmetric(root, root); }public boolean isSymmetric(TreeNode root1, TreeNode root2) {if (null == root1 && null == root2) {return true;}if (null == root1 || null == root2) {return false;}if (root1.val != root2.val) {return false;}return isSymmetric(root1.left, root2.right) && isSymmetric(root1.right, root2.left); }

自己做的思路是使用中序遍歷來(lái)判斷(轉(zhuǎn)成數(shù)組之后是對(duì)稱的),但是出了很多問(wèn)題,就是需要考慮null值,中序遍歷中并不能很好地把一棵樹(shù)保存為一個(gè)完整二叉樹(shù)的樣子..所以看了下參考答案..寫得服..

104. 二叉樹(shù)的最大深度(劍指Offer面試題55)

我的答案:(3ms)

public int maxDepth(TreeNode root) {int leftHeight, rightHeight;if (null == root) {return 0;} else { // 計(jì)算每個(gè)子樹(shù)的高度leftHeight = maxDepth(root.left);rightHeight = maxDepth(root.right);return leftHeight > rightHeight ? leftHeight + 1 : rightHeight + 1;} }

參考答案:(0ms)

public int maxDepth(TreeNode root) {if(root==null)return 0;return Math.max(maxDepth(root.left)+1,maxDepth(root.right)+1); }

105. 從前序與中序遍歷序列構(gòu)造二叉樹(shù)(劍指Offer面試題7)

參考答案:(2ms)

public TreeNode buildTree(int[] preorder, int[] inorder) {if (preorder == null || preorder.length == 0) {return null;}return buildTree(preorder, inorder, 0, 0, inorder.length - 1); }private TreeNode buildTree(int[] preorder, int[] inorder, int ps, int is, int ie) {int val = preorder[ps];TreeNode node = new TreeNode(val);int iRoot = ie;while (iRoot > is) {if (val == inorder[iRoot]) {break;}iRoot--;}if (iRoot > is) {node.left = buildTree(preorder, inorder, ps + 1, is, iRoot - 1);}if (iRoot < ie) {node.right = buildTree(preorder, inorder, ps + 1 + (iRoot - is), iRoot + 1, ie);}return node; }

思路是這樣的:在二叉樹(shù)的前序遍歷序列中,第一個(gè)數(shù)字總是樹(shù)的根節(jié)點(diǎn)的值,但在中序遍歷序列中,根節(jié)點(diǎn)的值保存在序列的中間,左子樹(shù)的節(jié)點(diǎn)的值位于根節(jié)點(diǎn)的值的左邊,而右子樹(shù)則相反,然后既然找到了左右子樹(shù)我們又可以使用同樣的方法在前序和中序中分別構(gòu)建左右子樹(shù),這樣我們就能夠使用遞歸的方法完成;(上面算法中的ps、is、ie分別表示前序的開(kāi)始位置,中序的開(kāi)始位置和中序的結(jié)束位置;)

113. 路徑總和 II(劍指Offer面試題34)

參考答案:(3ms)

public List<List<Integer>> pathSum(TreeNode root, int sum) {List<Integer> nodeList = new ArrayList<Integer>();List<List<Integer>> sumList = new ArrayList<List<Integer>>();if (root == null) {return sumList;}pathSum2(root, sum, sumList, nodeList);return sumList; }public void pathSum2(TreeNode root, int target,List<List<Integer>> sumList, List<Integer> nodeList) {if (root.left == null && root.right == null) {nodeList.add(root.val);int sum = 0;for (Integer integer : nodeList) {sum += integer;}if (sum == target) {sumList.add(new ArrayList<Integer>(nodeList));}return;}nodeList.add(root.val);if (root.left != null) {pathSum2(root.left, target, sumList, nodeList);nodeList.remove(nodeList.size() - 1);}if (root.right != null) {pathSum2(root.right, target, sumList, nodeList);nodeList.remove(nodeList.size() - 1);} }

230. 二叉搜索樹(shù)中第K小的元素(類似劍指Offer面試題54)

我的答案:(23ms)

public int kthSmallest(TreeNode root, int k) {// 正確性判斷if (null == root || k < 1) {return -1;}List<Integer> result = preOrder(root);// 從小到大排序Collections.sort(result);return result.get(k - 1); }/*** 遍歷整棵樹(shù)并返回一個(gè)List** @param root* @return*/ private List<Integer> preOrder(TreeNode root) {List result = new ArrayList();if (null != root) {result.add(root.val);result.addAll(preOrder(root.left));result.addAll(preOrder(root.right));}return result; }

賊蠢,完全沒(méi)有用到二叉搜索樹(shù)的特性

參考答案:(1ms)

public int kthSmallest(TreeNode root, int k) {int count = countNodes(root.left);if (k <= count) {return kthSmallest(root.left, k);} else if (k > count + 1) {return kthSmallest(root.right, k - 1 - count);}return root.val; }public int countNodes(TreeNode n) {if (n == null) return 0;return 1 + countNodes(n.left) + countNodes(n.right); }

449. 序列化二叉搜索樹(shù)(類似劍指Offer面試題37)

參考答案:(12ms)

// Encodes a tree to a single string. public String serialize(TreeNode root) {StringBuffer sb = new StringBuffer();preOrder(root,sb);return sb.toString(); } private static void preOrder(TreeNode root, StringBuffer sb){if(root==null)return;sb.append(root.val).append('#');preOrder(root.left,sb);preOrder(root.right,sb); }// Decodes your encoded data to tree. public TreeNode deserialize(String data) {if(data==null)return null;int val =0;TreeNode root = null;for(int i=0;i<data.length();i++){if(data.charAt(i)!='#'){val = val*10+(data.charAt(i)-'0');}else{root = insert(root,val);val=0;}}return root; } private static TreeNode insert(TreeNode root,int val){if(root==null)return new TreeNode(val);if(root.val<val)root.right = insert(root.right,val);elseroot.left = insert(root.left,val);return root; }

572. 另一個(gè)樹(shù)的子樹(shù)(類似劍指Offer面試題26)

參考答案:(15ms)

public boolean isSubtree(TreeNode s, TreeNode t) {// Write your code hereif (s == null) {return t == null;}if (s.val == t.val && isSametree(s, t)) {return true;}return isSubtree(s.left, t) | isSubtree(s.right, t); }private boolean isSametree(TreeNode s, TreeNode t) {if (s == null) {return t == null;}if (t == null) {return false;}if (s.val != t.val) {return false;}return isSametree(s.left, t.left) & isSametree(s.right, t.right); }

我的第一個(gè)反應(yīng)還是去把兩棵樹(shù)的前序遍歷的數(shù)組弄出來(lái)然后判斷是否為子集,但是樹(shù)這樣的天然遞歸結(jié)構(gòu)這樣寫很自然...


簡(jiǎn)單總結(jié)

還是只是簡(jiǎn)單復(fù)習(xí)了一下樹(shù)的相關(guān)知識(shí)吧,通過(guò)刷LeetCode題目還有參照著劍指Offer對(duì)二叉樹(shù)、二叉搜索樹(shù)僅僅這兩種結(jié)構(gòu)有了一個(gè)較深的認(rèn)識(shí),因?yàn)楹罄m(xù)還會(huì)繼續(xù)用到,所以這里簡(jiǎn)單復(fù)習(xí)一下也無(wú)所謂,不過(guò)看著題目倒是感覺(jué)這樣的結(jié)構(gòu)很容易考面試題啊,因?yàn)檫@些結(jié)構(gòu)既重要考點(diǎn)又多...

歡迎轉(zhuǎn)載,轉(zhuǎn)載請(qǐng)注明出處!
簡(jiǎn)書ID:@我沒(méi)有三顆心臟
github:wmyskxz

《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結(jié)

以上是生活随笔為你收集整理的数据结构与算法(3)——树(二叉、二叉搜索树)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

精品二区视频 | 在线看一级片 | 欧美另类视频 | av免费看电影 | 五月婷婷精品 | 日韩免费b | 9999在线观看 | 国产精品欧美久久久久久 | 免费看国产精品 | 久久视频在线观看中文字幕 | aaa亚洲精品一二三区 | 亚洲精品资源在线观看 | 天天操天天操天天操天天操天天操天天操 | 久久经典视频 | 99视频在线观看免费 | 蜜臀久久99静品久久久久久 | 美女国内精品自产拍在线播放 | 亚洲闷骚少妇在线观看网站 | 伊人婷婷综合 | 久久国产影视 | 成人免费网站视频 | 国产免费久久av | 日韩激情久久 | 久久精品高清 | av一二三区 | 亚洲精品a区 | 日b视频在线观看网址 | 免费看一级黄色 | 一级片视频免费观看 | 久久视频一区二区 | 国产精品普通话 | 日韩黄视频| 日日爱999| 亚洲精品白浆高清久久久久久 | 国产99久久九九精品免费 | 国产精品va在线 | 美女福利视频一区二区 | 日日草夜夜操 | 六月色 | 国产视 | 国产精品久久久久久久免费观看 | 日韩理论片中文字幕 | 黄色av一级片 | 日韩欧美视频一区二区 | 欧美日韩免费看 | 久久99久久99精品免观看粉嫩 | 91精品国产成 | 丁香六月婷婷开心婷婷网 | 在线观看完整版 | 综合久久2023| 五月婷婷中文 | 亚洲精品视频在线观看免费视频 | 欧美精品亚州精品 | 最近中文字幕完整视频高清1 | 韩日三级在线 | 久久国产精品久久精品 | 天天综合日| 麻豆系列在线观看 | 九九99靖品| 成人午夜影院 | av千婊在线免费观看 | 999抗病毒口服液 | 久久午夜精品影院一区 | 黄色一级动作片 | 色婷婷av一区 | 五月天久久精品 | 人人干狠狠操 | 天天艹日日干 | 天天操天天能 | 欧美精品一区二区三区一线天视频 | 日本在线观看一区 | 国产精品欧美一区二区 | 色久网| 国产激情电影综合在线看 | 天天超碰| 婷婷综合视频 | 亚洲国产精品第一区二区 | 97超碰中文 | 欧美日韩精品在线观看 | 欧美性大战久久久久 | 91女子私密保健养生少妇 | 久久精品91久久久久久再现 | 亚洲一区二区三区在线看 | 亚洲免费小视频 | 中文字幕在线观看网站 | 亚洲免费av观看 | 日本大片免费观看在线 | 国产中文字幕亚洲 | 久久久免费少妇 | 中文十次啦 | 精品福利国产 | 四虎最新入口 | 久久精品视频3 | 精品久久一二三区 | 欧美另类v| 国产精品综合在线 | 免费h在线观看 | 欧美俄罗斯性视频 | 亚洲激情电影在线 | 一区二区不卡在线观看 | 欧美成天堂网地址 | 久久精品视频网址 | 麻豆视频91| 亚洲综合在线一区二区三区 | 日本精品xxxx | 国产精品免费大片视频 | 国产美女精品视频 | 最近中文字幕视频网 | 国产精品剧情在线亚洲 | av免费在线观看1 | 蜜臀一区二区三区精品免费视频 | 国产精成人品免费观看 | 在线播放亚洲激情 | 国产91电影在线观看 | av免费片 | 天天做天天射 | 亚洲五月六月 | 在线久热 | 免费欧美精品 | 91九色视频| 97超碰总站 | 久久黄页 | 免费观看成人网 | 日韩在线激情 | 久久久久草| 国产视频精选 | 欧美一级在线看 | 国色天香在线观看 | 国产视频18 | 一区二区三区www | 午夜电影久久 | 最新国产视频 | 国产成人av片 | 色国产视频 | 欧美天天综合网 | www.大网伊人| 欧美日韩精品在线观看视频 | 久久精品国产第一区二区三区 | 亚洲干视频在线观看 | 国产精品久久久久久妇 | 欧美精品亚洲二区 | 久久精品国产亚洲a | 欧美精品在线免费 | 97视频在线 | 精品国产乱码久久久久久久 | 午夜精品电影 | 激情五月婷婷综合网 | 麻豆影视网| 久久理论电影 | 最近2019年日本中文免费字幕 | 国产永久网站 | 香蕉视频网站在线观看 | 在线99热 | 日本久久免费电影 | 99在线精品视频观看 | 色婷婷综合久色 | 一级性视频 | 国产黄色免费观看 | 97人人爽| 亚洲另类在线视频 | 在线观看免费视频 | 亚洲高清视频在线 | www.五月婷 | 国产一区二区三区黄 | 欧美另类一二三四区 | 一二区电影 | 亚洲精品国产精品国 | 色综合久久久久综合 | 99色国产| 久久www免费人成看片高清 | 久在线观看视频 | 精品亚洲欧美一区 | 在线精品视频免费播放 | 九九免费观看视频 | 99久久精品一区二区成人 | 亚洲片在线| 欧美激情综合五月色丁香小说 | 国产123av| 中文网丁香综合网 | 久久免费在线观看 | 精品国产91亚洲一区二区三区www | 丁香婷婷久久久综合精品国产 | 精品无人国产偷自产在线 | 黄色国产成人 | 又黄又刺激视频 | 久久精品视频网站 | adc在线观看 | 午夜精品久久久久久久99热影院 | 免费在线观看中文字幕 | 国产日韩在线播放 | 日日夜夜91 | 福利一区二区三区四区 | 日韩在线资源 | 日韩精品在线看 | 欧美日韩3p | 韩国在线一区 | 1024手机看片国产 | 伊人色综合久久天天网 | 久久精品久久久久电影 | 欧美91精品国产自产 | 国产高清在线精品 | 69视频在线 | 成人a视频片观看免费 | www色片 | 日韩中文字幕91 | 久99精品 | 久草在线视频在线 | a黄色片在线观看 | 国内免费的中文字幕 | 99久久99视频 | а天堂中文最新一区二区三区 | 波多野结衣在线视频一区 | 玖玖视频在线 | 婷婷丁香在线视频 | 日韩精品在线观看av | 久久精品久久99精品久久 | 日本高清dvd| 在线视频欧美亚洲 | 免费高清在线观看电视网站 | 色五婷婷 | 亚洲专区中文字幕 | 天天草天天草 | 欧美成天堂网地址 | 热久久99这里有精品 | 美女露久久 | 亚洲精品国产电影 | 亚洲国产精品传媒在线观看 | 免费视频黄 | 在线观看视频中文字幕 | 日韩视频区 | 国产成人免费在线 | 99热这里只有精品在线观看 | aa一级片| 超碰夜夜| 六月激情网 | 国产精品成人一区二区三区吃奶 | 午夜国产福利在线观看 | 伊人激情综合 | 亚洲精品资源在线观看 | 日本久久成人 | 午夜精品视频在线 | 成人国产精品久久久久久亚洲 | 成人不用播放器 | 久久免费精品国产 | 天天爽网站 | 亚洲国产三级在线观看 | 久久婷婷综合激情 | 五月婷色 | 成人a视频片观看免费 | 狠狠色丁香婷婷综合久小说久 | 美女视频a美女大全免费下载蜜臀 | 久久久久99精品国产片 | 免费观看版 | 国产xxxx性hd极品 | 五月天视频网站 | 欧美日韩国产一二三区 | www最近高清中文国语在线观看 | 日日躁你夜夜躁你av蜜 | 国产免码va在线观看免费 | 特级西西www44高清大胆图片 | 亚洲精品高清视频在线观看 | 国内精品国产三级国产aⅴ久 | 成人禁用看黄a在线 | 日韩欧美一区二区三区在线观看 | 夜夜操狠狠操 | 99欧美视频 | 中文综合在线 | 亚洲视频在线观看网站 | 在线电影a | 在线观看亚洲成人 | 亚洲精品一区二区久 | 在线观看日韩中文字幕 | 色姑娘综合网 | 奇米影视8888在线观看大全免费 | 天天躁日日躁狠狠躁 | 在线观看中文字幕视频 | 成人av片免费看 | 在线观看视频色 | 中文在线a在线 | 69国产盗摄一区二区三区五区 | 操一草| 久久亚洲区 | 美女精品久久久 | 久久精品欧美一区二区三区麻豆 | 久久久免费视频播放 | 国产中文字幕第一页 | 九九九九热精品免费视频点播观看 | 亚洲最新av在线网站 | 国产成人精品一区二区三区福利 | 国产91精品在线播放 | 国产黄影院色大全免费 | 欧洲亚洲国产视频 | 久久99精品国产一区二区三区 | 人人精久 | 91在线播 | 国产韩国日本高清视频 | 久久不卡国产精品一区二区 | 久久精品这里热有精品 | 波多野结衣在线观看一区 | 成人久久久精品国产乱码一区二区 | 色香蕉网 | 日本黄色大片儿 | 人人涩| 成人免费一级片 | 日韩高清三区 | 国产精品麻豆一区二区三区 | 一级特黄av | 欧美国产日韩一区二区三区 | www.福利视频 | 久久优 | 99国产视频 | 91在线免费视频观看 | 超碰伊人网 | 国产精品视频 | 国产精品色婷婷视频 | 久久亚洲综合色 | 国产美女免费看 | 欧美老女人xx | 亚洲一级国产 | 亚洲一区二区精品在线 | 97成人免费| 激情综合网在线观看 | 中文字幕首页 | 色婷婷狠狠五月综合天色拍 | 久久久九九 | 亚洲中字幕 | 人成在线免费视频 | 9999精品视频 | 日本中文字幕免费观看 | 伊人视频 | 久久久久中文 | 香蕉91视频 | 91亚洲在线 | 91爱爱免费观看 | 午夜精品视频免费在线观看 | 在线观看国产区 | 啪啪凸凸 | 亚洲天堂色婷婷 | 日韩国产精品久久久久久亚洲 | av丝袜美腿 | 中国精品少妇 | 中文字幕精品一区二区精品 | 美女国产免费 | 国产在线观看91 | 天天干人人 | 91污视频在线观看 | 亚洲最新av在线网站 | 91成人精品一区在线播放69 | 亚洲激情视频在线 | 久久乐九色婷婷综合色狠狠182 | 视频一区二区在线观看 | 精品久久精品 | 精品国产乱码久久久久久三级人 | 久久免费精品视频 | 久久99影院 | 欧美a免费 | 日日躁天天躁 | 在线视频日韩一区 | 91精品国产91久久久久福利 | 日本中文字幕在线一区 | 91成人小视频 | 久久精品官网 | 激情欧美国产 | 精品国产精品国产偷麻豆 | 激情婷婷亚洲 | 久久视频精品 | 午夜精品视频一区二区三区在线看 | 欧美激情视频在线免费观看 | 国产亚洲成av片在线观看 | 国产小视频你懂的在线 | 在线观看av中文字幕 | 婷婷精品进入 | 在线观看mv的中文字幕网站 | 久久一级片 | 日韩r级电影在线观看 | 免费黄色在线播放 | 超碰资源在线 | 天天爽夜夜爽精品视频婷婷 | 一本一本久久a久久精品牛牛影视 | 日p视频 | 国产精品久久久久一区二区 | 韩日电影在线免费看 | 国产视频中文字幕在线观看 | av高清一区二区三区 | 国产一区二区在线免费观看 | 亚洲欧美一区二区三区孕妇写真 | 九九九国产 | 久久久久亚洲国产 | 天天天天天天天天操 | 国内精品视频在线 | 亚洲国产免费看 | 四季av综合网站 | 色综合久久久久综合体桃花网 | 日韩色高清 | 综合激情网... | 91九色蝌蚪视频 | 久久深夜 | 成人小视频在线免费观看 | 久久久毛片 | 日韩久久精品一区二区三区下载 | 国产一区免费观看 | 亚洲精品国产品国语在线 | 日本丰满少妇免费一区 | 一区二区三区在线免费 | 在线观看你懂的网址 | 天天玩天天操天天射 | 精选久久| 在线亚洲播放 | 国产午夜在线观看视频 | 亚洲 成人 欧美 | 最近日本中文字幕 | 奇米影视777四色米奇影院 | 亚洲涩涩网站 | 国产91免费在线 | 日日爽视频 | 五月天电影免费在线观看一区 | 亚洲我射av | 午夜久久久久久久久 | 国产成人精品久久久久 | 亚洲在线免费视频 | 精品一区91| 97超碰.com| av线上免费看 | 亚洲成人精品av | 欧美精品色 | 国内精品久久久久久久影视麻豆 | 91福利视频免费观看 | www亚洲国产 | 九九视频在线播放 | 亚洲2019精品 | 亚洲欧美国产日韩在线观看 | avav片 | 国产精品久久久久久麻豆一区 | 欧美精品做受xxx性少妇 | 国内精品国产三级国产aⅴ久 | 中文字幕在线看视频国产 | 久久激情五月婷婷 | 亚洲精品国产精品99久久 | 波多野结衣在线观看一区二区三区 | 亚洲一级电影 | 久久精品国产免费看久久精品 | 美女福利视频在线 | 国产精选在线观看 | 久久久99国产精品免费 | 久久精品网站视频 | 人人插人人费 | 欧美一二三区播放 | 中文不卡视频在线 | 黄色一级大片在线观看 | 婷婷色资源 | 亚洲精品国产精品国自产在线 | 婷婷黄色片 | 欧美在线不卡一区 | 蜜臀av免费一区二区三区 | 天天综合导航 | 国产乱对白刺激视频在线观看女王 | 国产流白浆高潮在线观看 | 99精品亚洲 | 日韩精品视频久久 | 国产高清在线 | 日韩中文字幕免费电影 | 视频一区二区国产 | 国产人在线成免费视频 | 一级久久精品 | 免费国产视频 | 国产一区二区三区免费在线 | 国产黄色在线观看 | 五月天开心 | 日韩精品中文字幕在线播放 | 亚洲综合色丁香婷婷六月图片 | 久久夜靖品 | 国产69久久久 | 成人综合婷婷国产精品久久免费 | 国产一区网 | 91av电影在线 | 国产一区欧美在线 | 香蕉在线视频观看 | 欧美日韩在线网站 | av综合网址| 国产黄色精品视频 | 中文字幕在线不卡国产视频 | 国产成人高清av | 欧美国产日韩一区二区三区 | 国产精品露脸在线 | 日韩69视频 | 亚洲精品在线二区 | 啪啪肉肉污av国网站 | 国产一级淫片在线观看 | 欧美日韩免费视频 | 奇米网网址 | 91视频啊啊啊 | 日韩城人在线 | 国产精品女人久久久久久 | 亚洲精品国产精品国自 | 国产探花视频在线播放 | 91成年人在线观看 | 99国产精品免费网站 | 亚洲91在线| avove黑丝| 99久久精品久久久久久清纯 | 香蕉视频4aa| 中文字幕在线播放第一页 | 精品96久久久久久中文字幕无 | 亚洲精品免费在线视频 | 黄色不卡av| 精品久久福利 | 欧美在线视频二区 | 日日干夜夜草 | 久久久久女教师免费一区 | 国产在线观看你懂得 | 91成人在线视频观看 | 91.麻豆视频 | aaa亚洲精品一二三区 | 国产一区二区高清视频 | 欧美午夜精品久久久久久浪潮 | av在线成人| 久久免费观看少妇a级毛片 久久久久成人免费 | 九九有精品 | 国产精品久久亚洲 | 中文字幕成人在线 | 欧美经典久久 | 免费黄色网止 | 日韩在线视频网址 | 香蕉视频色 | 9ⅰ精品久久久久久久久中文字幕 | 国产美女搞久久 | 亚洲乱码中文字幕综合 | 丁香六月欧美 | 欧美激情综合色 | 日韩免费视频线观看 | 中文av一区二区 | 国产精品ssss在线亚洲 | 日韩一区二区三区免费视频 | 五月婷婷一区二区三区 | 91亚洲精品久久久蜜桃网站 | 2019中文 | 久久久久久久久亚洲精品 | 黄色成人影院 | 91在线中字| 久草在线欧美 | 日韩大片在线播放 | 99色网站 | 国产高清免费在线观看 | 在线 国产一区 | 国产一线天在线观看 | 亚洲人人精品 | 美女在线免费观看视频 | 国产视频一区在线免费观看 | 午夜精品av在线 | 国产在线第三页 | 国产精品网红直播 | 久精品在线观看 | 免费的黄色的网站 | 综合网天天 | 热久久视久久精品18亚洲精品 | 四虎成人免费影院 | 九九九在线观看 | av在线最新 | 在线国产日韩 | 亚洲欧美国内爽妇网 | 91视频 - v11av | av中文字幕在线免费观看 | 日韩三级精品 | 婷婷婷国产在线视频 | avav片 | 亚州国产精品久久久 | 在线 国产 亚洲 欧美 | 在线直播av| 狠狠ri| 日韩在线网址 | av一区二区三区在线观看 | 国产成人1区 | 日韩大片在线免费观看 | 91麻豆精品国产91久久久无需广告 | 国产一级精品在线观看 | 国产精品a级 | 国产专区日韩专区 | 国产在线专区 | 国产99一区二区 | 日本女人逼 | 国产无吗一区二区三区在线欢 | 免费网站在线观看成人 | 亚洲精品动漫在线 | 日韩欧美99 | 亚洲午夜av久久乱码 | 欧美精品亚洲二区 | 国产涩涩网站 | 99热国产在线中文 | 色婷婷综合久久久久中文字幕1 | 天堂久久电影网 | www.com黄| 91精品人成在线观看 | 日韩av电影一区 | 欧美亚洲成人免费 | 成人国产网址 | 国产精品综合久久久久久 | 日韩高清在线看 | 色欧美成人精品a∨在线观看 | 精品国产一二三四区 | 黄色大全免费观看 | 99c视频高清免费观看 | 日韩v在线91成人自拍 | 午夜视频在线瓜伦 | 黄色一级性片 | 高清av免费观看 | 精品五月天 | 欧美黑人巨大xxxxx | 日韩免费一区二区在线观看 | 成人黄色大片在线免费观看 | 亚洲精品国产日韩 | 久久99九九99精品 | 特级西西444www大精品视频免费看 | 日韩在线 | 国产精品私人影院 | 日韩精品久久久免费观看夜色 | 免费在线国产视频 | 成人久久久电影 | 国产激情免费 | 国产色久 | 亚洲视频在线观看免费 | 成人动漫精品一区二区 | 毛片一级免费一级 | av噜噜噜在线播放 | 亚州免费视频 | 久久99亚洲热视 | 日本在线观看中文字幕无线观看 | 久久久久久电影 | 色视频成人在线观看免 | 极品嫩模被强到高潮呻吟91 | 激情视频免费观看 | 久久综合视频网 | www.色爱 | 91久久精品日日躁夜夜躁国产 | 久久精品视频在线播放 | av一级网站 | 欧美性超爽 | 天天综合成人 | 日本精品久久久久 | 特级毛片爽www免费版 | 一级黄色免费网站 | 欧美在线视频a | 久久九九久久九九 | 黄色免费av| 一本一本久久a久久精品综合小说 | 国产精品一区二区三区在线免费观看 | 久久一二区 | 欧美成人久久 | 久久经典国产 | 在线观看国产一区二区 | 日韩中文字幕亚洲一区二区va在线 | 国产精品黄色影片导航在线观看 | 国产高清永久免费 | 日韩在线视频免费看 | 96精品高清视频在线观看软件特色 | 少妇bbb好爽 | 久久午夜免费视频 | 国产精品爽爽久久久久久蜜臀 | 美女在线免费视频 | 欧美aaaxxxx做受视频 | 国产精品涩涩屋www在线观看 | 国产精品久久在线 | 国产999免费视频 | 欧美精品久久久久 | 国产韩国日本高清视频 | 久久综合久久综合九色 | 国产日韩精品一区二区 | 精品一区二区三区久久久 | 久久婷婷色综合 | 欧美色图亚洲图片 | 天天插狠狠插 | 久久综合九色综合欧美就去吻 | 久久精品欧美一 | 一区电影 | 国产精品美乳一区二区免费 | 91成人精品一区在线播放69 | 日韩激情网| 女人18片 | 国产成人区 | 久久久 激情 | 九九热免费精品视频 | 国产视频一二区 | 成人a毛片 | 在线观看日韩视频 | av手机版 | 色av男人的天堂免费在线 | 国产成人一区二区啪在线观看 | 天天躁天天躁天天躁婷 | 97视频人人| 色婷婷激婷婷情综天天 | 成人资源在线 | 美女免费视频观看网站 | 国产在线探花 | 在线观看理论 | 国产经典 欧美精品 | 国产99中文字幕 | 一区二区三区日韩视频在线观看 | 午夜精品久久久久久久99 | 久久久久在线观看 | 人人射人人 | 激情综合久久 | 精品国产美女在线 | 精品高清美女精品国产区 | 日韩电影久久久 | 精品亚洲一区二区 | 成人av电影免费在线播放 | 香蕉一区 | 亚洲黄色在线观看 | 蜜臀av麻豆| 亚洲无人区小视频 | 国产精品igao视频网入口 | 91av在线免费看 | 欧美久久久久久久久中文字幕 | 午夜av电影 | 国内小视频 | 国产91小视频 | 国产精品原创av片国产免费 | 久久久久久久久久网 | 中文字幕 影院 | 青草草在线 | 国产精品福利无圣光在线一区 | 亚洲成av人片一区二区梦乃 | 91精品区 | 天天天天干 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 亚洲性xxxx | 玖玖国产精品视频 | 亚洲国产成人高清精品 | 天天色成人网 | 日韩av片免费在线观看 | 一区二区精品视频 | 国产一级片在线播放 | 国产91电影在线观看 | 成人小视频在线观看免费 | 中文字幕 婷婷 | 97碰碰视频| 日韩女同一区二区三区在线观看 | 日本激情视频中文字幕 | 91日韩精品| 欧美片一区二区三区 | 午夜影视剧场 | 国产精品99久久久久久宅男 | 国产精品久久久久999 | 东方av在线免费观看 | 色婷婷狠狠 | 天天看天天操 | 91视频观看免费 | 国产一级黄色片免费看 | 在线观看黄色小视频 | 在线视频第一页 | 亚洲区色 | 色福利网站| 亚洲精品观看 | 天天干天天看 | 91福利社在线观看 | 欧美激情xxxx性bbbb | 亚洲一级免费观看 | 美女一区网站 | 久久免费福利 | 日本99精品 | 久久草视频 | 国产手机视频 | 夜色资源站国产www在线视频 | 日韩高清在线一区二区三区 | 欧美一区二区三区特黄 | 99re久久资源最新地址 | 久草爱视频| 四虎影视成人精品国库在线观看 | 成人黄色免费在线观看 | 亚洲精品日韩一区二区电影 | 911在线 | 国内精品视频一区二区三区八戒 | 国产日韩欧美在线播放 | 日韩欧美xx | 美女精品久久久 | 国际精品久久久 | 天天操天天操天天操天天操天天操天天操 | 精品在线视频观看 | 我要看黄色一级片 | 日本久久免费视频 | 成人av影视在线 | 国产资源精品在线观看 | 免费看十八岁美女 | 婷婷久久一区二区三区 | 国产成人av福利 | 波多野结衣视频一区二区 | 超碰97在线资源站 | 日日爱视频 | 亚洲精品国产区 | 在线播放第一页 | 九九热久久免费视频 | 亚洲欧美综合 | 一区二区在线影院 | 免费成视频 | 日本中文字幕一二区观 | 天天草av| 国产激情小视频在线观看 | 午夜精品成人一区二区三区 | 精品一区二区三区久久久 | 99精品免费在线观看 | 韩国av免费在线 | 日韩在线观看中文字幕 | 色综合久久中文字幕综合网 | 免费午夜在线视频 | 人人爱爱 | 天干啦夜天干天干在线线 | 精品国产免费av | 少妇bbw搡bbbb搡bbbb | 国产xxxx做受性欧美88 | 久久国产精品免费一区 | 国产九九在线 | 国产成人精品一区二区在线 | 96视频免费在线观看 | 免费看日韩 | 亚洲三级网站 | 日本中文字幕电影在线免费观看 | av网站免费看 | 国产乱视频 | 亚洲女欲精品久久久久久久18 | 国产第一福利 | 天天色天天草天天射 | 成人黄色片免费 | 色婷婷www| 久久视频在线看 | 99亚洲精品视频 | 一区二区中文字幕在线 | 公开超碰在线 | 国产精品自拍在线 | 国产精品久久久久一区 | 色综合久久88色综合天天6 | 国产一级免费在线 | 国产涩涩在线观看 | 欧美精品v国产精品 | 日韩欧美高清 | 国产成人亚洲在线观看 | 91少妇精拍在线播放 | 国产高清在线视频 | 毛片区| 国产精品欧美久久久久天天影视 | 视频在线观看国产 | 国产精品一区二区三区99 | 精品亚洲免费视频 | 久久久久久久av | 国产99区 | 超碰在线观看99 | 伊人久久精品久久亚洲一区 | 成人福利在线播放 | 成人一区在线观看 | 97超碰超碰 | 天天操天天干天天爱 | 精品国产日本 | 欧美综合久久 | 青青草在久久免费久久免费 | 91看片在线看片 | 日韩久久久久久久久久久久 | 久久国内免费视频 | 国产视频在线播放 | 国产一级在线观看视频 | 最近中文字幕免费视频 | 色爽网站| 国产精品成久久久久三级 | 国产精品成人免费精品自在线观看 | 蜜桃av观看 | 久草网在线视频 | 国产美女免费视频 | 中文字幕在线视频精品 | 久久黄色小说视频 | 国产一区二区免费在线观看 | 欧美日本高清视频 | 久久综合影音 | 日韩爱爱网站 | 免费网站在线观看人 | 国产精品一区专区欧美日韩 | 久久精品99久久久久久 | 午夜在线免费观看视频 | 成人欧美一区二区三区黑人麻豆 | 狠狠操狠狠操 | 国产小视频在线 | 亚洲欧美va | 97视频在线免费观看 | 国产视频精品久久 | 亚洲视频网站在线观看 | 久久免费片| 天天婷婷 | 国产在线综合视频 | 欧美午夜视频在线 | 精品成人免费 | www.国产在线观看 | 成年人app网址 | 日韩欧美视频一区 | 玖玖色在线观看 | 天天艹| 国产精品免费麻豆入口 | 国产在线中文 | av高清网站在线观看 | 国产在线观看91 | 91mv.cool在线观看| 成年人电影免费看 | 久久久一本精品99久久精品 | 黄色片网站av | 国产一区二区中文字幕 | 一级黄色片在线免费看 | 免费网址你懂的 | 欧美色图东方 | 亚洲欧美日韩国产一区二区三区 | 久久好看| 天堂资源在线观看视频 | 九九热在线观看视频 | 国产高清中文字幕 | 四虎永久免费网站 | 免费在线观看毛片网站 | 成全免费观看视频 | 青草草在线视频 | 又色又爽又激情的59视频 | 久久久久中文 | 亚洲久草在线视频 | 午夜精品久久一牛影视 | 日韩高清不卡一区二区三区 | 在线观看视频日韩 | 国产精品自拍av | 夜夜嗨av色一区二区不卡 | 国产黄色一级片 | 91天天视频| 正在播放一区二区 | 国产精品久免费的黄网站 | 国产在线理论片 | 国产亚洲无| 69精品久久 | 久久精品老司机 | av黄在线播放 | 久久a免费视频 | 色婷婷狠狠18 | 综合久久一本 | 日韩v在线 | 就要干b| 欧美一级久久 | 亚洲视频精品 | 99精品视频免费看 | 亚洲天堂网在线观看视频 | 草久久av| av免费看在线 | 激情综合网天天干 | 久久影院精品 | 久草精品资源 | 网址你懂的在线观看 | 精品一区二区免费 | 激情伊人五月天 | 国产精品久久毛片 | 日本久久中文字幕 | 五月婷在线观看 | 国产xx在线 | 亚洲精品午夜一区人人爽 | 国产一区成人在线 | 精品国产一区二区三区四 | 久久久久综合 | 欧美色图30p | 国产午夜精品一区二区三区四区 | 午夜影视剧场 | 丁香花在线视频观看免费 | 国产欧美三级 | 国产高清免费av | 香蕉成人在线视频 | 天堂在线一区二区三区 | 国产精品原创视频 | 免费在线观看黄网站 | 日日夜夜91 | 中文字幕一区二区三区视频 | 亚洲黄色av网址 | 久久国产精品电影 | 久久免费一级片 | 久久久免费精品视频 | 国产在线欧美日韩 | 国产福利一区二区三区在线观看 | 国产精品五月天 | 五月婷婷久草 | 中文在线字幕观看电影 | 日韩最新理论电影 | 日韩高清 一区 | 国产精品一区二区在线免费观看 | 欧美巨大荫蒂茸毛毛人妖 | 999久久精品 | 97视频中文字幕 | 亚洲一级二级三级 | 欧美一级视频一区 | 久久婷婷一区二区三区 | 丰满少妇高潮在线观看 | 欧美国产日韩一区二区 | 精品国产一区二区三区日日嗨 | 91传媒免费观看 | 色噜噜色噜噜 | 亚洲影院天堂 | 97在线看 | 91在线中文 | 精品 激情 | 天天干,天天干 | av电影在线不卡 | 91香蕉久久 | 欧美日韩在线观看一区 | 九九色视频 |