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

0-1背包問題,你該了解這些!

開發(fā) 前端
有n件物品和一個最多能背重量為w 的背包。第i件物品的重量是weight[i],得到的價值是value[i] 。每件物品只能用一次,求解將哪些物品裝入背包里物品價值總和最大。

關(guān)于01背包問題,你該了解這些!

這周我們正式開始講解背包問題!

但說實話,背包九講對于小白來說確實不太友好,看起來還是有點費勁的,而且都是偽代碼理解起來也吃力。

對于面試的話,其實掌握01背包,和完全背包,就夠用了,最多可以再來一個多重背包。

如果這幾種背包,分不清,我這里畫了一個圖,如下:

分割等和子集1

至于背包九講中其他背包,面試幾乎不會問,都是競賽級別的了,leetcode上連多重背包的題目都沒有,所以題庫也告訴我們,01背包和完全背包就夠用了。

而完全背包又是也是01背包稍作變化而來,即:完全背包的物品數(shù)量是無限的。

所以背包問題的理論基礎(chǔ)重中之重是01背包,一定要理解透!

leetcode上沒有純01背包的問題,都是01背包應(yīng)用方面的題目,也就是需要轉(zhuǎn)化為01背包問題。

所以我先通過純01背包問題,把01背包原理講清楚,后續(xù)再講解leetcode題目的時候,重點就是講解如何轉(zhuǎn)化為01背包問題了。

之前可能有些錄友已經(jīng)可以熟練寫出背包了,但只要把這個文章仔細看完,相信你會意外收獲!

01 背包

有n件物品和一個最多能背重量為w 的背包。第i件物品的重量是weight[i],得到的價值是value[i] 。每件物品只能用一次,求解將哪些物品裝入背包里物品價值總和最大。

動態(tài)規(guī)劃-背包問題

這是標(biāo)準(zhǔn)的背包問題,以至于很多同學(xué)看了這個自然就會想到背包,甚至都不知道暴力的解法應(yīng)該怎么解了。

這樣其實是沒有從底向上去思考,而是習(xí)慣性想到了背包,那么暴力的解法應(yīng)該是怎么樣的呢?

每一件物品其實只有兩個狀態(tài),取或者不取,所以可以使用回溯法搜索出所有的情況,那么時間復(fù)雜度就是,這里的n表示物品數(shù)量。

所以暴力的解法是指數(shù)級別的時間復(fù)雜度。進而才需要動態(tài)規(guī)劃的解法來進行優(yōu)化!

在下面的講解中,我舉一個例子:

背包最大重量為4。

物品為:

  重量 價值
物品0 1 15
物品1 3 20
物品2 4 30

問背包能背的物品最大價值是多少?

以下講解和圖示中出現(xiàn)的數(shù)字都是以這個例子為例。

二維dp數(shù)組01背包

依然動規(guī)五部曲分析一波。

確定dp數(shù)組以及下標(biāo)的含義

對于背包問題,有一種寫法, 是使用二維數(shù)組,即dp[i][j] 表示從下標(biāo)為[0-i]的物品里任意取,放進容量為j的背包,價值總和最大是多少。

只看這個二維數(shù)組的定義,大家一定會有點懵,看下面這個圖:

動態(tài)規(guī)劃-背包問題1

要時刻記著這個dp數(shù)組的含義,下面的一些步驟都圍繞這dp數(shù)組的含義進行的,如果哪里看懵了,就來回顧一下i代表什么,j又代表什么。

確定遞推公式

再回顧一下dp[i][j]的含義:從下標(biāo)為[0-i]的物品里任意取,放進容量為j的背包,價值總和最大是多少。

那么可以有兩個方向推出來dp[i][j],

  • 不放物品i:由dp[i - 1][j]推出,即背包容量為j,里面不放物品i的最大價值,此時dp[i][j]就是dp[i - 1][j]。(其實就是當(dāng)物品i的重量大于背包j的重量時,物品i無法放進背包中,所以被背包內(nèi)的價值依然和前面相同。)
  • 放物品i:由dp[i - 1][j - weight[i]]推出,dp[i - 1][j - weight[i]] 為背包容量為j - weight[i]的時候不放物品i的最大價值,那么dp[i - 1][j - weight[i]] + value[i] (物品i的價值),就是背包放物品i得到的最大價值

所以遞歸公式:dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]);

dp數(shù)組如何初始化

關(guān)于初始化,一定要和dp數(shù)組的定義吻合,否則到遞推公式的時候就會越來越亂。

首先從dp[i][j]的定義出發(fā),如果背包容量j為0的話,即dp[i][0],無論是選取哪些物品,背包價值總和一定為0。如圖:

動態(tài)規(guī)劃-背包問題2

在看其他情況。

狀態(tài)轉(zhuǎn)移方程 dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]); 可以看出i 是由 i-1 推導(dǎo)出來,那么i為0的時候就一定要初始化。

dp[0][j],即:i為0,存放編號0的物品的時候,各個容量的背包所能存放的最大價值。

那么很明顯當(dāng) j < weight[0]的時候,dp[0][j] 應(yīng)該是 0,因為背包容量比編號0的物品重量還小。

當(dāng)j >= weight[0]時,dp[0][j] 應(yīng)該是value[0],因為背包容量放足夠放編號0物品。

代碼初始化如下:

  1. for (int j = 0 ; j < weight[0]; j++) {  // 當(dāng)然這一步,如果把dp數(shù)組預(yù)先初始化為0了,這一步就可以省略,但很多同學(xué)應(yīng)該沒有想清楚這一點。 
  2.     dp[0][j] = 0; 
  3. // 正序遍歷 
  4. for (int j = weight[0]; j <= bagweight; j++) { 
  5.     dp[0][j] = value[0]; 

此時dp數(shù)組初始化情況如圖所示:

動態(tài)規(guī)劃-背包問題7

dp[0][j] 和 dp[i][0] 都已經(jīng)初始化了,那么其他下標(biāo)應(yīng)該初始化多少呢?

其實從遞歸公式:dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]); 可以看出dp[i][j] 是由左上方數(shù)值推導(dǎo)出來了,那么 其他下標(biāo)初始為什么數(shù)值都可以,因為都會被覆蓋。

初始-1,初始-2,初始100,都可以!

但只不過一開始就統(tǒng)一把dp數(shù)組統(tǒng)一初始為0,更方便一些。

如圖:

動態(tài)規(guī)劃-背包問題10

最后初始化代碼如下:

  1. // 初始化 dp 
  2. vector<vector<int>> dp(weight.size(), vector<int>(bagweight + 1, 0)); 
  3. for (int j = weight[0]; j <= bagweight; j++) { 
  4.     dp[0][j] = value[0]; 

費了這么大的功夫,才把如何初始化講清楚,相信不少同學(xué)平時初始化dp數(shù)組是憑感覺來的,但有時候感覺是不靠譜的。

確定遍歷順序

在如下圖中,可以看出,有兩個遍歷的維度:物品與背包重量

動態(tài)規(guī)劃-背包問題3

那么問題來了,先遍歷 物品還是先遍歷背包重量呢?

其實都可以!!但是先遍歷物品更好理解。

那么我先給出先遍歷物品,然后遍歷背包重量的代碼。

  1. // weight數(shù)組的大小 就是物品個數(shù) 
  2. for(int i = 1; i < weight.size(); i++) { // 遍歷物品 
  3.     for(int j = 0; j <= bagweight; j++) { // 遍歷背包容量 
  4.         if (j < weight[i]) dp[i][j] = dp[i - 1][j]; 
  5.         else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]); 
  6.  
  7.     } 

先遍歷背包,再遍歷物品,也是可以的!(注意我這里使用的二維dp數(shù)組)

例如這樣:

  1. // weight數(shù)組的大小 就是物品個數(shù) 
  2. for(int j = 0; j <= bagweight; j++) { // 遍歷背包容量 
  3.     for(int i = 1; i < weight.size(); i++) { // 遍歷物品 
  4.         if (j < weight[i]) dp[i][j] = dp[i - 1][j]; 
  5.         else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]); 
  6.     } 

為什么也是可以的呢?

要理解遞歸的本質(zhì)和遞推的方向。

dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]); 遞歸公式中可以看出dp[i][j]是靠dp[i-1][j]和dp[i - 1][j - weight[i]]推導(dǎo)出來的。

dp[i-1][j]和dp[i - 1][j - weight[i]] 都在dp[i][j]的左上角方向(包括正上方向),那么先遍歷物品,再遍歷背包的過程如圖所示:

動態(tài)規(guī)劃-背包問題5

再來看看先遍歷背包,再遍歷物品呢,如圖:

動態(tài)規(guī)劃-背包問題6

大家可以看出,雖然兩個for循環(huán)遍歷的次序不同,但是dp[i][j]所需要的數(shù)據(jù)就是左上角,根本不影響dp[i][j]公式的推導(dǎo)!

但先遍歷物品再遍歷背包這個順序更好理解。

其實背包問題里,兩個for循環(huán)的先后循序是非常有講究的,理解遍歷順序其實比理解推導(dǎo)公式難多了。

舉例推導(dǎo)dp數(shù)組

來看一下對應(yīng)的dp數(shù)組的數(shù)值,如圖:

動態(tài)規(guī)劃-背包問題4

最終結(jié)果就是dp[2][4]。

建議大家此時自己在紙上推導(dǎo)一遍,看看dp數(shù)組里每一個數(shù)值是不是這樣的。

做動態(tài)規(guī)劃的題目,最好的過程就是自己在紙上舉一個例子把對應(yīng)的dp數(shù)組的數(shù)值推導(dǎo)一下,然后在動手寫代碼!

很多同學(xué)做dp題目,遇到各種問題,然后憑感覺東改改西改改,怎么改都不對,或者稀里糊涂就改過了。

主要就是自己沒有動手推導(dǎo)一下dp數(shù)組的演變過程,如果推導(dǎo)明白了,代碼寫出來就算有問題,只要把dp數(shù)組打印出來,對比一下和自己推導(dǎo)的有什么差異,很快就可以發(fā)現(xiàn)問題了。

完整c++測試代碼

  1. void test_2_wei_bag_problem1() { 
  2.     vector<int> weight = {1, 3, 4}; 
  3.     vector<int> value = {15, 20, 30}; 
  4.     int bagweight = 4; 
  5.  
  6.     // 二維數(shù)組 
  7.     vector<vector<int>> dp(weight.size(), vector<int>(bagweight + 1, 0)); 
  8.  
  9.     // 初始化 
  10.     for (int j = weight[0]; j <= bagweight; j++) { 
  11.         dp[0][j] = value[0]; 
  12.     } 
  13.  
  14.     // weight數(shù)組的大小 就是物品個數(shù) 
  15.     for(int i = 1; i < weight.size(); i++) { // 遍歷物品 
  16.         for(int j = 0; j <= bagweight; j++) { // 遍歷背包容量 
  17.             if (j < weight[i]) dp[i][j] = dp[i - 1][j]; 
  18.             else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]); 
  19.  
  20.         } 
  21.     } 
  22.  
  23.     cout << dp[weight.size() - 1][bagweight] << endl; 
  24.  
  25. int main() { 
  26.     test_2_wei_bag_problem1(); 

總結(jié)

講了這么多才剛剛把二維dp的01背包講完,這里大家其實可以發(fā)現(xiàn)最簡單的是推導(dǎo)公式了,推導(dǎo)公式估計看一遍就記下來了,但難就難在如何初始化和遍歷順序上。

可能有的同學(xué)并沒有注意到初始化 和 遍歷順序的重要性,我們后面做力扣上背包面試題目的時候,大家就會感受出來了。

本文轉(zhuǎn)載自微信公眾號「代碼隨想錄」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系代碼隨想錄公眾號。

 

責(zé)任編輯:武曉燕 來源: 代碼隨想錄
相關(guān)推薦

2021-01-19 05:46:45

背包數(shù)組容量

2021-04-13 07:58:38

背包代碼模式

2021-02-09 09:55:24

動態(tài)規(guī)劃

2021-01-04 08:37:53

動態(tài)規(guī)劃DP

2018-10-15 12:42:21

2021-07-13 14:03:24

二叉樹滿二叉樹完全二叉樹

2021-04-27 07:52:18

跳槽數(shù)據(jù)分析

2021-03-29 09:37:17

SpringBoot常用注解Spring Boot

2021-05-18 08:02:40

面試面試問題職業(yè)規(guī)劃

2023-06-26 19:25:18

效率消息中心業(yè)務(wù)線

2020-10-29 10:26:28

DevOps軟件自動化

2020-04-03 18:43:21

大數(shù)據(jù)Hadoop數(shù)據(jù)

2021-05-11 07:39:58

跳槽談薪工作

2017-06-14 15:07:58

機房管理服務(wù)器

2022-12-23 08:03:45

西瓜業(yè)務(wù)SEO前端

2023-12-07 08:13:58

Java開發(fā)

2021-01-07 05:40:13

BLE模塊Android

2017-01-09 16:40:07

React NatiAndroid 開發(fā)

2010-08-27 15:24:39

機房監(jiān)控

2011-05-10 10:56:29

DBA面試
點贊
收藏

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

www.久久久久| 亚洲国产精品视频| 国产热re99久久6国产精品| 亚洲女人久久久| 欧美不卡在线观看| 亚洲18女电影在线观看| 日韩精品另类天天更新| 国产又爽又黄免费软件| 亚洲人成免费| 在线视频免费一区二区| 成人做爰69片免费| 高清亚洲高清| 第一福利永久视频精品| 国产成人精品免费看在线播放| 天天干视频在线观看| 老司机一区二区| 国内精品久久久久伊人av | 成人av在线资源网站| 国产mv免费观看入口亚洲| 精品无码久久久久成人漫画| 中文字幕亚洲影视| 精品国产区一区| 一区二区三区网址| 欧美a级在线观看| 国产精品国产三级国产三级人妇| 国产青春久久久国产毛片| 亚洲一级视频在线观看| 亚洲欧美卡通另类91av| 欧美老女人性生活| 波兰性xxxxx极品hd| 校花撩起jk露出白色内裤国产精品| 777午夜精品视频在线播放| 国产l精品国产亚洲区久久| 羞羞视频在线免费国产| 亚洲国产精品二十页| 亚洲精品中文字幕有码专区| 国产成人精品亚洲精品| 日韩成人高清视频| 欧美xxx在线观看| 色综合伊人色综合网站| 30一40一50老女人毛片| 久久悠悠精品综合网| 日韩欧美一级二级三级久久久| 波多野结衣xxxx| 欧美成人精品一区二区男人小说| 精品国产电影一区| 精品视频在线观看一区| 激情在线视频播放| 一二三区精品视频| 国产专区在线视频| 在线黄色网页| 亚洲免费av高清| 99re8这里只有精品| 久久亚洲天堂| 一区在线中文字幕| 自拍偷拍99| 日本综合在线| 亚洲女同ⅹxx女同tv| 麻豆md0077饥渴少妇| 老司机99精品99| 亚洲欧美日韩小说| 99re6这里有精品热视频| 麻豆网在线观看| 亚洲精品欧美激情| 91网站在线观看免费| 国产黄色在线网站| 亚洲欧洲日产国产综合网| 中文字幕一区二区三区5566| 天堂а√在线资源在线| 成人免费一区二区三区视频| 伊人久久99| 性欧美高清come| 午夜久久久影院| 农村妇女精品一二区| 日本.亚洲电影| 欧美久久久一区| 4438x全国最大成人| 1769国产精品视频| 国产丝袜一区二区三区免费视频| 五月天精品视频| 日韩电影免费网址| 欧美激情影音先锋| 免费的毛片视频| 国产精品酒店视频| 亚洲人成网站77777在线观看| 亚洲午夜精品久久久久久久久久久久 | 六月婷婷久久| 999国产在线视频| 亚洲韩国一区二区三区| 91淫黄看大片| 亚洲综合影院| 一区二区三区回区在观看免费视频| 国产wwwwxxxx| 亚洲人成毛片在线播放女女| 国产精品一区二区三区久久 | 成人视屏在线观看| 欧美精品777| 国产成人av无码精品| 欧美日韩水蜜桃| 欧美激情国产日韩精品一区18| 国产午夜精品久久久久| 国产精品影音先锋| 日本亚洲自拍| 精精国产xxxx视频在线中文版| 91久久精品一区二区| 中文字幕55页| 欧州一区二区| 91精品国产一区| 国产精品无码免费播放| www一区二区| 成人av在线播放观看| 日本.亚洲电影| 亚洲精品大尺度| www.av成人| 日韩高清不卡在线| 精品国产一区二区三区麻豆免费观看完整版 | 色小说视频一区| 日韩精品在线不卡| 国产一区二区三区免费播放| 青青草久久网络| av剧情在线观看| 日韩一区二区三区免费看| 日韩人妻无码精品综合区| 99re6在线精品视频免费播放| 欧美亚洲高清| 欧美精品一本久久男人的天堂| 亚洲免费视频二区| 久久综合久久99| 亚洲人成无码网站久久99热国产| 91精品麻豆| 日韩在线精品一区| 国产精品第6页| 久久久精品天堂| 男女激情无遮挡| 国产精品自在| 欧美激情视频一区二区三区不卡| 91国在线视频| 国产精品乱人伦中文| 午夜欧美福利视频| 最新亚洲精品| 青青久久av北条麻妃海外网| 天天操天天射天天舔| 中文字幕中文字幕一区二区| 欧美黄色性生活| 欧美手机在线| 国产一区二区香蕉| 精品欧美色视频网站在线观看| 欧美中文字幕一区| 精品熟妇无码av免费久久| 日本不卡高清视频| 亚洲成人自拍| 欧美成人福利| 久久精品国产免费观看| 国产露脸国语对白在线| 亚洲人成在线播放网站岛国 | 日韩高清在线| 亚洲视频在线观看| 成人黄色三级视频| 国产精品高潮呻吟| 三级黄色片免费看| 欧美黄免费看| 超碰97在线播放| 热色播在线视频| 亚洲一区av在线播放| 亚洲视屏在线观看| 国产精品美女久久久久久2018| 午夜久久福利视频| 中文字幕一区二区三区久久网站| av一区和二区| 成人美女黄网站| 中文字幕国产精品| 999国产精品视频免费| 亚洲五码中文字幕| 玖玖爱在线观看| 久久超碰97中文字幕| 美女999久久久精品视频 | 交100部在线观看| 精品无人区乱码1区2区3区在线| 欧产日产国产69| 国产精品久久久久久久久免费樱桃 | 翔田千里亚洲一二三区| 图片一区二区| 午夜免费日韩视频| 粉嫩av一区| 欧美大片在线观看一区| 精品在线播放视频| 国产精品你懂的在线| 挪威xxxx性hd极品| 奇米影视一区二区三区| www.xxx麻豆| 国产一区二区三区电影在线观看| 丝袜美腿高跟呻吟高潮一区| 人偷久久久久久久偷女厕| 色999久久久精品人人澡69| 欧美精品18videosex性欧美| 国产在线一二三| 日韩欧美一二三区| 天天干天天操天天操| 1区2区3区国产精品| 91av在线免费| 久久99精品久久久久久动态图| 中文字幕无码精品亚洲资源网久久| 激情婷婷综合| 国产伦一区二区三区色一情| 成人mm视频在线观看| 久久久亚洲精选| 毛片在线视频| 亚洲网址你懂得| 欧美自拍偷拍一区二区| 91精品福利在线一区二区三区 | 欧美午夜免费| 99久久人爽人人添人人澡 | www.日韩.com| 日产精品久久久久久久性色| 日韩欧美黄色影院| 亚洲影院一区二区三区| 黑人巨大精品欧美一区二区一视频 | 男女视频在线看| 一区二区三区成人精品| 400部精品国偷自产在线观看| 九九久久婷婷| 国内精品国语自产拍在线观看| 国产麻豆一区二区三区| 国产欧美日韩视频| 欧美freesex| 1769国产精品| 97天天综合网| 欧美日韩不卡合集视频| 国产不卡在线| 亚洲美女免费精品视频在线观看| 成人1区2区3区| 欧美区视频在线观看| 懂色av中文字幕| 欧美三级免费观看| 日韩成人高清视频| 亚洲国产一二三| 欧美色图亚洲天堂| 亚洲婷婷在线视频| 日韩高清dvd碟片| 国产精品的网站| 中文字幕91视频| 国产精品毛片高清在线完整版| 国产精品成人在线视频| 国产精品网站在线观看| 内射毛片内射国产夫妻| 国产欧美日韩卡一| 国产欧美一区二区三区在线观看视频| 久久综合狠狠综合久久综合88 | 99视频在线免费| 久久青草久久| 美女网站免费观看视频| 久久一区欧美| 黑人粗进入欧美aaaaa| 日韩电影在线观看网站| 无码人妻精品一区二区三区66| 日韩精品福利网| 精品久久久久久中文字幕2017| 美女性感视频久久| www.精品在线| 国产伦精品一区二区三区免费 | 日韩一区二区三区精品| 99久久综合狠狠综合久久止| 一区中文字幕电影| 激情久久av| 国产色一区二区三区| 99精品热6080yy久久| 久久成人免费观看| 久久激情网站| 色一情一区二区| 国产麻豆视频精品| 中文字幕一区二区三区乱码不卡| 风间由美性色一区二区三区| 少妇光屁股影院| 午夜久久影院| 国产性猛交xxxx免费看久久| 亚洲欧美日本在线观看| 国产亚洲精品91在线| 国产在线观看免费麻豆| 久久久久国色av免费观看性色| 黄色在线观看www| 国产精品久久av| 亚洲一区二区三区四区电影| 欧美激情视频一区二区三区| 91亚洲国产成人久久精品| 久久手机在线视频| 日一区二区三区| 波多野结衣三级视频| 久久视频一区二区| 久久精品一区二区三区四区五区 | av日韩一区二区三区| 葵司免费一区二区三区四区五区| 99日在线视频| 久久综合九色综合欧美98| 成人三级视频在线观看| 午夜精品久久久久久久99水蜜桃 | 91九色porn在线资源| 国产成人精品日本亚洲专区61| 91丨精品丨国产| 欧美日韩在线播放一区二区| 欧美aa国产视频| 国产熟人av一二三区| 成人av网站在线| 精品一区二区在线观看视频| 天天射综合影视| 国产精选久久久| 亚洲欧洲日本专区| 国产蜜臀一区二区打屁股调教| 国产精品中文字幕久久久| 精品欧美午夜寂寞影院| 最新av在线免费观看| 久久综合五月| 香港三日本8a三级少妇三级99| 国产精品国模大尺度视频| 天堂а√在线中文在线新版| 日韩精品影音先锋| 麻豆传媒视频在线观看| 欧美最猛性xxxx| 久久人人爽人人爽人人片av不| 日韩一区二区精品视频| 17c丨国产丨精品视频| 中文字幕在线视频第一页| 成人午夜大片| 久久久国产午夜精品| 国自在线精品视频| 亚洲乱熟女一区二区| 色av吧综合网| 黑人巨大精品欧美一区二区桃花岛| 99久久精品免费看国产四区| 色综合狠狠操| 91插插插插插插插插| 久久精品亚洲精品国产欧美kt∨| 日韩xxx高潮hd| 国产亚洲人成a在线v网站| 97在线免费视频| 一区二区三区在线免费看| 黄黄视频在线观看| 久草在线在线精品观看| 国产探花视频在线播放| 日本道色综合久久| 国产在线一二三区| 国产成人精品一区二区在线| 天美av一区二区三区久久| 欧美二区在线视频| 成人av资源在线| 国产情侣自拍av| 日韩电影免费观看在线观看| 高清视频在线观看三级| 国产一级精品aaaaa看| 在线精品亚洲| 国产白嫩美女无套久久| 亚洲成av人片在线| 偷拍25位美女撒尿视频在线观看| 91国产中文字幕| 思热99re视热频这里只精品| 国产极品粉嫩福利姬萌白酱| 91麻豆swag| 国产成人精品亚洲| 久久精品中文字幕电影| 国产精品成人**免费视频| 青青在线视频免费观看| av欧美精品.com| 极品国产91在线网站| 中文字幕av一区中文字幕天堂 | 欧洲亚洲女同hd| 国产一区日韩| 中文字幕在线观看日| 一区二区久久久| 神马午夜精品95| 国产精品扒开腿做爽爽爽的视频| 色88久久久久高潮综合影院| 在线播放av中文字幕| 夜夜精品浪潮av一区二区三区| 粉嫩小泬无遮挡久久久久久| 2021国产精品视频| av在线网页| 欧美一区二区三区电影| 午夜在线视频播放| 97视频中文字幕| 国产精品三上| 老头老太做爰xxx视频| 欧美日韩成人一区| 国模私拍视频在线播放| 欧美一区国产一区| 国产乱码精品一品二品| 日本天堂网在线观看| 一本色道久久综合狠狠躁篇的优点| 亚洲18在线| 浮妇高潮喷白浆视频| 自拍偷拍亚洲综合| 四虎精品成人影院观看地址| 国产欧美 在线欧美| 亚洲一级黄色| 97精品在线播放| 日韩国产欧美区| 亚洲91在线| 久久久久久久久久久久久国产精品| 中文字幕一区视频| 天堂资源最新在线| 91麻豆蜜桃| 青青青伊人色综合久久|