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

一個套路,寫出來二叉樹的迭代遍歷

開發(fā) 前端
實踐過的同學,也會發(fā)現(xiàn)使用迭代法實現(xiàn)先中后序遍歷,很難寫出統(tǒng)一的代碼,不像是遞歸法,實現(xiàn)了其中的一種遍歷方式,其他兩種只要稍稍改一下節(jié)點順序就可以了。

[[411706]]

二叉樹的統(tǒng)一迭代法

此時我們在二叉樹:一入遞歸深似海,從此offer是路人中用遞歸的方式,實現(xiàn)了二叉樹前中后序的遍歷。

在二叉樹:聽說遞歸能做的,棧也能做!中用棧實現(xiàn)了二叉樹前后中序的迭代遍歷(非遞歸)。

之后我們發(fā)現(xiàn)迭代法實現(xiàn)的先中后序,其實風格也不是那么統(tǒng)一,除了先序和后序,有關聯(lián),中序完全就是另一個風格了,一會用棧遍歷,一會又用指針來遍歷。

實踐過的同學,也會發(fā)現(xiàn)使用迭代法實現(xiàn)先中后序遍歷,很難寫出統(tǒng)一的代碼,不像是遞歸法,實現(xiàn)了其中的一種遍歷方式,其他兩種只要稍稍改一下節(jié)點順序就可以了。

其實針對三種遍歷方式,使用迭代法是可以寫出統(tǒng)一風格的代碼!

重頭戲來了,接下來介紹一下統(tǒng)一寫法。

我們以中序遍歷為例,在二叉樹:聽說遞歸能做的,棧也能做!中提到說使用棧的話,無法同時解決訪問節(jié)點(遍歷節(jié)點)和處理節(jié)點(將元素放進結果集)不一致的情況。

那我們就將訪問的節(jié)點放入棧中,把要處理的節(jié)點也放入棧中但是要做標記。

如何標記呢,就是要處理的節(jié)點放入棧之后,緊接著放入一個空指針作為標記。 這種方法也可以叫做標記法。

迭代法中序遍歷

中序遍歷代碼如下:(詳細注釋)

  1. class Solution { 
  2. public
  3.     vector<int> inorderTraversal(TreeNode* root) { 
  4.         vector<int> result; 
  5.         stack<TreeNode*> st; 
  6.         if (root != NULL) st.push(root); 
  7.         while (!st.empty()) { 
  8.             TreeNode* node = st.top(); 
  9.             if (node != NULL) { 
  10.                 st.pop(); // 將該節(jié)點彈出,避免重復操作,下面再將右中左節(jié)點添加到棧中 
  11.                 if (node->right) st.push(node->right);  // 添加右節(jié)點(空節(jié)點不入棧) 
  12.  
  13.                 st.push(node);                          // 添加中節(jié)點 
  14.                 st.push(NULL); // 中節(jié)點訪問過,但是還沒有處理,加入空節(jié)點做為標記。 
  15.  
  16.                 if (node->left) st.push(node->left);    // 添加左節(jié)點(空節(jié)點不入棧) 
  17.             } else { // 只有遇到空節(jié)點的時候,才將下一個節(jié)點放進結果集 
  18.                 st.pop();           // 將空節(jié)點彈出 
  19.                 node = st.top();    // 重新取出棧中元素 
  20.                 st.pop(); 
  21.                 result.push_back(node->val); // 加入到結果集 
  22.             } 
  23.         } 
  24.         return result; 
  25.     } 
  26. }; 

看代碼有點抽象我們來看一下動畫(中序遍歷):

中序遍歷迭代(統(tǒng)一寫法)

動畫中,result數(shù)組就是最終結果集。

可以看出我們將訪問的節(jié)點直接加入到棧中,但如果是處理的節(jié)點則后面放入一個空節(jié)點, 這樣只有空節(jié)點彈出的時候,才將下一個節(jié)點放進結果集。

此時我們再來看前序遍歷代碼。

迭代法前序遍歷

迭代法前序遍歷代碼如下:(注意此時我們和中序遍歷相比僅僅改變了兩行代碼的順序)

  1. class Solution { 
  2. public
  3.     vector<int> preorderTraversal(TreeNode* root) { 
  4.         vector<int> result; 
  5.         stack<TreeNode*> st; 
  6.         if (root != NULL) st.push(root); 
  7.         while (!st.empty()) { 
  8.             TreeNode* node = st.top(); 
  9.             if (node != NULL) { 
  10.                 st.pop(); 
  11.                 if (node->right) st.push(node->right);  // 右 
  12.                 if (node->left) st.push(node->left);    // 左 
  13.                 st.push(node);                          // 中 
  14.                 st.push(NULL); 
  15.             } else { 
  16.                 st.pop(); 
  17.                 node = st.top(); 
  18.                 st.pop(); 
  19.                 result.push_back(node->val); 
  20.             } 
  21.         } 
  22.         return result; 
  23.     } 
  24. }; 

迭代法后序遍歷

后續(xù)遍歷代碼如下:(注意此時我們和中序遍歷相比僅僅改變了兩行代碼的順序)

  1. class Solution { 
  2. public
  3.     vector<int> postorderTraversal(TreeNode* root) { 
  4.         vector<int> result; 
  5.         stack<TreeNode*> st; 
  6.         if (root != NULL) st.push(root); 
  7.         while (!st.empty()) { 
  8.             TreeNode* node = st.top(); 
  9.             if (node != NULL) { 
  10.                 st.pop(); 
  11.                 st.push(node);                          // 中 
  12.                 st.push(NULL); 
  13.  
  14.                 if (node->right) st.push(node->right);  // 右 
  15.                 if (node->left) st.push(node->left);    // 左 
  16.  
  17.             } else { 
  18.                 st.pop(); 
  19.                 node = st.top(); 
  20.                 st.pop(); 
  21.                 result.push_back(node->val); 
  22.             } 
  23.         } 
  24.         return result; 
  25.     } 
  26. }; 

總結

此時我們寫出了統(tǒng)一風格的迭代法,不用在糾結于前序寫出來了,中序寫不出來的情況了。

但是統(tǒng)一風格的迭代法并不好理解,而且想在面試直接寫出來還有難度的。

所以大家根據(jù)自己的個人喜好,對于二叉樹的前中后序遍歷,選擇一種自己容易理解的遞歸和迭代法。

其他語言版本

Java:迭代法前序遍歷代碼如下:

  1. class Solution { 
  2.     public List<Integer> preorderTraversal(TreeNode root) { 
  3.         List<Integer> result = new LinkedList<>(); 
  4.         Stack<TreeNode> st = new Stack<>(); 
  5.         if (root != null) st.push(root); 
  6.         while (!st.empty()) { 
  7.             TreeNode node = st.peek(); 
  8.             if (node != null) { 
  9.                 st.pop(); // 將該節(jié)點彈出,避免重復操作,下面再將右中左節(jié)點添加到棧中 
  10.                 if (node.right!=null) st.push(node.right);  // 添加右節(jié)點(空節(jié)點不入棧) 
  11.                 if (node.left!=null) st.push(node.left);    // 添加左節(jié)點(空節(jié)點不入棧) 
  12.                 st.push(node);                          // 添加中節(jié)點 
  13.                 st.push(null); // 中節(jié)點訪問過,但是還沒有處理,加入空節(jié)點做為標記。 
  14.                  
  15.             } else { // 只有遇到空節(jié)點的時候,才將下一個節(jié)點放進結果集 
  16.                 st.pop();           // 將空節(jié)點彈出 
  17.                 node = st.peek();    // 重新取出棧中元素 
  18.                 st.pop(); 
  19.                 result.add(node.val); // 加入到結果集 
  20.             } 
  21.         } 
  22.         return result; 
  23.     } 

迭代法中序遍歷代碼如下:

  1. class Solution { 
  2. public List<Integer> inorderTraversal(TreeNode root) { 
  3.         List<Integer> result = new LinkedList<>(); 
  4.     Stack<TreeNode> st = new Stack<>(); 
  5.     if (root != null) st.push(root); 
  6.     while (!st.empty()) { 
  7.         TreeNode node = st.peek(); 
  8.         if (node != null) { 
  9.             st.pop(); // 將該節(jié)點彈出,避免重復操作,下面再將右中左節(jié)點添加到棧中 
  10.             if (node.right!=null) st.push(node.right);  // 添加右節(jié)點(空節(jié)點不入棧) 
  11.             st.push(node);                          // 添加中節(jié)點 
  12.             st.push(null); // 中節(jié)點訪問過,但是還沒有處理,加入空節(jié)點做為標記。 
  13.  
  14.             if (node.left!=null) st.push(node.left);    // 添加左節(jié)點(空節(jié)點不入棧) 
  15.         } else { // 只有遇到空節(jié)點的時候,才將下一個節(jié)點放進結果集 
  16.             st.pop();           // 將空節(jié)點彈出 
  17.             node = st.peek();    // 重新取出棧中元素 
  18.             st.pop(); 
  19.             result.add(node.val); // 加入到結果集 
  20.         } 
  21.     } 
  22.     return result; 

迭代法后序遍歷代碼如下:

  1. class Solution { 
  2.    public List<Integer> postorderTraversal(TreeNode root) { 
  3.         List<Integer> result = new LinkedList<>(); 
  4.         Stack<TreeNode> st = new Stack<>(); 
  5.         if (root != null) st.push(root); 
  6.         while (!st.empty()) { 
  7.             TreeNode node = st.peek(); 
  8.             if (node != null) { 
  9.                 st.pop(); // 將該節(jié)點彈出,避免重復操作,下面再將右中左節(jié)點添加到棧中 
  10.                 st.push(node);                          // 添加中節(jié)點 
  11.                 st.push(null); // 中節(jié)點訪問過,但是還沒有處理,加入空節(jié)點做為標記。 
  12.                 if (node.right!=null) st.push(node.right);  // 添加右節(jié)點(空節(jié)點不入棧) 
  13.                 if (node.left!=null) st.push(node.left);    // 添加左節(jié)點(空節(jié)點不入棧)          
  14.                                 
  15.             } else { // 只有遇到空節(jié)點的時候,才將下一個節(jié)點放進結果集 
  16.                 st.pop();           // 將空節(jié)點彈出 
  17.                 node = st.peek();    // 重新取出棧中元素 
  18.                 st.pop(); 
  19.                 result.add(node.val); // 加入到結果集 
  20.             } 
  21.         } 
  22.         return result; 
  23.    } 

Python:

迭代法前序遍歷:

  1. class Solution: 
  2.     def preorderTraversal(self, root: TreeNode) -> List[int]: 
  3.         result = [] 
  4.         st= [] 
  5.         if root: 
  6.             st.append(root) 
  7.         while st: 
  8.             node = st.pop() 
  9.             if node != None: 
  10.                 if node.right: #右 
  11.                     st.append(node.right
  12.                 if node.left: #左 
  13.                     st.append(node.left
  14.                 st.append(node) #中 
  15.                 st.append(None) 
  16.             else
  17.                 node = st.pop() 
  18.                 result.append(node.val) 
  19.         return result 

迭代法中序遍歷:

  1. class Solution: 
  2.     def inorderTraversal(self, root: TreeNode) -> List[int]: 
  3.         result = [] 
  4.         st = [] 
  5.         if root: 
  6.             st.append(root) 
  7.         while st: 
  8.             node = st.pop() 
  9.             if node != None: 
  10.                 if node.right: #添加右節(jié)點(空節(jié)點不入棧) 
  11.                     st.append(node.right
  12.                  
  13.                 st.append(node) #添加中節(jié)點 
  14.                 st.append(None) #中節(jié)點訪問過,但是還沒有處理,加入空節(jié)點做為標記。 
  15.                  
  16.                 if node.left: #添加左節(jié)點(空節(jié)點不入棧) 
  17.                     st.append(node.left
  18.             else: #只有遇到空節(jié)點的時候,才將下一個節(jié)點放進結果集 
  19.                 node = st.pop() #重新取出棧中元素 
  20.                 result.append(node.val) #加入到結果集 
  21.         return result 

迭代法后序遍歷:

  1. class Solution: 
  2.     def postorderTraversal(self, root: TreeNode) -> List[int]: 
  3.         result = [] 
  4.         st = [] 
  5.         if root: 
  6.             st.append(root) 
  7.         while st: 
  8.             node = st.pop() 
  9.             if node != None: 
  10.                 st.append(node) #中 
  11.                 st.append(None) 
  12.                  
  13.                 if node.right: #右 
  14.                     st.append(node.right
  15.                 if node.left: #左 
  16.                     st.append(node.left
  17.             else
  18.                 node = st.pop() 
  19.                 result.append(node.val) 
  20.         return result 

舊文鏈接:二叉樹:前中后序迭代方式的寫法就不能統(tǒng)一一下么?

 

責任編輯:武曉燕 來源: 代碼隨想錄
相關推薦

2020-04-27 07:05:58

二叉樹左子樹右子樹

2021-07-13 11:32:41

二叉樹數(shù)據(jù)結構算法

2013-07-15 16:35:55

二叉樹迭代器

2022-10-26 23:58:02

二叉樹數(shù)組算法

2021-04-20 08:37:14

數(shù)據(jù)結構二叉樹

2023-05-08 15:57:16

二叉樹數(shù)據(jù)結構

2021-09-15 07:56:32

二叉樹層次遍歷

2021-09-13 17:58:11

二叉樹層序算法

2021-02-28 22:00:28

二叉樹節(jié)點序列

2021-01-13 10:03:36

二叉樹層序遍歷層次遍歷

2009-08-11 13:29:57

C#二叉樹遍歷

2021-05-06 17:46:30

二叉樹數(shù)據(jù)結構

2021-04-19 07:47:42

數(shù)據(jù)結構二叉樹Tree

2024-01-23 12:54:00

C++編程語言代碼

2021-04-28 20:12:27

數(shù)據(jù)結構創(chuàng)建

2021-11-29 10:40:58

二叉樹鏡像節(jié)點

2021-08-27 11:36:44

二叉樹回溯節(jié)點

2021-03-17 08:19:22

二叉樹LeetCode

2021-09-29 10:19:00

算法平衡二叉樹

2021-12-17 14:26:58

二叉樹節(jié)點數(shù)量
點贊
收藏

51CTO技術棧公眾號

国产欧美日韩亚洲一区二区三区| 日韩综合久久| 91丨porny丨在线| 国产精品极品在线| 国产av无码专区亚洲av毛网站 | 国产精品精品久久久| 天天爽天天爽天天爽| 福利片在线一区二区| 色偷偷久久一区二区三区| 最新国产精品久久| 无套内谢的新婚少妇国语播放| 日韩不卡一区二区| 欧美精品福利视频| jizzjizz日本少妇| 色老板在线视频一区二区| 欧美日韩一级视频| 69堂免费视频| av片在线观看免费| 久久综合资源网| 成人av资源在线播放| 国产黄色片免费看| 午夜欧美精品久久久久久久| 在线观看久久久久久| 年下总裁被打光屁股sp| 日韩毛片免费看| 日韩欧美主播在线| 男人天堂手机在线视频| 精品欧美色视频网站在线观看| 99久久综合狠狠综合久久| 91精品视频免费| 无码人妻精品一区二区| 亚洲区欧美区| 欧美黑人巨大精品一区二区| 小泽玛利亚一区二区免费| 精品一区在线| 日韩av中文字幕在线免费观看| 亚洲天堂一区二区在线观看| 欧美日韩精品免费观看视欧美高清免费大片 | 91cn在线观看| 国产精品免费丝袜| 区一区二区三区中文字幕| 色综合免费视频| 岛国精品在线播放| 91久久国产综合久久蜜月精品| 中文字幕在线观看视频一区| 欧美亚洲自偷自偷| 欧美亚洲另类视频| 亚洲国产成人精品激情在线| 黄色欧美成人| 欧美激情综合亚洲一二区| 深夜福利影院在线观看| 亚洲一本二本| 久久久精品2019中文字幕神马| 国产中文字幕久久| 日韩欧美一区免费| 这里只有精品视频在线| 国产综合精品久久久久成人av| 视频一区在线观看| 国产亚洲欧美日韩一区二区| 精品国产成人亚洲午夜福利| 国产一区二区欧美| 中文字幕日韩在线观看| 婷婷综合在线视频| 99精品电影| 欧美成人午夜激情视频| 欧美人妻精品一区二区免费看| 午夜国产欧美理论在线播放 | 韩国主播福利视频一区二区三区| 精品国产乱码久久久久久婷婷| 久久久久久久久久久视频| 极品视频在线| 欧洲一区二区三区在线| 中文av一区二区三区| 日韩欧美专区| 欧美mv日韩mv国产网站| 日韩精品视频一区二区| 久久av资源| 日韩在线播放一区| www青青草原| 在线成人av| 欧美在线视频一区| 中文字幕视频在线播放| 国产高清成人在线| 精品久久中出| 超碰97在线免费观看| 亚洲欧洲综合另类| 无码熟妇人妻av在线电影| 18aaaa精品欧美大片h| 都市激情亚洲色图| 不卡的在线视频| 136导航精品福利| 精品亚洲一区二区三区| 肉色超薄丝袜脚交69xx图片| 精品二区久久| 国产成人精品最新| 精品人妻伦一区二区三区久久| 国产成人亚洲精品狼色在线| 免费av一区二区三区| 日本亚洲精品| 精品国产鲁一鲁一区二区张丽| 性欧美极品xxxx欧美一区二区| 日韩在线网址| 伊人伊成久久人综合网站| 久久在线视频精品| 秋霞午夜鲁丝一区二区老狼| 风间由美一区二区三区| av在线二区| 黄色成人av在线| 精品国产鲁一鲁一区二区三区| 日韩av午夜| 久久99久久99精品中文字幕| 五月天婷婷丁香| 精品一区二区三区影院在线午夜 | 国产传媒免费观看| 四虎884aa成人精品最新| 久久国产精品久久久久久| 99久热在线精品996热是什么| 久久国产精品区| 蜜桃传媒视频麻豆一区| 久草免费在线色站| 8x福利精品第一导航| 极品蜜桃臀肥臀-x88av| 性高湖久久久久久久久| 国产精品一区二区三区四区五区 | 91成人在线观看国产| 精品毛片在线观看| 中文字幕一区二区三区四区不卡| 久久精品免费一区二区| 风间由美中文字幕在线看视频国产欧美| 日韩一中文字幕| 中文字幕一区二区三区人妻四季 | 亚洲第一精品夜夜躁人人爽| 欧美丰满熟妇bbbbbb| 麻豆国产精品官网| 手机看片福利永久国产日韩| 亚洲精品成人图区| 亚洲国产另类久久精品| 九九久久免费视频| 国产一区二区调教| 伊人色综合影院| 黄色成人在线观看网站| 一区二区三区动漫| 欧美精品xxxxx| 日韩中文字幕麻豆| 久99久在线| 中文在线а√天堂| 日韩国产高清视频在线| 日韩在线视频免费播放| 99在线热播精品免费| 国产av天堂无码一区二区三区| 97超碰成人| 国语自产精品视频在线看抢先版图片 | 国产视频亚洲| 欧美日韩在线一二三| 在线毛片观看| 精品香蕉一区二区三区| 在线观看日本网站| 国产亚洲成av人在线观看导航| 国产1区2区在线| 成人久久一区| 成人xxxxx| 51xtv成人影院| 日韩av在线导航| 亚洲欧美综合自拍| 亚洲国产精品99久久久久久久久| www.com黄色片| 在线精品视频在线观看高清| 亚洲在线视频福利| 国产色播av在线| 国产一区二区日韩精品欧美精品| 中文字幕av网站| 亚洲欧美日韩电影| 国产精品手机在线观看| 免费在线播放第一区高清av| 亚洲国产午夜伦理片大全在线观看网站| 日韩在线电影| 91精品国产成人www| 精品视频三区| 欧美一级欧美一级在线播放| 久久精品国产亚洲av无码娇色| 91免费精品国自产拍在线不卡| 亚洲第一中文av| 欧美在线日韩| 奇米视频888战线精品播放| 国产精品xxx| 国内精品一区二区三区四区| 撸视在线观看免费视频| 在线成人高清不卡| 欧美一区二区三区四| 国产精品美女久久久久久久久久久 | 国产精品粉嫩| 免费av在线一区| 精品美女视频在线观看免费软件| 欧美精品丝袜中出| 草久视频在线观看| 亚洲另类在线视频| 成年人免费观看视频网站| 国产伦理精品不卡| 国产a级片免费观看| 欧美三级网页| 亚洲国产欧美日韩| 日韩理论电影中文字幕| 成人欧美一区二区三区黑人| 国产免费不卡| 午夜精品美女自拍福到在线| 日韩在线资源| 亚洲人成77777在线观看网| 亚洲成人777777| 欧美日韩一区二区三区不卡| 成人精品免费在线观看| 亚洲最大成人网4388xx| 夜夜春很很躁夜夜躁| av一二三不卡影片| 精品人妻一区二区乱码| 蜜桃精品视频在线| 黑森林福利视频导航| 国内精品久久久久久久97牛牛| 亚洲精品二区| 国内精品伊人久久久| 精品九九九九| 一区二区在线视频观看| 91精品在线看| 欧美激情啪啪| 国产精品热视频| 正在播放日韩精品| 538国产精品一区二区免费视频| 在线中文字幕电影| 久久天堂电影网| 最新97超碰在线| 在线电影av不卡网址| 日本韩国一区| 精品视频久久久| 香蕉人妻av久久久久天天| 精品精品欲导航| 精品久久人妻av中文字幕| 正在播放亚洲一区| 亚洲视频久久久| 欧美日韩精品三区| 91久久国产综合久久91| 色又黄又爽网站www久久| 亚洲 欧美 日韩 综合| 欧美日韩在线视频一区| 欧美三日本三级少妇99| 精品久久久久久久久久ntr影视 | 午夜在线播放视频欧美| 黄色一级在线视频| 亚洲影音先锋| 国产成人无码一二三区视频| 国产精品人人爽人人做我的可爱| 黄色片网址在线观看| 99热这里只有精品8| 日韩在线视频在线观看| 亚洲欧美日韩国产综合精品二区 | 国产乱一区二区| 国产乱国产乱老熟300部视频| 高清在线观看日韩| 日本免费福利视频| 国产偷v国产偷v亚洲高清| 精品熟妇无码av免费久久| 国产精品美女久久久久久久 | 91在线网址| 久久久精品2019中文字幕神马| 91国内在线| 97在线看福利| 一二区成人影院电影网| 国产精品视频区| 伊人久久噜噜噜躁狠狠躁| 国产精品一区二区三区免费| 首页亚洲中字| 中国一区二区三区| 国产精品红桃| 国产成人无码一二三区视频| 久久精品国产亚洲高清剧情介绍 | 亚洲天堂avav| 日韩欧美一二三区| 天堂中文在线官网| 中文字幕日韩av综合精品| 黄网站在线免费看| 91超碰caoporn97人人| 99久久er| 国产精品免费一区二区三区四区| 亚洲动漫在线观看| 一区二区三区欧美在线| 欧美涩涩网站| 国产真人无码作爱视频免费| 国产在线精品一区在线观看麻豆| 美女黄色一级视频| 国产精品久久久久久久蜜臀| 69av.com| 欧美在线啊v一区| 隣の若妻さん波多野结衣| 尤物tv国产一区| 国产va在线视频| 成人自拍性视频| 亚洲精华一区二区三区| 青青在线免费视频| 鲁大师成人一区二区三区| 日韩欧美中文视频| 久久久噜噜噜久噜久久综合| 欧美被狂躁喷白浆精品| 91福利视频久久久久| 高清乱码毛片入口| 色老头一区二区三区| 僵尸再翻生在线观看免费国语| 成人午夜一级二级三级| 国产精品美女久久久久久不卡| 热久久最新地址| 久久国产精品99精品国产| 亚洲黄色在线网站| 一区二区三区四区在线免费观看 | 国产精品系列在线播放| 特级西西www444人体聚色| 亚洲午夜三级在线| 国产毛片毛片毛片毛片| 亚洲系列中文字幕| 三妻四妾完整版在线观看电视剧 | 亚洲第九十九页| 少妇高潮久久77777| 欧美大胆性生话| 含羞草久久爱69一区| 影音先锋日韩在线| 亚洲国产成人va在线观看麻豆| 久久久噜噜噜久久人人看| 日本一区二区不卡在线| 日韩欧美一二三四区| 精品孕妇一区二区三区| 国产欧美精品日韩精品| 免费国产自久久久久三四区久久| 日韩精品免费一区| 国产乱码精品1区2区3区| 人人澡人人澡人人看| 欧美日韩国产美女| 波多野结衣在线影院| 国产精品美女视频网站| 欧美日中文字幕| 中文久久久久久| 国产欧美一区二区在线观看| 国产亚洲欧美日韩高清| 亚洲欧美日韩精品久久| 久久sese| 日本不卡一二三区| 日韩二区三区在线观看| 在哪里可以看毛片| 91黄色免费看| 3p在线观看| 国产自摸综合网| 亚洲有吗中文字幕| 成年人性生活视频| 亚洲综合精品久久| 污污视频在线免费看| 欧美又大又硬又粗bbbbb| 国产精品免费不| 中文字幕在线导航| 亚洲欧美综合在线精品| 国产成人三级在线播放| 欧美乱妇高清无乱码| 成人偷拍自拍| 国产又大又硬又粗| 国产嫩草影院久久久久| 亚洲最大成人av| 欧美成人在线免费视频| 亚洲精品国产九九九| 国产91xxx| 国产欧美一区二区三区在线看蜜臀| 中文字幕日韩三级| 欧美日韩不卡合集视频| 美女呻吟一区| wwwwxxxx日韩| 一区二区三区丝袜| 亚洲av成人精品一区二区三区在线播放 | 中文字幕在线成人| 欧美视频二区欧美影视| 青青青青草视频| 国产午夜精品一区二区| 国产色视频在线| 97色在线视频观看| 波多野结衣在线播放一区| av噜噜在线观看| 欧美日韩中文字幕在线| av国产在线观看| 粉嫩精品一区二区三区在线观看| 美女久久网站| 日本aⅴ在线观看| 国产午夜精品久久久| 天堂久久一区| 久久久999视频| 亚洲乱码国产乱码精品精的特点 | 日日夜夜精品视频免费观看| 亚洲va欧美va国产va天堂影院| 狠狠v欧美ⅴ日韩v亚洲v大胸| 91精品视频在线免费观看| 国产欧美在线| 国产激情无码一区二区三区| 日韩av影片在线观看| 亚洲精品伊人| 999精品网站| 亚洲电影第三页| 黄色成人在线观看| 欧美国产一二三区| 国产成人av网站|