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

淺談慢速的二次算法與快速的 hashmap

開發(fā) 后端 算法
我們聊到了二次時(shí)間與線性時(shí)間算法的話題,我認(rèn)為在這里寫這篇文章會(huì)很有趣,因?yàn)楸苊舛螘r(shí)間算法不僅在面試中很重要——有時(shí)在現(xiàn)實(shí)生活中了解一下也是很好的!后面我會(huì)快速解釋一下什么是“二次時(shí)間算法” :)

[[424110]]

大家好!昨天我與一位朋友聊天,他正在準(zhǔn)備編程面試,并試圖學(xué)習(xí)一些算法基礎(chǔ)知識(shí)。

我們聊到了二次時(shí)間quadratic-time線性時(shí)間linear-time算法的話題,我認(rèn)為在這里寫這篇文章會(huì)很有趣,因?yàn)楸苊舛螘r(shí)間算法不僅在面試中很重要——有時(shí)在現(xiàn)實(shí)生活中了解一下也是很好的!后面我會(huì)快速解釋一下什么是“二次時(shí)間算法” :)

以下是我們將要討論的 3 件事:

  1. 二次時(shí)間函數(shù)比線性時(shí)間函數(shù)慢得非常非常多
  2. 有時(shí)可以通過使用 hashmap 把二次算法變成線性算法
  3. 這是因?yàn)?hashmap 查找非常快(即時(shí)查詢!)

我會(huì)盡量避免使用數(shù)學(xué)術(shù)語,重點(diǎn)關(guān)注真實(shí)的代碼示例以及它們到底有多快/多慢。

目標(biāo)問題:取兩個(gè)列表的交集

我們來討論一個(gè)簡單的面試式問題:獲取 2 個(gè)數(shù)字列表的交集。 例如,intersect([1,2,3], [2,4,5]) 應(yīng)該返回 [2]

這個(gè)問題也是有些現(xiàn)實(shí)應(yīng)用的——你可以假設(shè)有一個(gè)真實(shí)程序,其需求正是取兩個(gè) ID 列表的交集。

“顯而易見”的解決方案:

我們來寫一些獲取 2 個(gè)列表交集的代碼。下面是一個(gè)實(shí)現(xiàn)此需求的程序,命名為 quadratic.py

  1. import sys
  2.  
  3. # 實(shí)際運(yùn)行的代碼
  4. def intersection(list1, list2):
  5. result = []
  6. for x in list1:
  7. for y in list2:
  8. if x == y:
  9. result.append(y)
  10. return result
  11.  
  12. # 一些樣板,便于我們從命令行運(yùn)行程序,處理不同大小的列表
  13. def run(n):
  14. # 定義兩個(gè)有 n+1 個(gè)元素的列表
  15. list1 = list(range(3, n)) + [2]
  16. list2 = list(range(n+1, 2*n)) + [2]
  17. # 取其交集并輸出結(jié)果
  18. print(list(intersection(list1, list2)))
  19.  
  20. # 使用第一個(gè)命令行參數(shù)作為輸入,運(yùn)行程序
  21. run(int(sys.argv[1]))

程序名為 quadratic.py(LCTT 譯注:“quadratic”意為“二次方的”)的原因是:如果 list1 和 list2 的大小為 n,那么內(nèi)層循環(huán)(if x == y)會(huì)運(yùn)行 n^2 次。在數(shù)學(xué)中,像 x^2 這樣的函數(shù)就稱為“二次”函數(shù)。

quadratic.py 有多慢?

用一些不同長度的列表來運(yùn)行這個(gè)程序,兩個(gè)列表的交集總是相同的:[2]

  1. $ time python3 quadratic.py 10
  2. [2]
  3.  
  4. real 0m0.037s
  5. $ time python3 quadratic.py 100
  6. [2]
  7.  
  8. real 0m0.053s
  9. $ time python3 quadratic.py 1000
  10. [2]
  11.  
  12. real 0m0.051s
  13. $ time python3 quadratic.py 10000 # 10,000
  14. [2]
  15.  
  16. real 0m1.661s

到目前為止,一切都還不錯(cuò)——程序仍然只花費(fèi)不到 2 秒的時(shí)間。

然后運(yùn)行該程序處理兩個(gè)包含 100,000 個(gè)元素的列表,我不得不等待了很長時(shí)間。結(jié)果如下:

  1. $ time python3 quadratic.py 100000 # 100,000
  2. [2]
  3.  
  4. real 2m41.059s

這可以說相當(dāng)慢了!總共花費(fèi)了 160 秒,幾乎是在 10,000 個(gè)元素上運(yùn)行時(shí)(1.6 秒)的 100 倍。所以我們可以看到,在某個(gè)點(diǎn)之后,每次我們將列表擴(kuò)大 10 倍,程序運(yùn)行的時(shí)間就會(huì)增加大約 100 倍。

我沒有嘗試在 1,000,000 個(gè)元素上運(yùn)行這個(gè)程序,因?yàn)槲抑浪鼤?huì)花費(fèi)又 100 倍的時(shí)間——可能大約需要 3 個(gè)小時(shí)。我沒時(shí)間這樣做!

你現(xiàn)在大概明白了為什么二次時(shí)間算法會(huì)成為一個(gè)問題——即使是這個(gè)非常簡單的程序也會(huì)很快變得非常緩慢。

快速版:linear.py

好,接下來我們編寫一個(gè)快速版的程序。我先給你看看程序的樣子,然后再分析。

  1. import sys
  2.  
  3. # 實(shí)際執(zhí)行的算法
  4. def intersection(list1, list2):
  5. set1 = set(list1) # this is a hash set
  6. result = []
  7. for y in list2:
  8. if y in set1:
  9. result.append(y)
  10. return result
  11.  
  12. # 一些樣板,便于我們從命令行運(yùn)行程序,處理不同大小的列表
  13. def run(n):
  14. # 定義兩個(gè)有 n+1 個(gè)元素的列表
  15. list1 = range(3, n) + [2]
  16. list2 = range(n+1, 2*n) + [2]
  17. # 輸出交集結(jié)果
  18. print(intersection(list1, list2))
  19.  
  20. run(int(sys.argv[1]))

(這不是最慣用的 Python 使用方式,但我想在盡量避免使用太多 Python 思想的前提下編寫代碼,以便不了解 Python 的人能夠更容易理解)

這里我們做了兩件與慢速版程序不同的事:

  1. 將 list1 轉(zhuǎn)換成名為 set1 的 set 集合
  2. 只使用一個(gè) for 循環(huán)而不是兩個(gè)

看看 linear.py 程序有多快

在討論 為什么 這個(gè)程序快之前,我們先在一些大型列表上運(yùn)行該程序,以此證明它確實(shí)是很快的。此處演示該程序依次在大小為 10 到 10,000,000 的列表上運(yùn)行的過程。(請記住,我們上一個(gè)的程序在 100,000 個(gè)元素上運(yùn)行時(shí)開始變得非常非常慢)

  1. $ time python3 linear.py 100
  2. [2]
  3.  
  4. real 0m0.056s
  5. $ time python3 linear.py 1000
  6. [2]
  7.  
  8. real 0m0.036s
  9. $ time python3 linear.py 10000 # 10,000
  10. [2]
  11.  
  12. real 0m0.028s
  13. $ time python3 linear.py 100000 # 100,000
  14. [2]
  15.  
  16. real 0m0.048s <-- quadratic.py took 2 minutes in this case! we're doing it in 0.04 seconds now!!! so fast!
  17. $ time python3 linear.py 1000000 # 1,000,000
  18. [2]
  19.  
  20. real 0m0.178s
  21. $ time python3 linear.py 10000000 # 10,000,000
  22. [2]
  23.  
  24. real 0m1.560s

在極大型列表上運(yùn)行 linear.py

如果我們試著在一個(gè)非常非常大的列表(100 億 / 10,000,000,000 個(gè)元素)上運(yùn)行它,那么實(shí)際上會(huì)遇到另一個(gè)問題:它足夠  了(該列表僅比花費(fèi) 4.2 秒的列表大 100 倍,因此我們大概應(yīng)該能在不超過 420 秒的時(shí)間內(nèi)完成),但我的計(jì)算機(jī)沒有足夠的內(nèi)存來存儲(chǔ)列表的所有元素,因此程序在運(yùn)行結(jié)束之前崩潰了。

  1. $ time python3 linear.py 10000000000
  2. Traceback (most recent call last):
  3. File "/home/bork/work/homepage/linear.py", line 18, in <module>
  4. run(int(sys.argv[1]))
  5. File "/home/bork/work/homepage/linear.py", line 13, in run
  6. list1 = [1] * n + [2]
  7. MemoryError
  8.  
  9. real 0m0.090s
  10. user 0m0.034s
  11. sys 0m0.018s

不過本文不討論內(nèi)存使用,所以我們可以忽略這個(gè)問題。

那么,為什么 linear.py 很快呢?

現(xiàn)在我將試著解釋為什么 linear.py 很快。

再看一下我們的代碼:

  1. def intersection(list1, list2):
  2. set1 = set(list1) # this is a hash set
  3. result = []
  4. for y in list2:
  5. if y in set1:
  6. result.append(y)
  7. return result

假設(shè) list1 和 list2 都是大約 10,000,000 個(gè)不同元素的列表,這樣的元素?cái)?shù)量可以說是很大了!

那么為什么它還能夠運(yùn)行得如此之快呢?因?yàn)?hashmap!!!

hashmap 查找是即時(shí)的(“常數(shù)級(jí)時(shí)間”)

我們看一下快速版程序中的 if 語句:

  1. if y in set1:
  2. result.append(y)

你可能會(huì)認(rèn)為如果 set1 包含 1000 萬個(gè)元素,那么這個(gè)查找——if y in set1 會(huì)比 set1 包含 1000 個(gè)元素時(shí)慢。但事實(shí)并非如此!無論 set1 有多大,所需時(shí)間基本是相同的(超級(jí)快)。

這是因?yàn)?nbsp;set1 是一個(gè)哈希集合,它是一種只有鍵沒有值的 hashmap(hashtable)結(jié)構(gòu)。

我不準(zhǔn)備在本文中解釋 為什么 hashmap 查找是即時(shí)的,但是神奇的 Vaidehi Joshi 的 basecs 系列中有關(guān)于 hash table 和 hash 函數(shù) 的解釋,其中討論了 hashmap 即時(shí)查找的原因。

不經(jīng)意的二次方:現(xiàn)實(shí)中的二次算法!

二次時(shí)間算法真的很慢,我們看到的的這個(gè)問題實(shí)際上在現(xiàn)實(shí)中也會(huì)遇到——Nelson Elhage 有一個(gè)很棒的博客,名為 不經(jīng)意的二次方,其中有關(guān)于不經(jīng)意以二次時(shí)間算法運(yùn)行代碼導(dǎo)致性能問題的故事。

二次時(shí)間算法可能會(huì)“偷襲”你

關(guān)于二次時(shí)間算法的奇怪之處在于,當(dāng)你在少量元素(如 1000)上運(yùn)行它們時(shí),它看起來并沒有那么糟糕!沒那么慢!但是如果你給它 1,000,000 個(gè)元素,它真的會(huì)花費(fèi)幾個(gè)小時(shí)去運(yùn)行。

所以我認(rèn)為它還是值得深入了解的,這樣你就可以避免無意中使用二次時(shí)間算法,特別是當(dāng)有一種簡單的方法來編寫線性時(shí)間算法(例如使用 hashmap)時(shí)。

總是讓我感到一絲神奇的 hashmap

hashmap 當(dāng)然不是魔法(你可以學(xué)習(xí)一下為什么 hashmap 查找是即時(shí)的!真的很酷!),但它總是讓人 感覺 有點(diǎn)神奇,每次我在程序中使用 hashmap 來加速,都會(huì)使我感到開心 :) 

責(zé)任編輯:龐桂玉 來源: Linux中國
相關(guān)推薦

2021-09-15 11:38:36

Hashmap二次算法列表

2020-10-29 15:13:55

數(shù)字科技金融行業(yè)互聯(lián)網(wǎng)

2015-09-01 15:12:45

JavaHashMap那點(diǎn)事

2017-03-24 21:26:26

代碼架構(gòu)Java

2011-08-05 12:36:01

2012-10-09 13:53:33

大型網(wǎng)站算法架構(gòu)

2010-05-19 13:05:39

思科認(rèn)證CCIE安博

2018-07-13 05:40:06

數(shù)據(jù)中心運(yùn)維可視化

2021-10-22 08:21:27

CSS 技巧文字二次加粗

2021-09-03 13:54:45

雙重勒索勒索軟件攻擊

2016-05-11 10:49:03

醫(yī)療SaaS

2012-11-27 10:45:13

路由器LANDHCP

2009-07-02 15:12:50

JSP Jdbc

2021-06-17 12:54:31

勒索軟件網(wǎng)絡(luò)攻擊贖金

2021-12-05 21:05:49

前端JSON API

2024-03-18 09:44:02

HashMap算法Java

2012-08-21 11:55:46

2022-10-20 10:38:11

無服務(wù)器RustC++

2019-04-30 13:09:30

蘋果微軟KOL

2022-03-11 22:52:29

調(diào)試版本編譯器
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

aaa国产一区| 色婷婷综合久久久久久| 中文字幕在线免费不卡| 亚洲最大福利视频网站| 欧美日韩在线视频免费| 久久97久久97精品免视看秋霞| 午夜国产不卡在线观看视频| 日韩欧美手机在线| 国产精品久久久久久免费| 欧美黄在线观看| 亚洲精品综合久久中文字幕| 亚洲精品久久久中文字幕| 性xxxxfjsxxxxx欧美| 99久久久国产精品免费蜜臀| 国产精品美女视频网站| 欧美日韩偷拍视频| 伊人成综合网yiren22| 欧美日韩一区三区四区| 国产片侵犯亲女视频播放| 国产黄在线播放| 粉嫩av一区二区三区| 国产精品av在线播放| 欧美黑人一级片| 国产一区二区三区四区大秀| 欧美成人一级视频| www.超碰com| 国产自产自拍视频在线观看| 国产精品国产自产拍高清av王其| 国产综合动作在线观看| 一区二区 亚洲| 国产亚洲精品bv在线观看| 久久精品国产2020观看福利| 伊人网伊人影院| 亚洲视频国产精品| 制服丝袜中文字幕一区| 亚洲五月天综合| 婷婷激情五月网| 一区二区小视频| 亚洲男女av一区二区| 亚洲区一区二区| 999精品免费视频| 五月亚洲婷婷| 在线综合+亚洲+欧美中文字幕| 日本一极黄色片| 精品丝袜在线| 亚洲成人自拍一区| 欧美性潮喷xxxxx免费视频看| 欧美精品日韩少妇| 中文字幕免费不卡| 美日韩免费视频| 亚洲aⅴ在线观看| 成人夜色视频网站在线观看| 不卡的av一区| aa视频在线免费观看| 激情亚洲综合在线| 成人久久久久爱| 91亚洲视频在线观看| 麻豆一区二区三| 国产精品视频久久久久| 日韩欧美一级大片| 日韩1区2区日韩1区2区| 国产成人在线播放| aaa在线视频| 天堂久久一区二区三区| 热久久这里只有精品| 黄色av一级片| 日韩电影在线一区二区三区| 国产精品久久久av久久久| 久久精品偷拍视频| 捆绑紧缚一区二区三区视频| 国产欧美日韩最新| 国产欧美日韩成人| 国产成人免费视| 国产精品一区二| 亚洲色图 校园春色| 91视频.com| 日韩高清国产精品| 一区二区三区视频在线观看视频| 自拍av一区二区三区| 蜜臀av性久久久久蜜臀av| 色爱综合区网| 欧美天堂在线观看| 高清一区二区视频| 日韩xxxx视频| 久久日韩视频| 一区二区不卡在线视频 午夜欧美不卡在 | 国产va在线视频| 色婷婷综合久色| 亚洲精品久久久中文字幕| 免费看日产一区二区三区| 欧美videossexotv100| aaaaaav| 日本不卡免费一区| 欧美精品成人在线| 久久久精品毛片| 国产在线一区观看| 国内精品二区| 成a人v在线播放| 亚洲宅男天堂在线观看无病毒| 逼特逼视频在线| 亚州精品国产| 亚洲国产精品中文| 亚洲精品电影院| 夜久久久久久| 亚洲aⅴ男人的天堂在线观看| 亚州男人的天堂| 1区2区3区国产精品| jizzjizz国产精品喷水| www.久久草.com| 亚洲美女喷白浆| 中文字幕人妻一区二| 国产精品日韩精品欧美精品| 国产欧美久久一区二区| 日本精品一二区| 国产精品久久二区二区| 免费看一级大黄情大片| 免费一级欧美在线大片| 亚洲人成在线观看网站高清| caoporn91| 毛片av中文字幕一区二区| 久久久久久久久久久久久久久久av| 欧洲不卡av| 日韩欧美亚洲范冰冰与中字| 亚洲精品乱码久久久久久9色| 精品一区二区三区中文字幕老牛| 欧美激情亚洲激情| 国产精品一级视频| 国产视频亚洲色图| 欧美成人三级在线视频| 久久午夜福利电影| 欧美一区在线观看视频| 色综合亚洲精品激情狠狠| 日韩免费不卡视频| 国产在线一区二区| 亚洲欧美日本国产有色| 日韩性xxx| 亚洲精品国精品久久99热 | 精品亚洲成人| 欧美一性一乱一交一视频| 国产极品久久久| 国产精品国产三级国产普通话蜜臀 | 免费不卡视频| 91久久精品午夜一区二区| 黄色在线免费播放| 欧美日韩视频一区二区三区| 91中文字幕在线| 成人午夜免费在线观看| 亚洲精品videosex极品| 日日干夜夜操s8| 成人在线电影在线观看视频| 国产精品99久久久久久白浆小说| 牛牛澡牛牛爽一区二区| 欧美性色xo影院| 全黄一级裸体片| 久久久人人人| 欧美一区二区三区成人久久片| 樱花草涩涩www在线播放| 亚洲国产婷婷香蕉久久久久久 | 五月婷婷在线观看| 欧美三级午夜理伦三级中视频| 日本成人午夜影院| 免费视频最近日韩| 一区二区三区av| 中文字幕日韩亚洲| 欧美大胆a视频| 亚洲免费国产视频| 婷婷夜色潮精品综合在线| 中文字幕在线免费看线人| 午夜亚洲性色视频| 欧美精品亚洲| 日韩三区四区| 欧美成人性生活| 日韩在线视频观看免费| 欧美日韩亚洲高清| 99久久精品免费视频| 男人操女人的视频在线观看欧美| 久久99国产精品成人| 国内精品一区二区| 久久青青视频| 久久精品精品电影网| 精品久久在线观看| 午夜精品福利久久久| 精品人妻无码一区| 国产美女一区二区| 精品国产一区三区| 成人久久久久| 亚洲最大福利网| 色黄视频在线观看| 中文字幕日韩高清| a级片在线免费看| 精品国产999| 国产又粗又猛又爽又黄的视频四季| 国产综合色在线视频区| 国产精品专区在线| 久久一区二区三区喷水| 国产精品国产亚洲精品看不卡15| 小h片在线观看| www.亚洲一区| 天堂中文在线资| 欧美片网站yy| 91美女免费看| 中文字幕综合网| 亚洲黄色在线网站| 国产伦精品一区二区三区免费| 久久久久免费看黄a片app| 四季av一区二区三区免费观看| 国产高清一区视频| 国产精品高潮久久| 97在线视频免费| 黄色网址在线免费观看| 亚洲欧美日韩天堂一区二区| 国产叼嘿视频在线观看| 91国偷自产一区二区开放时间| 东方av正在进入| 国产婷婷精品av在线| 成人在线视频免费播放| 韩日欧美一区二区三区| 少妇性l交大片| 亚洲精品乱码| av电影一区二区三区| 国产精品探花在线观看| 国产精品视频入口| 日韩一区二区三区四区五区| 欧美中在线观看| 好久没做在线观看| 久久久精品一区二区三区| 九色视频网站在线观看| 精品国产乱码久久久久久浪潮| 在线视频 中文字幕| 色婷婷香蕉在线一区二区| 久久精品国产av一区二区三区| 中文字幕一区二区三区色视频| 国产精品九九九| 神马久久久久久久久久| 日韩一区二区三区电影| 亚洲天堂中文在线| 欧美在线观看你懂的| 麻豆成人免费视频| 五月天一区二区| 国产乱码久久久久久| 一区二区三区色| 精品国产精品国产精品| 国产精品久久久久婷婷二区次| 国产高清一区二区三区四区| 2022国产精品视频| 美国黄色一级毛片| av男人天堂一区| bl动漫在线观看| 91在线精品秘密一区二区| a级一a一级在线观看| www..com久久爱| 特级西西人体wwwww| 99久久精品免费观看| 美女又爽又黄免费| 91一区二区三区在线播放| 欧美老熟妇乱大交xxxxx| 国产亚洲福利社区一区| 五月婷婷六月香| 亚洲欧美综合在线精品| 欧美成人777| 亚洲一区二区高清| 国产亚洲欧美精品久久久www| 亚洲国产wwwccc36天堂| 五月婷婷开心网| 色视频成人在线观看免| 中文字幕男人天堂| 欧美精品 日韩| 高h震动喷水双性1v1| 日韩成人久久久| 国产黄在线看| 久久视频中文字幕| 免费网站在线观看人| 96精品视频在线| 电影一区电影二区| 成人在线视频网| www.亚洲一二| 日本一区不卡| 欧美在线观看天堂一区二区三区| 国产欧美日韩小视频| 欧美综合国产| 日韩欧美亚洲另类| 国产99精品视频| 妺妺窝人体色WWW精品| 国产精品夫妻自拍| 久久久全国免费视频| 91国产丝袜在线播放| 国产女人18毛片水真多| 日韩av一区在线观看| 不卡在线视频| 欧美成人黄色小视频| 国产污视频在线播放| 91av中文字幕| 激情久久一区二区| 国产视频一区二区不卡| 国产精品日韩精品中文字幕| 欧美日韩中文字幕日韩欧美| 在线观看日本黄色| 最新日韩av在线| 国产情侣自拍av| 精品视频123区在线观看| 99免费在线视频| 亚洲天堂2020| 日韩精品亚洲人成在线观看| 97久久精品人人澡人人爽缅北| 日韩免费va| 亚洲综合在线做性| 精品久久影视| 亚洲精品天堂成人片av在线播放| 狠狠综合久久av一区二区老牛| 杨幂毛片午夜性生毛片| 国产精品1区2区| 国产二级一片内射视频播放 | 亚洲永久免费观看| 精品五月天堂| 自拍偷拍亚洲色图欧美| 9国产精品视频| 污污的视频免费观看| 久久久久久一二三区| 国产高潮流白浆| 欧美性猛交xxxxxx富婆| 黄色av一区二区三区| 丝袜亚洲另类欧美重口| 亚洲最大网站| 99国内精品久久久久久久软件| 国产亚洲一卡2卡3卡4卡新区 | 久久国产精品一区二区三区四区| 在线精品国产| 成人免费无码av| 高清av一区二区| 国产1区2区3区4区| 欧洲一区二区三区免费视频| 亚洲国产精品suv| 自拍视频国产精品| 欧美私密网站| 成人免费看片网址| 欧美第一精品| 精品视频免费在线播放| 顶级嫩模精品视频在线看| sm捆绑调教视频| 欧美日韩一区 二区 三区 久久精品| 天堂成人在线观看| 欧美黄色片免费观看| 51精品国产| 黄色污污在线观看| 国产乱子伦视频一区二区三区 | 性色av一区二区三区在线观看| 白嫩亚洲一区二区三区| 亚洲欧洲日韩综合二区| 久色成人在线| 国产又黄又粗视频| 在线观看国产日韩| 视频一区二区三区在线看免费看| 97国产精品视频| 风间由美一区二区av101| 成人免费播放器| 国产精品69毛片高清亚洲| 国模吧一区二区| 日本三级韩国三级欧美三级| 国产日韩欧美91| 一区二区蜜桃| 午夜一区二区视频| 欧美国产一区二区在线观看| 亚洲天堂男人av| 亚洲天堂色网站| 主播大秀视频在线观看一区二区| 免费影院在线观看一区| 日韩激情一二三区| 在线观看亚洲大片短视频| 在线中文字幕不卡| 日本黄色片在线观看| 国产日韩欧美视频| 91亚洲国产| 在线播放第一页| 亚洲va国产va欧美va观看| 天堂a√在线| 日本一区二区三区四区视频| 区一区二视频| 一起操在线视频| 亚洲欧洲一区二区在线播放| 国产sm主人调教女m视频| 九九热这里只有在线精品视| 欧美电影完整版在线观看| 国产h视频在线播放| 9色porny自拍视频一区二区| 国产中文字幕视频| 色狠狠久久aa北条麻妃| 91成人入口| 波多野结衣家庭教师在线播放| av日韩在线网站| 看黄色一级大片| 日韩中文字幕精品视频| 婷婷综合国产| 国产97在线 | 亚洲| 国产精品视频在线看| 国产99视频在线| 隔壁老王国产在线精品| 日韩电影在线视频| 久久久久中文字幕亚洲精品| 色中色一区二区| 91小视频xxxx网站在线|