久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

码农常用10种算法

發布時間:2023/12/31 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 码农常用10种算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

碼農常用10種算法

二分查找算法(非遞歸)

查看前面筆記:查找算法中的非遞歸二分查找

分治算法

分治算法介紹
分治法是一種很重要的算法。字面上的解釋是“分而治之”,就是把一個復雜的問題分成兩個或更多的相同或相似的子問題,再把子問題分成更小的子問題……直到最后子問題可以簡單的直接求解,原問題的解即子問題的解的合并。這個技巧是很多高效算法的基礎,如排序算法(快速排序,歸并排序),傅立葉變換(快速傅立葉變換)……

分治算法可以求解的一些經典問題

  • 二分搜索
  • 大整數乘法
  • 棋盤覆蓋
  • 合并排序
  • 快速排序
  • 線性時間選擇
  • 最接近點對問題
  • 循環賽日程表
  • 漢諾塔

分治算法的基本步驟

分治法在每一層遞歸上都有三個步驟:

  • 分解:將原問題分解為若干個規模較小,相互獨立,與原問題形式相同的子問題
  • 解決:若子問題規模較小而容易被解決則直接解,否則遞歸地解各個子問題
  • 合并:將各個子問題的解合并為原問題的解。
  • 分治(Divide-and-Conquer§)算法設計模式如下:

    說明:其中|P|表示問題P的規模;n0為一閾值,表示當問題P的規模不超過n0時,問題已容易直接解出,不必再繼續分解。ADHOC§是該分治法中的基本子算法,用于直接解小規模的問題P。因此,當P的規模不超過n0時直接用算法ADHOC§求解。算法MERGE(y1,y2,…,yk)是該分治法中的合并子算法,用于將P的子問題P1 ,P2 ,…,Pk的相應的解y1,y2,…,yk合并為P的解

    分治算法最佳實踐-漢諾塔

    漢諾塔的傳說
    漢諾塔:漢諾塔(又稱河內塔)問題是源于印度一個古老傳說的益智玩具。大梵天創造世界的時候做了三根金剛石柱子,在一根柱子中從下往上按照大小順序摞著64片黃金圓盤。大梵天命令婆羅門把圓盤從下面開始按大小順序重新擺放在另一根柱子上。并且規定,在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動一個圓盤。


    漢諾塔游戲的演示和思路分析:

    如果是有一個盤, A->C
    如果有 n >= 2 情況,則總是可以看做是兩個盤 1.最下邊的盤 2. 上面的所有盤

    • 先把 最上面的盤 A->B
    • 再把最下邊的盤 A->C
    • 最后把B塔的所有盤 從 B->C

    代碼實現

    package com.atguigu.dac;/*** @author ysxstart* @create 2022-04-24 13:18*/ public class HanoiTower {/*** 漢諾塔的移動的方法,使用分治算法** @param num 盤的個數* @param a 第一根柱子* @param b 第二根柱子* @param c 第三根柱子*/public static void hanoiTower(int num, char a, char b, char c) {//如果只有 1個盤if (num == 1) {System.out.println("第1個盤從" + a + "->" + c);} else {//如果有 num >= 2情況,則總是可以看做是兩個盤: 1.最下邊的一個盤 2. 上面的所有盤//1.先把最上面的所有盤 a->b, 移動過程會使用到 chanoiTower(num - 1, a, c, b);//2.把最下邊的盤 a->cSystem.out.println("第" + num + "個盤從" + a + "->" + c);//3.把 b塔的所有盤從 b->c , 移動過程使用到 a塔hanoiTower(num - 1, b, a, c);}}public static void main(String[] args) {hanoiTower(3, 'A', 'B', 'C');} }

    動態規劃算法

    動態規劃算法介紹

    • 動態規劃(Dynamic Programming)算法的核心思想是:將大問題劃分為小問題進行解決,從而一步步獲取最優解的處理算法
    • 動態規劃算法與分治算法類似,其基本思想也是將待求解問題分解成若干個子問題,先求解子問題,然后從這些子問題的解得到原問題的解。
    • 與分治法不同的是,適合于用動態規劃求解的問題,經分解得到子問題往往不是互相獨立的。 ( 即下一個子階段的求解是建立在上一個子階段的解的基礎上,進行進一步的求解 )
    • 動態規劃可以通過填表的方式來逐步推進,得到最優解.

    動態規劃算法最佳實踐-背包問題

    背包問題:有一個背包,容量為4磅 , 現有如下物品

  • 要求達到的目標為裝入的背包的總價值最大,并且重量不超出
  • 要求裝入的物品不能重復
  • 背包問題主要是指一個給定容量的背包、若干具有一定價值和重量的物品,如何選擇物品放入背包使物品的價值最大。其中又分01背包和完全背包(完全背包指的是:每種物品都有無限件可用)
    這里的問題屬于01背包,即每個物品最多放一個。而無限背包可以轉化為01背包。

    思路分析:

    算法的主要思想,利用動態規劃來解決。每次遍歷到的第i個物品,根據w[i]和val[i]來確定是否需要將該物品放入背包中。即對于給定的n個物品,設val[i]、w[i]分別為第i個物品的價值和重量,C為背包的容量。再令v[i][j]表示前i個物品中能夠裝入容量為j的背包中的最大價值。則有下面的結果:

  • v[i][0]=val[0][j]=0; //表示填入表第一行和第一列是0
  • 當w[i]> j 時:v[i][j]=v[i-1][j] //當準備加入新增的商品的容量大于當前背包的容量時,就直接使用上一個單元格的裝入策略
  • 當j>=w[i]時: v[i][j]=max{v[i-1][j], val[i]+v[i-1][j-w[i]]} //當準備加入的新增的商品的容量小于等于當前背包的容量,裝入的方式:
  • v[i-1][j]: 就是上一個單元格的裝入的最大值
  • val[i] : 表示當前商品的價值
  • v[i-1][j-w[i]] : 裝入i-1商品,到剩余空間j-w[i]的最大值。當j>=w[i]時: v[i][j]=max{v[i-1][j], val[i]+v[i-1][j-w[i]]}
  • 代碼實現:

    package com.atguigu.dynamicprogramming;/*** @author ysxstart* @create 2022-04-24 16:43*/ public class KnapsackProblem {public static void main(String[] args) {int[] w = {1, 4, 3}; //物品的重量int[] val = {1500, 3000, 2000}; //物品的價值int m = 4; //背包的容量int n = val.length; //物品的個數//創建二維數組//v[i][j] 表示在前 i個物品中能夠裝入容量為j的背包中的最大價值int[][] v = new int[n + 1][m + 1];//為了記錄放入商品的情況,定一個二維數組int[][] path = new int[n + 1][m + 1];//初始化第一行和第一列, 這里可以不去處理,因為默認就是0for (int i = 0; i < v.length; i++) {v[i][0] = 0; //將第一列設置為0}for (int i = 0; i < v[0].length; i++) {v[0][i] = 0; //將第一行設置0}//根據前面得到公式來動態規劃處理for (int i = 1; i < v.length; i++) {for (int j = 1; j < v[0].length; j++) {//公式if (w[i - 1] > j) { //因為 i是從1開始的,因此原來公式中的 w[i]修改成 w[i-1]v[i][j] = v[i - 1][j];} else { //背包容量大于等于當前商品的容量//因為 i從1開始的,因此公式需要調整成://v[i][j] = max{v[i-1][j], val[i] + v[i-1][j-w[i]]}//v[i][j] = Math.max(v[i-1][j], val[i-1]+v[i-1][j-w[i-1]]);//為了記錄商品存放到背包的情況,不能直接的使用上面的公式,需要使用if-else來體現公式if (v[i - 1][j] < val[i - 1] + v[i - 1][j - w[i - 1]]) {v[i][j] = val[i - 1] + v[i - 1][j - w[i - 1]];//把當前的情況記錄到pathpath[i][j] = 1;} else {v[i][j] = v[i - 1][j];}}}}//輸出一下 v看看目前的情況for (int i = 0; i < v.length; i++) {for (int j = 0; j < v[0].length; j++) {System.out.print(v[i][j] + " ");}System.out.println();}System.out.println();//輸出最后是哪些商品被放入,從后往前遍歷int i = path.length - 1; //行的最大下標int j = path[0].length - 1; //列的最大下標while (i > 0 && j > 0) { //從path的最后開始找if (path[i][j] == 1) {System.out.printf("第%d個商品放入到背包\n", i);j -= w[i - 1];}i--;}} }

    運行結果:

    KMP算法

    應用場景-字符串匹配問題

    字符串匹配問題:
    有一個字符串 str1= ““硅硅谷 尚硅谷你尚硅 尚硅谷你尚硅谷你尚硅你好””,和一個子串 str2=“尚硅谷你尚硅你”?,F在要判斷 str1 是否含有 str2, 如果存在,就返回第一次出現的位置, 如果沒有,則返回-1

    BF暴力匹配算法

    如果用暴力匹配的思路,并假設現在str1匹配到 i 位置,子串str2匹配到 j 位置,則有:

    • 如果當前字符匹配成功(即str1[i] == str2[j]),則i++,j++,繼續匹配下一個字符
    • 如果失配(即str1[i]! = str2[j]),令i = i - (j - 1),j = 0。相當于每次匹配失敗時,i 回溯,j 被置為0。
    • 用暴力方法解決的話就會有大量的回溯,每次只移動一位,若是不匹配,移動到下一位接著判斷,浪費了大量的時間。(不可行!)

    代碼實現:

    package com.atguigu.kmp;/*** @author ysxstart* @create 2022-04-24 23:03*/ public class ViolenceMatch {/*** 暴力匹配算法實現** @param str1 主串* @param str2 子串* @return 匹配到則返回索引,沒有匹配到則返回-1*/public static int violenceMatch(String str1, String str2) {char[] s1 = str1.toCharArray();char[] s2 = str2.toCharArray();int s1Len = s1.length;int s2Len = s2.length;int i = 0; // i索引指向s1int j = 0; // j索引指向s2while (i < s1Len && j < s2Len) {if (s1[i] == s2[j]) { //匹配oki++;j++;} else { //匹配 no ok!//主串回溯,重新匹配子串;i等于匹配ok的i的下一個索引;若程序剛開始就沒有匹配ok,則i每次加1繼續循環i = i - (j - 1);j = 0;}}if (j == s2Len) {return i - j;} else {return -1;}}public static void main(String[] args) {//測試暴力匹配算法String str1 = "硅硅谷 尚硅谷你尚硅 尚硅谷你尚硅谷你尚硅你好";String str2 = "尚硅谷你尚硅你";int index = violenceMatch(str1, str2);System.out.println("index = " + index);} }

    KMP算法最佳應用-字符串匹配問題

    字符串匹配問題::
    有一個字符串 str1= “BBC ABCDAB ABCDABCDABDE”,和一個子串 str2=“ABCDABD”
    現在要判斷 str1 是否含有 str2, 如果存在,就返回第一次出現的位置, 如果沒有,則返回-1
    要求:使用KMP算法完成判斷,不能使用簡單的暴力匹配算法.

    KMP算法思路圖解分析:
    舉例來說,有一個字符串 Str1 = “BBC ABCDAB ABCDABCDABDE”,判斷,里面是否包含另一個字符串 Str2 = “ABCDABD”?

  • 首先,用Str1的第一個字符和Str2的第一個字符去比較,不符合,關鍵詞向后移動一位
  • 重復第一步,還是不符合,再后移
  • 一直重復,直到Str1有一個字符與Str2的第一個字符符合為止
  • 接著比較字符串str1和搜索詞str2的下一個字符,還是符合。
  • 遇到Str1有一個字符與Str2對應的字符不符合。
  • 這時候,想到的是繼續遍歷Str1的下一個字符B,重復第1步。(其實是很不明智的,因為此時BCD已經比較過了,沒有必要再做重復的工作。一個基本事實是,當空格與D不匹配時,你其實知道前面六個字符是”ABCDAB”。KMP 算法的想法是,設法利用這個已知信息,不要把”搜索位置”移回已經比較過的位置,繼續把它向后移,這樣就提高了效率。)
  • 怎么做到把剛剛重復的步驟省略掉?可以對Str2計算出一張《部分匹配表》
  • 已知空格與D不匹配時,前面六個字符”ABCDAB”是匹配的。查表可知,最后一個匹配字符B對應的”部分匹配值”為2,因此按照下面的公式算出向后移動的位數:
    • 移動位數 = 已匹配的字符數 - 對應的部分匹配值
    • 因為 6 - 2 等于4,所以將搜索詞向后移動 4 位。
  • 因為空格與C不匹配,搜索詞還要繼續往后移。這時,已匹配的字符數為2(”AB”),對應的”部分匹配值”為0。所以,移動位數 = 2 - 0,結果為 2,于是將搜索詞向后移 2 位。
  • 因為空格與A不匹配,繼續后移一位。
  • 逐位比較,直到發現C與D不匹配。于是,移動位數 = 6 - 2,繼續將搜索詞向后移動 4 位。
  • 逐位比較,直到搜索詞的最后一位,發現完全匹配,于是搜索完成。如果還要繼續搜索(即找出全部匹配),移動位數 = 7 - 0,再將搜索詞向后移動 7 位,這里就不再重復了。
  • 《部分匹配表》的產生
    • 先介紹前綴,后綴是什么
    • “部分匹配值”就是”前綴”和”后綴”的最長的共有元素的長度。以”ABCDABD”為例,
    • -”A”的前綴和后綴都為空集,共有元素的長度為0;
    • -”AB”的前綴為[A],后綴為[B],共有元素的長度為0;
    • -”ABC”的前綴為[A, AB],后綴為[BC, C],共有元素的長度0;
    • -”ABCD”的前綴為[A, AB, ABC],后綴為[BCD, CD, D],共有元素的長度為0;
    • -”ABCDA”的前綴為[A, AB, ABC, ABCD],后綴為[BCDA, CDA, DA, A],共有元素為”A”,長度為1;
    • -”ABCDAB”的前綴為[A, AB, ABC, ABCD, ABCDA],后綴為[BCDAB, CDAB, DAB, AB, B],共有元素為”AB”,長度為2;
    • -”ABCDABD”的前綴為[A, AB, ABC, ABCD, ABCDA, ABCDAB],后綴為[BCDABD, CDABD, DABD, ABD, BD, D],共有元素的長度為0。
  • ”部分匹配”的實質是:有時候,字符串頭部和尾部會有重復。比如,”ABCDAB”之中有兩個”AB”,那么它的”部分匹配值”就是2(”AB”的長度)。搜索詞移動的時候,第一個”AB”向后移動 4 位(字符串長度-部分匹配值),就可以來到第二個”AB”的位置。
  • 到此KMP算法思想分析完畢!

    代碼實現:

    package com.atguigu.kmp;import java.util.Arrays;/*** @author ysxstart* @create 2022-04-25 13:10*/ public class KMPAlgorithm2 {/*** kmp算法實現** @param str1 主串* @param str2 子串* @param next 子串的部分匹配值表* @return 不返回-1表示找到*/public static int kmpSearch(String str1, String str2, int[] next) {for (int i = 0, j = 0; i < str1.length(); i++) {//需要處理 str1.charAt(i) != str2.charAt(j), 去調整j的大小//KMP算法核心點while (j > 0 && str1.charAt(i) != str2.charAt(j)) {j = next[j - 1]; //獲取需移動的位數}if (str1.charAt(i) == str2.charAt(j)) {j++;}if (j == str2.length()) {return i - (j - 1); //j要減1,因 j=str2.length}}return -1;}//生成部分匹配值表,dest搜索詞private static int[] kmpNext(String dest) {//next數組保存部分匹配值;索引表示字符,數組值表示部分匹配值int[] next = new int[dest.length()];//字符串長度為1,部分匹配值就是0next[0] = 0;for (int i = 1, j = 0; i < dest.length(); i++) {//當dest.charAt(i) != dest.charAt(j) ,需要從next[j-1]獲取新的jwhile (j > 0 && dest.charAt(i) != dest.charAt(j)) {// 1.第一次進入while循環時,j=2,i=6即'C'和'D'不同,則取子串ABC的前一個子串AB的部分匹配值,即0。// 2.j = 0; i =6 和j=0相比較,即'D'和'A',首尾不同。即ABCDABD串的前綴和后綴沒有公共元素,部分匹配值為0;next[6] = 0;j = next[j - 1];}//當dest.charAt(i) == dest.charAt(j)滿足時,部分匹配值就是 +1if (dest.charAt(i) == dest.charAt(j)) {j++;}next[i] = j;}return next;}public static void main(String[] args) {String str1 = "BBC ABCDAB ABCDABCDABDE";String str2 = "ABCDABD";int[] next = kmpNext(str2);System.out.println("搜索詞 " + str2 + " 的部分匹配表:" + Arrays.toString(next));int index = kmpSearch(str1, str2, next);System.out.println("找到的子串開始索引:" + index);} }

    運行結果:

    貪心算法

    貪心算法介紹

    • 貪婪算法(貪心算法)是指在對問題進行求解時,在每一步選擇中都采取最好或者最優(即最有利)的選擇,從而希望能夠導致結果是最好或者最優的算法
    • 貪婪算法所得到的結果不一定是最優的結果(有時候會是最優解),但是都是相對近似(接近)最優解的結果

    貪心算法最佳應用-集合覆蓋

    假設存在如下表的需要付費的廣播臺,以及廣播臺信號可以覆蓋的地區。 如何選擇最少的廣播臺,讓所有的地區都可以接收到信號!

    廣播臺覆蓋地區
    K1“北京”, “上?!? “天津”
    K2“廣州”, “北京”, “深圳”
    K3“成都”, “上?!? “杭州”
    K4“上?!? “天津”
    K5“杭州”, “大連”

    思路分析:
    如何找出覆蓋所有地區的廣播臺的集合呢,使用窮舉法實現,列出每個可能的廣播臺的集合,這被稱為冪集。假設總的有n個廣播臺,則廣播臺的組合總共有2? -1 個,假設每秒可以計算10個子集, 如圖:

    使用貪婪算法,效率高:
    目前并沒有算法可以快速計算得到準備的值, 使用貪婪算法,則可以得到非常接近的解,并且效率高。選擇策略上,因為需要覆蓋全部地區的最小集合:

  • 遍歷所有的廣播電臺, 找到一個覆蓋了最多未覆蓋的地區的電臺(此電臺可能包含一些已覆蓋的地區,但沒有關系)
  • 將這個電臺加入到一個集合中(比如ArrayList), 想辦法把該電臺覆蓋的地區在下次比較時去掉。
  • 重復第1步直到覆蓋了全部的地區
  • 代碼實現

    package com.atguigu.greedy;import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; import java.util.List;/*** @author ysxstart* @create 2022-04-25 22:41*/ public class GreedyAlgorithm2 {public static void main(String[] args) {//創建廣播電臺,放入到MapHashMap<String, HashSet<String>> broadcasts = new HashMap<>();//創建每個電臺對應的覆蓋的地區HashSet<String> hashSet1 = new HashSet<>();hashSet1.add("北京");hashSet1.add("上海");hashSet1.add("天津");HashSet<String> hashSet2 = new HashSet<>();hashSet2.add("廣州");hashSet2.add("北京");hashSet2.add("深圳");HashSet<String> hashSet3 = new HashSet<>();hashSet3.add("成都");hashSet3.add("上海");hashSet3.add("杭州");HashSet<String> hashSet4 = new HashSet<>();hashSet4.add("上海");hashSet4.add("天津");HashSet<String> hashSet5 = new HashSet<>();hashSet5.add("杭州");hashSet5.add("大連");//加入到map,將各個電臺放入到broadcastsbroadcasts.put("K1", hashSet1);broadcasts.put("K2", hashSet2);broadcasts.put("K3", hashSet3);broadcasts.put("K4", hashSet4);broadcasts.put("K5", hashSet5);//allAreas存放所有的地區,即未覆蓋的地區HashSet<String> allAreas = new HashSet<>();for (HashSet<String> value : broadcasts.values()) {allAreas.addAll(value);}List<String> selectList = greedy(broadcasts, allAreas);System.out.println("得到的選擇結果是:" + selectList);}public static List<String> greedy(HashMap<String, HashSet<String>> broadcasts, HashSet<String> allAreas) {//存放選擇的電臺集合ArrayList<String> selects = new ArrayList<>();/*臨時集合tempSet,存放遍歷過程中該電臺覆蓋的地區 和當前還沒有覆蓋的地區(allAreas)的交集;臨時集合maxTempSet,(上一個maxKey)maxKey和allAreas集合的交集,用于后面與當前的key和allAreas的交集的數量作比較*/HashSet<String> tempSet = new HashSet<>();HashSet<String> maxTempSet = new HashSet<>();/*定義maxKey,保存在一次遍歷過程中,能夠覆蓋最大 未覆蓋的地區對應的電臺的key如果maxKey不為null,則會加入到selects*/String maxKey = null;//開始循環,如果allAreas不為0,則表示還沒有覆蓋完所有的地區while (allAreas.size() > 0) {//每進行一次while,需要重置maxKeymaxKey = null;//遍歷 broadcasts,取出對應key,得到maxKeyfor (String key : broadcasts.keySet()) {//每進行一次for重置臨時集合tempSet,maxTempSet不用重置tempSet.clear();//當前這個key能夠覆蓋的地區HashSet<String> areas = broadcasts.get(key);tempSet.addAll(areas);//求出tempSet和allAreas集合的交集,交集結果會賦給tempSettempSet.retainAll(allAreas);/*如果當前這個集合包含的未覆蓋地區的數量,比maxKey指向的集合地區還多,就需要重置maxKey體現出貪心算法的特點,每次都選擇最優的:tempSet.size() > maxTempSet.size(); maxTempSet.size()是上一個maxKey和allAreas集合的交集的數量簡單點:就是比較每一輪中每一個key中和allAreas集合的交集的數量大小,最大的即為maxKey。即被選擇加入selects集合的電臺*/if (tempSet.size() > 0 && (maxKey == null ||tempSet.size() > maxTempSet.size())) {maxKey = key;maxTempSet.addAll(broadcasts.get(maxKey));maxTempSet.retainAll(allAreas);}}//maxKey != null,就應該將maxKey加入selectsif (maxKey != null) {selects.add(maxKey);//將maxKey指向的廣播電臺覆蓋的地區,從allAreas去掉allAreas.removeAll(broadcasts.get(maxKey));}}//循環結束之后就得到了貪心算法的最優的一種解法(可能也不是最優的,看具體需求情況)return selects;} }

    運行結果:

    貪心算法注意事項和細節

    貪婪算法所得到的結果不一定是最優的結果(有時候會是最優解),但是都是相對近似(接近)最優解的結果。
    比如上題的算法選出的是K1, K2, K3, K5,符合覆蓋了全部的地區,但是我們發現 K2, K3,K4,K5 也可以覆蓋全部地區,如果K2 的使用成本低于K1,那么我們上題的 K1, K2, K3, K5 雖然是滿足條件,但是并不是最優的.

    普里姆算法

    應用場景-修路問題

    有勝利鄉有7個村莊(A, B, C, D, E, F, G) ,現在需要修路把7個村莊連通,各個村莊的距離用邊線表示(權) ,比如 A – B 距離 5公里
    問:如何修路保證各個村莊都能連通,并且總的修建公路總里程最短?
    思路: 將10條邊,連接即可,但是總的里程數不是最小.
    正確的思路: 就是盡可能的選擇少的路線,并且每條路線最小,保證總里程數最少

    最小生成樹

    修路問題本質就是就是最小生成樹問題, 先介紹一下最小生成樹(Minimum Cost Spanning Tree),簡稱MST。

  • 給定一個帶權的無向連通圖,如何選取一棵生成樹,使樹上所有邊上權的總和為最小,這叫最小生成樹
  • N個頂點,一定有N-1條邊
  • 包含全部頂點
  • N-1條邊都在圖中
  • 舉例說明(如圖下圖)
  • 求最小生成樹的算法主要是普里姆算法和克魯斯卡爾算法
  • 普里姆算法介紹

    普利姆(Prim)算法求最小生成樹,也就是在包含n個頂點的連通圖中,找出只有(n-1)條邊包含所有n個頂點的連通子圖,也就是所謂的極小連通子圖
    普利姆的算法如下:

  • 設G=(V,E)是連通網,T=(U,D)是最小生成樹,V,U是頂點集合,E,D是邊的集合
  • 若從頂點u開始構造最小生成樹,則從集合V中取出頂點u放入集合U中,標記頂點v的visited[u]=1
  • 若集合U中頂點ui與集合V-U中的頂點vj之間存在邊,則尋找這些邊中權值最小的邊,但不能構成回路,將頂點vj加入集合U中,將邊(ui,vj)加入集合D中,標記visited[vj]=1
  • 重復步驟2,直到U與V相等,即所有頂點都被標記為訪問過,此時D中有n-1條邊
  • 代碼實現:

    package com.atguigu.prim;import java.util.Arrays;/*** @author ysxstart* @create 2022-04-26 19:54*/ public class PrimAlgorithm {public static void main(String[] args) {//測試圖是否創建okchar[] data = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};int verxs = data.length;//鄰接矩陣的關系使用二維數組表示,10000這個大數,表示兩個點不聯通int[][] weight = new int[][]{{10000, 5, 7, 10000, 10000, 10000, 2},{5, 10000, 10000, 9, 10000, 10000, 3},{7, 10000, 10000, 10000, 8, 10000, 10000},{10000, 9, 10000, 10000, 10000, 4, 10000},{10000, 10000, 8, 10000, 10000, 5, 4},{10000, 10000, 10000, 4, 5, 10000, 6},{2, 3, 10000, 10000, 4, 6, 10000}};//創建MGraph對象MGraph graph = new MGraph(verxs);//創建一個MinTree對象MinTree minTree = new MinTree();minTree.createGraphMatrix(graph, verxs, data, weight);//輸出minTree.showGraph(graph);//測試普利姆算法int weightNum = minTree.prim(graph, 0);System.out.println("權值:" + weightNum);} }//創建最小生成樹->村莊的圖(連通網) class MinTree {/*** 創建圖的鄰接矩陣** @param graph 圖對象* @param verxs 圖對應的頂點個數* @param data 圖的各個頂點的值* @param weight 圖的鄰接矩陣*/public void createGraphMatrix(MGraph graph, int verxs, char[] data, int[][] weight) {int i, j;for (i = 0; i < verxs; i++) {graph.data[i] = data[i];for (j = 0; j < verxs; j++) {graph.weight[i][j] = weight[i][j];}}}//顯示圖的鄰接矩陣public void showGraph(MGraph graph) {for (int[] row : graph.weight) {System.out.println(Arrays.toString(row));}}/*** 編寫prim算法,得到最小生成樹** @param graph 圖* @param v 表示從圖的第幾個頂點開始生成'A'->0 'B'->1...* @return 返回權值大小*/public int prim(MGraph graph, int v) {//visited[] 標記頂點是否被訪問過,默認元素的值都是0,表示沒有訪問過int[] visited = new int[graph.verxs];//把當前這個結點標記為已訪問visited[v] = 1;//h1和h2記錄每個子圖中 邊的權值最小的兩個頂點的下標int h1 = -1;int h2 = -1;//將minWeight初始成一個大數(頂點之間不存在邊),后面在遍歷過程中,會被替換int minWeight = 10000;//最短路徑的邊的權值的總和int weightSum = 0;//graph.verxs頂點,普利姆算法結束后,有 graph.verxs-1條邊for (int k = 1; k < graph.verxs; k++) {//這是確定每一次生成的子圖 eg:<A,G,B>中,和哪個未訪問過的結點的距離最近。//簡單點說就是:判斷頂點與頂點之間的距離大小,將距離小的加入最小生成樹for (int i = 0; i < graph.verxs; i++) { //i結點表示被訪問過的結點for (int j = 0; j < graph.verxs; j++) { //j結點表示還沒有訪問過的結點if (visited[i] == 1 && visited[j] == 0 && graph.weight[i][j] < minWeight) {//替換minWeight(尋找已經訪問過的結點和未訪問過的結點間的權值最小的邊)minWeight = graph.weight[i][j];h1 = i;h2 = j;}}}//找到一條邊是最小System.out.println("邊<" + graph.data[h1] + "," + graph.data[h2] + "> 權值:" + minWeight);//將當前這個結點標記為已經訪問visited[h2] = 1;//記錄權值和weightSum += minWeight;//minWeight 重新設置為最大值10000minWeight = 10000;}return weightSum;} }//創建圖,表示連通網 class MGraph {int verxs; //表示圖的節點個數char[] data; //存放結點數據int[][] weight; //存放邊(權值),就是鄰接矩陣public MGraph(int verxs) {this.verxs = verxs;data = new char[verxs];weight = new int[verxs][verxs];} }

    運行結果:

    克魯斯卡爾算法

    應用場景-公交站問題

    某城市新增7個站點(A, B, C, D, E, F, G) ,現在需要修路把7個站點連通。各個站點的距離用邊線表示(權) ,比如 A – B 距離 12公里。問:如何修路保證各個站點都能連通,并且總的修建公路總里程最短?

    克魯斯卡爾算法介紹

    • 克魯斯卡爾(Kruskal)算法,是用來求加權連通圖的最小生成樹的算法。
    • 基本思想:按照權值從小到大的順序選擇n-1條邊,并保證這n-1條邊不構成回路
    • 具體做法:首先構造一個只含n個頂點的森林,然后依權值從小到大從連通網中選擇邊加入到森林中,并使森林中不產生回路,直至森林變成一棵樹為止

    以城市公交站問題來圖解說明 克魯斯卡爾算法的原理和步驟

    在含有n個頂點的連通圖中選擇n-1條邊,構成一棵極小連通子圖,并使該連通子圖中n-1條邊上權值之和達到最小,則稱其為連通網的最小生成樹。

    例如,對于如上圖G4所示的連通網可以有多棵權值總和不相同的生成樹。

    克魯斯卡爾算法圖解
    以上圖G4為例,來對克魯斯卡爾進行演示(假設,用數組R保存最小生成樹結果)。

    第1步:將邊<E,F>加入R中。邊<E,F>的權值最小,因此將它加入到最小生成樹結果R中。
    第2步:將邊<C,D>加入R中。上一步操作之后,邊<C,D>的權值最小,因此將它加入到最小生成樹結果R中。
    第3步:將邊<D,E>加入R中。上一步操作之后,邊<D,E>的權值最小,因此將它加入到最小生成樹結果R中。
    第4步:將邊<B,F>加入R中。上一步操作之后,邊<C,E>的權值最小,但<C,E>會和已有的邊構成回路;因此,跳過邊<C,E>。同理,跳過邊<C,F>。將邊<B,F>加入到最小生成樹結果R中。
    第5步:將邊<E,G>加入R中。上一步操作之后,邊<E,G>的權值最小,因此將它加入到最小生成樹結果R中。
    第6步:將邊<A,B>加入R中。上一步操作之后,邊<F,G>的權值最小,但<F,G>會和已有的邊構成回路;因此,跳過邊<F,G>。同理,跳過邊<B,C>。將邊<A,B>加入到最小生成樹結果R中。
    此時,最小生成樹構造完成!它包括的邊依次是:<E,F> <C,D> <D,E> <B,F> <E,G> <A,B>。

    克魯斯卡爾算法分析
    根據前面介紹的克魯斯卡爾算法的基本思想和做法,能夠了解到,克魯斯卡爾算法重點需要解決的以下兩個問題:

    • 問題一: 對圖的所有邊按照權值大小進行排序。
    • 問題二: 將邊添加到最小生成樹中時,怎么樣判斷是否形成了回路。
    • 問題一很好解決,采用排序算法進行排序即可。
    • 問題二,處理方式是:記錄頂點在"最小生成樹"中的終點,頂點的終點是"在最小生成樹中與它連通的最大頂點"。然后每次需要將一條邊添加到最小生存樹時,判斷該邊的兩個頂點的終點是否重合,重合的話則會構成回路。

    如何判斷是否構成回路-舉例說明(如圖)

    在將<E,F> <C,D> <D,E>加入到最小生成樹R中之后,這幾條邊的頂點就都有了終點:
    (01) C的終點是F。
    (02) D的終點是F。
    (03) E的終點是F。
    (04) F的終點是F。

    關于終點的說明:

  • 就是將所有頂點按照從小到大的順序排列好之后;某個頂點的終點就是"與它連通的最大頂點"。
  • 因此,接下來,雖然<C,E>是權值最小的邊。但是C和E的終點都是F,即它們的終點相同,因此,將<C,E>加入最小生成樹的話,會形成回路。這就是判斷回路的方式。也就是說,加入的邊的兩個頂點不能都指向同一個終點,否則將構成回路。
  • 代碼實現:

    package com.atguigu.kruskal;import java.util.Arrays;/*** @author ysxstart* @create 2022-04-27 23:04*/ public class KruskalCase2 {private int edgeNum; //邊的數量private char[] vertxs; //頂點數組private int[][] matrix; //鄰接矩陣//INF表示兩個頂點不連通private static final int INF = Integer.MAX_VALUE;//構造器public KruskalCase2(char[] vertxs, int[][] matrix) {int vlen = vertxs.length;//初始化頂點數組和鄰接矩陣//初始化頂點,復制拷貝的方式this.vertxs = new char[vlen];for (int i = 0; i < vlen; i++) {this.vertxs[i] = vertxs[i];}//初始化邊,復制拷貝的方式this.matrix = new int[vlen][vlen];for (int i = 0; i < vlen; i++) {for (int j = 0; j < vlen; j++) {this.matrix[i][j] = matrix[i][j];}}//初始化邊的數量for (int i = 0; i < vlen; i++) {for (int j = i + 1; j < vlen; j++) {if (this.matrix[i][j] != INF) {edgeNum++;}}}}//打印鄰接矩陣private void print() {System.out.println("鄰接矩陣:");for (int i = 0; i < vertxs.length; i++) {for (int j = 0; j < vertxs.length; j++) {System.out.printf("%12d", matrix[i][j]);}System.out.println();}}//克魯斯卡爾算法所需方法:/*** 獲取圖中的邊(通過matrix鄰接矩陣來獲取),放到EData[]數組中,后面需要遍歷該數組* EData[]形式: [EData{<A, B> =12}, EData{<A, F> =16}],toString()方法** @return 返回邊的數組*/private EData2[] getEdges() {int index = 0;EData2[] edges = new EData2[edgeNum];for (int i = 0; i < vertxs.length; i++) {for (int j = i + 1; j < vertxs.length; j++) {if (matrix[i][j] != INF) {edges[index++] = new EData2(vertxs[i], vertxs[j], matrix[i][j]);}}}return edges;}/*** 對邊進行排序處理, 冒泡排序** @param edges 邊的集合*/private void sortEdges(EData2[] edges) {for (int i = 0; i < edges.length - 1; i++) {for (int j = 0; j < edges.length - 1 - i; j++) {if (edges[j].weight > edges[j + 1].weight) {EData2 temp = edges[j];edges[j] = edges[j + 1];edges[j + 1] = temp;}}}}/*** 獲取頂點的下標** @param ch 頂點的值,比如'A','B'* @return 返回 ch頂點對應的下標,如果找不到,返回-1*/private int getPosition(char ch) {for (int i = 0; i < vertxs.length; i++) {if (ch == vertxs[i]) {return i;}}return -1;}/*** 獲取下標為 i的頂點的終點()的下標, 用于后面判斷兩個頂點的終點是否相同** @param ends 數組記錄了各個頂點對應的終點,ends數組是在遍歷過程中,逐步形成(動態的)* @param i 表示頂點對應的下標* @return 返回下標為 i的這個頂點對應的終點的下標*/private int getEnds(int[] ends, int i) {while (ends[i] != 0) {i = ends[i];}return i;}//克魯斯卡爾算法實現public void kruskal() {//表示最后結果數組的索引int index = 0;//用于保存 "已有最小生成樹"中的每個頂點在最小生成樹中的{終點}int[] ends = new int[edgeNum];//創建結果數組, 保存最后的最小生成樹EData2[] rets = new EData2[edgeNum];//獲取圖中所有的邊的集合,一共有12邊EData2[] edges = getEdges();System.out.println("排序前邊的集合:" + Arrays.toString(edges));//按照邊的權值大小進行排序(從小到大)sortEdges(edges);System.out.println("排序后邊的集合:" + Arrays.toString(edges));/*遍歷edges數組,將邊添加到最小生成樹中時,判斷準備加入的邊是否形成了回路,如果沒有,就加入 rets, 否則不能加入*/for (int i = 0; i < edges.length; i++) {//獲取到第 i條邊的第一個頂點(起點)int p1 = getPosition(edges[i].start);//獲取到第 i條邊的第二個頂點int p2 = getPosition(edges[i].end);//獲取 p1這個頂點在已有最小生成樹中的終點的下標int m = getEnds(ends, p1);//獲取 p2這個頂點在已有最小生成樹中的終點的下標int n = getEnds(ends, p2);//判斷是否構成回路if (m != n) {//設置 m在"已有最小生成樹"中的終點 <E,F> [0,0,0,0,5,0,0,0,0,0,0,0]ends[m] = n;//有一條邊加入到rets數組rets[index++] = edges[i];}}//<E,F> <C,D> <D,E> <B,F> <E,G> <A,B>。//統計并打印 "最小生成樹", 輸出 retsSystem.out.println("最小生成樹為:");for (int i = 0; i < index; i++) {System.out.println(rets[i]);}}public static void main(String[] args) {char[] vertexs = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};//克魯斯卡爾算法的鄰接矩陣int[][] matrix = {/*A*//*B*//*C*//*D*//*E*//*F*//*G*//*A*/ {0, 12, INF, INF, INF, 16, 14},/*B*/ {12, 0, 10, INF, INF, 7, INF},/*C*/ {INF, 10, 0, 3, 5, 6, INF},/*D*/ {INF, INF, 3, 0, 4, INF, INF},/*E*/ {INF, INF, 5, 4, 0, 2, 8},/*F*/ {16, 7, 6, INF, 2, 0, 9},/*G*/ {14, INF, INF, INF, 8, 9, 0}};KruskalCase2 kruskalCase2 = new KruskalCase2(vertexs, matrix);kruskalCase2.print();kruskalCase2.kruskal();} }//創建一個類 EData ,它的對象實例就表示一條邊 class EData2 {char start; //邊的一個點char end; //邊的另外一個點int weight; //邊的權值public EData2(char start, char end, int weight) {this.start = start;this.end = end;this.weight = weight;}@Overridepublic String toString() {return "EData2{<" + start + ", " + end + "> =" + weight + '}';} }

    運行結果:

    迪杰斯特拉算法

    應用場景-最短路徑問題

    • 戰爭時期,勝利鄉有7個村莊(A, B, C, D, E, F, G) ,現在有六個郵差,從G點出發,需要- 分別把郵件分別送到 A, B, C , D, E, F 六個村莊
    • 各個村莊的距離用邊線表示(權) ,比如 A – B 距離 5公里
    • 問:如何計算出G村莊到 其它各個村莊的最短距離?
    • 如果從其它點出發到各個點的最短距離又是多少?

    迪杰斯特拉(Dijkstra)算法介紹

    迪杰斯特拉(Dijkstra)算法是典型最短路徑算法,用于計算一個結點到其他結點的最短路徑。 它的主要特點是以起始點為中心向外層層擴展(廣度優先搜索思想),直到擴展到終點為止。

    迪杰斯特拉(Dijkstra)算法過程

    設置出發頂點為v,頂點集合V{v1,v2,vi…},v到V中各頂點的距離構成距離集合Dis,Dis{d1,d2,di…},Dis集合記錄著v到圖中各頂點的距離(到自身可以看作0,v到vi距離對應為di)

  • 從Dis中選擇值最小的距離并移出Dis集合,同時移出V集合中對應的頂點vi,此時的v到vi即為最短路徑
  • 更新Dis集合,更新規則為:比較v到V集合中頂點的距離值,與v通過vi到V集合中頂點的距離值,保留值較小的一個(同時也應該更新頂點的前驅節點為vi,表明是通過vi到達的)
  • 重復執行兩步驟,直到最短路徑頂點為目標頂點即可結束
  • 思路圖解

    代碼實現:

    package com.atguigu.dijkstra;import java.util.Arrays;/*** @author Mustang* @create 2022-04-29 9:37*/ public class DijkstraAlgorithm2 {public static void main(String[] args) {char[] vertex = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};int[][] matrix = new int[vertex.length][vertex.length];//表示不可以連接final int N = 65535;matrix[0] = new int[]{N, 5, 7, N, N, N, 2};matrix[1] = new int[]{5, N, N, 9, N, N, 3};matrix[2] = new int[]{7, N, N, N, 8, N, N};matrix[3] = new int[]{N, 9, N, N, N, 4, N};matrix[4] = new int[]{N, N, 8, N, N, 5, 4};matrix[5] = new int[]{N, N, N, 4, 5, N, 6};matrix[6] = new int[]{2, 3, N, N, 4, 6, N};Graph2 graph2 = new Graph2(vertex, matrix);//測試圖的鄰接矩陣是否okgraph2.showGraph();//測試迪杰斯特拉算法graph2.dijkstra(6);graph2.showDijkstra();} }//圖,村莊 class Graph2 {private char[] vertex; //頂點數組private int[][] matrix; //鄰接矩陣private VisitedVertex2 vv; //已經訪問的頂點的集合//構造器public Graph2(char[] vertex, int[][] matrix) {int len = vertex.length;this.vertex = new char[len];for (int i = 0; i < len; i++) {this.vertex[i] = vertex[i];}this.matrix = new int[len][len];for (int i = 0; i < len; i++) {for (int j = 0; j < len; j++) {this.matrix[i][j] = matrix[i][j];}}}//顯示圖public void showGraph() {for (int[] row : matrix) {System.out.println(Arrays.toString(row));}}//顯示迪杰斯特拉算法結果public void showDijkstra() {vv.show();}/*** 迪杰斯特拉算法實現** @param index 出發的頂點*/public void dijkstra(int index) {vv = new VisitedVertex2(vertex.length, index);for (int i = 0; i < vertex.length; i++) {update(index); //更新index頂點到周圍頂點的距離和周圍頂點的前驅頂點index = vv.updateArr(); //更新訪問頂點}}//更新 index下標頂點到周圍頂點的距離和周圍頂點的前驅頂點.G->A,G->B;前驅:G<-B,B的前驅是Gprivate void update(int index) {int len = 0;//根據出發頂點index 遍歷鄰接矩陣的matrix[index]行for (int i = 0; i < matrix[index].length; i++) {//len含義是: 出發頂點到index頂點的距離 + 從index頂點到i頂點的距離的和.G->G + G-Alen = vv.getDis(index) + matrix[index][i];// i頂點沒有被訪問過,并且 len小于出發頂點到i頂點的距離,就需要更新if (!vv.isVisited(i) && len < vv.getDis(i)) {vv.updateDis(i, len); //更新出發頂點到 i頂點的距離vv.updatePre(i, index); //更新 i頂點的前驅為index頂點}}} }//已訪問頂點集合 class VisitedVertex2 {//記錄各個頂點是否訪問過 1表示訪問過,0未訪問,會動態更新public int[] already_arr;//每個頂點下標對應的前一個頂點下標(頂點的前驅頂點),會動態更新public int[] pre_visited;//記錄出發頂點到其他所有頂點的距離,//比如G為出發頂點,就會記錄G到其它頂點的距離,會動態更新,求的最短距離就會存放到dispublic int[] dis;/*** 構造器** @param length 頂點的個數* @param index 出發頂點的下標, 比如G頂點,下標就是6*/public VisitedVertex2(int length, int index) {this.already_arr = new int[length];this.pre_visited = new int[length];this.dis = new int[length];//初始化 dis數組Arrays.fill(dis, 65535);//設置出發頂點被訪問過this.already_arr[index] = 1;//設置出發頂點的到它自己的距離為 0this.dis[index] = 0;}//迪杰斯特拉算法所需方法:/*** 返回出發頂點到 index頂點的距離** @param index* @return*/public int getDis(int index) {return dis[index];}/*** 判斷index頂點是否被訪問過** @param index* @return 如果訪問過, 就返回true, 否則訪問false*/public boolean isVisited(int index) {return already_arr[index] == 1;}/*** 更新出發頂點到 index頂點的距離** @param index 更新的頂點* @param len 更新的距離*/public void updateDis(int index, int len) {dis[index] = len;}/*** 更新 pre頂點的前驅頂點為 index頂點** @param pre* @param index*/public void updatePre(int pre, int index) {pre_visited[pre] = index;}/*** 繼續選擇頂點并返回新的訪問頂點,比如這里的 G完后,* 就是 A點作為新的訪問頂點(注意不是出發頂點)** @return 返回新的訪問頂點*/public int updateArr() {int min = 65535, index = 0;for (int i = 0; i < already_arr.length; i++) {//沒有訪問過且距離最小if (already_arr[i] == 0 && dis[i] < min) {min = dis[i];index = i;}}//更新 index頂點被訪問過already_arr[index] = 1;return index;}//顯示最后的結果public void show() {System.out.println("====================================================");//輸出already_arrSystem.out.print("already_arr: ");for (int i : already_arr) {System.out.print(i + " ");}System.out.println();//輸出pre_visitedSystem.out.print("pre_visited: ");for (int i : pre_visited) {System.out.print(i + " ");}System.out.println();//輸出disSystem.out.print("dis: ");for (int i : dis) {System.out.print(i + " ");}System.out.println();System.out.println("====================================================");char[] vertex = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};int count = 0;for (int i : dis) {if (i != 65535) {System.out.print(vertex[count] + "(" + i + ") ");} else {System.out.print("N ");}count++;}} }

    運行結果:

    弗洛伊德算法

    弗洛伊德(Floyd)算法介紹

    • 和Dijkstra算法一樣,弗洛伊德(Floyd)算法也是一種用于尋找給定的加權圖中頂點間最短路徑的算法。該算法名稱以創始人之一、1978年圖靈獎獲得者、斯坦福大學計算機科學系教授羅伯特·弗洛伊德命名
    • 弗洛伊德算法(Floyd)計算圖中各個頂點之間的最短路徑
    • 迪杰斯特拉算法用于計算圖中某一個頂點到其他頂點的最短路徑。
    • 弗洛伊德算法 VS 迪杰斯特拉算法:迪杰斯特拉算法通過選定的被訪問頂點,求出從出發訪問頂點到其他頂點的最短路徑;弗洛伊德算法中每一個頂點都是出發訪問點,所以需要將每一個頂點看做被訪問頂點,求出從每一個頂點到其他頂點的最短路徑。

    弗洛伊德(Floyd)算法圖解分析

  • 設置頂點vi到頂點vk的最短路徑已知為Lik,頂點vk到vj的最短路徑已知為Lkj,頂點vi到vj的路徑為Lij,則vi到vj的最短路徑為:min((Lik+Lkj),Lij),vk的取值為圖中所有頂點,則可獲得vi到vj的最短路徑
  • 至于vi到vk的最短路徑Lik或者vk到vj的最短路徑Lkj,是以同樣的方式獲得

    第一輪循環中,以A(下標為:0)作為中間頂點,距離表和前驅關系更新為:
  • 分析如下:

  • 以A頂點作為中間頂點是,B->A->C的距離由N->9,同理C到B;C->A->G的距離由N->12,同理G到C
  • 更換中間頂點,循環執行操作,直到所有頂點都作為中間頂點更新后,計算結束
  • 弗洛伊德(Floyd)算法最佳應用-最短路徑

    勝利鄉有7個村莊(A, B, C, D, E, F, G),各個村莊的距離用邊線表示(權) ,比如 A – B 距離 5公里。問:如何計算出各村莊到 其它各村莊的最短距離?

    代碼實現:

    package com.atguigu.floyd;import java.util.Arrays;/*** @author Mustang* @create 2022-04-30 10:42*/ public class FloydAlgorithm {public static void main(String[] args) {char[] vertex = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};int[][] matrix = new int[vertex.length][vertex.length];final int N = 65535;matrix[0] = new int[]{0, 5, 7, N, N, N, 2};matrix[1] = new int[]{5, 0, N, 9, N, N, 3};matrix[2] = new int[]{7, N, 0, N, 8, N, N};matrix[3] = new int[]{N, 9, N, 0, N, 4, N};matrix[4] = new int[]{N, N, 8, N, 0, 5, 4};matrix[5] = new int[]{N, N, N, 4, 5, 0, 6};matrix[6] = new int[]{2, 3, N, N, 4, 6, 0};Graph graph = new Graph(vertex, matrix);graph.floyd();graph.show();} }//創建圖 class Graph {//存放頂點的數組private char[] vertex;//保存從各個頂點出發到其它頂點的距離,最后的結果也是保留在該數組private int[][] dis;//保存到達目標頂點的前驅頂點private int[][] pre;/*** 構造器** @param matrix 鄰接矩陣* @param vertex 頂點數組*/public Graph(char[] vertex, int[][] matrix) {int len = vertex.length;//初始化頂點數組和鄰接矩陣this.vertex = new char[len];for (int i = 0; i < len; i++) {this.vertex[i] = vertex[i];}this.dis = new int[len][len];for (int i = 0; i < len; i++) {for (int j = 0; j < len; j++) {this.dis[i][j] = matrix[i][j];}}//對pre數組初始化, 注意存放的是前驅頂點的下標this.pre = new int[len][len];for (int i = 0; i < len; i++) {Arrays.fill(pre[i], i);}}//顯示pre數組和dis數組public void show() {char[] vertex = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};for (int k = 0; k < dis.length; k++) {System.out.print("前驅關系--> ");for (int i = 0; i < dis.length; i++) {System.out.print(vertex[pre[k][i]] + " ");}System.out.println();for (int i = 0; i < dis.length; i++) {System.out.print("(" + vertex[k] + "到" + vertex[i] + "的最短路徑是" + dis[k][i] + ") ");}System.out.println();}}//弗洛伊德算法實現,3層for循環public void floyd() {int len = 0; //保存距離//對中間頂點遍歷,k就是中間頂點的下標 [A, B, C, D, E, F, G]for (int k = 0; k < dis.length; k++) {//從i頂點開始出發 [A, B, C, D, E, F, G]for (int i = 0; i < dis.length; i++) {//到達j頂點 [A, B, C, D, E, F, G]for (int j = 0; j < dis.length; j++) {//求出從 i頂點出發,經過 k中間頂點,到達 j頂點距離len = dis[i][k] + dis[k][j];//如果len小于 dis[i][j]if (len < dis[i][j]){dis[i][j] = len; //更新距離pre[i][j] = pre[k][j]; //更新前驅頂點}}}}} }

    運行結果:

    馬踏棋盤算法

    馬踏棋盤算法介紹和游戲演示

    馬踏棋盤算法也被稱為騎士周游問題
    將馬隨機放在國際象棋的8×8棋盤Board[0~7][0~7]的某個方格中,馬按走棋規則(馬走日字)進行移動。要求每個方格只進入一次,走遍棋盤上全部64個方格

    馬踏棋盤游戲代碼實現

    • 馬踏棋盤問題(騎士周游問題)實際上是圖的深度優先搜索(DFS)的應用。
    • 如果使用回溯(就是深度優先搜索)來解決,假如馬兒踏了53個點,如圖:走到了第53個,坐標(1,0),發現已經走到盡頭,沒辦法,那就只能回退了,查看其他的路徑,就在棋盤上不停的回溯……
    • 分析第一種方式的問題,并使用貪心算法(greedyalgorithm)進行優化。解決馬踏棋盤問題.

    思路圖解:

    代碼實現:

    package com.atguigu.horse;import java.awt.*; import java.util.ArrayList; import java.util.Comparator;/*** @author Mustang* @create 2022-05-04 13:50*/ public class HorseChessboard2 {private static int X; //棋盤的列數private static int Y; //棋盤的行數//標記棋盤的各個位置是否被訪問過private static boolean[] visited;//標記棋盤的所有位置是否都被訪問,如果為true,表示成功private static boolean finished;public static void main(String[] args) {System.out.println("馬踏棋盤算法 Begining~");X = 8;Y = 8;int row = 1;int column = 1;int[][] chessboard = new int[X][Y];visited = new boolean[X * Y];//測試耗時long start = System.currentTimeMillis();traversalChessboard(chessboard, row - 1, column - 1, 1);long end = System.currentTimeMillis();System.out.println("共耗時:" + (end - start) + "毫秒");//輸出棋盤的最后情況for (int[] rows : chessboard) {for (int step : rows) {System.out.print(step + "\t");}System.out.println();}}/*** 完成騎士周游問題算法** @param chessboard 棋盤* @param row 馬兒當前的位置的行 從0開始* @param column 馬兒當前的位置的列 從0開始* @param step 是第幾步 ,初始位置就是第1步*/public static void traversalChessboard(int[][] chessboard, int row, int column, int step) {chessboard[row][column] = step;//標記該位置已經訪問visited[row * X + column] = true;//獲取當前位置可以走的下一個位置的集合ArrayList<Point> ps = next(new Point(column, row));//對ps進行排序,排序的規則就是對ps的所有的Point對象的下一步的位置的數目,進行非遞減排序sort(ps);while (!ps.isEmpty()) {//取出下一個可以走的位置Point p = ps.remove(0);//判斷該點是否已經訪問過if (!visited[p.y * X + p.x]) { //說明還沒有訪問過traversalChessboard(chessboard, p.y, p.x, step + 1);}}//判斷馬兒是否完成了任務,使用 step和應該走的步數比較。如果沒有達到數量,則表示沒有完成任務,將整個棋盤置 0//說明: step < X * Y 成立的情況有兩種:1.馬兒到達目標位置,仍然沒有走完 2.棋盤處于一個回溯過程if (step < X * Y && !finished) {//當前這步沒有走過,用于回溯之后再走chessboard[row][column] = 0;visited[row * X + column] = false;} else {finished = true;}}/*** 根據當前位置(Point對象),計算馬兒還能走哪些位置(Point),* 并放入到一個集合中(ArrayList), 最多有8個位置** @param curPoint 當前位置* @return 返回位置集合*/public static ArrayList<Point> next(Point curPoint) {//位置集合ArrayList<Point> ps = new ArrayList<>();//創建一個Point位置Point p1 = new Point();if ((p1.x = curPoint.x - 2) >= 0 && (p1.y = curPoint.y - 1) >= 0) {ps.add(new Point(p1));}//判斷馬兒可以走6這個位置if ((p1.x = curPoint.x - 1) >= 0 && (p1.y = curPoint.y - 2) >= 0) {ps.add(new Point(p1));}//判斷馬兒可以走7這個位置if ((p1.x = curPoint.x + 1) < X && (p1.y = curPoint.y - 2) >= 0) {ps.add(new Point(p1));}//判斷馬兒可以走0這個位置if ((p1.x = curPoint.x + 2) < X && (p1.y = curPoint.y - 1) >= 0) {ps.add(new Point(p1));}//判斷馬兒可以走1這個位置if ((p1.x = curPoint.x + 2) < X && (p1.y = curPoint.y + 1) < Y) {ps.add(new Point(p1));}//判斷馬兒可以走2這個位置if ((p1.x = curPoint.x + 1) < X && (p1.y = curPoint.y + 2) < Y) {ps.add(new Point(p1));}//判斷馬兒可以走3這個位置if ((p1.x = curPoint.x - 1) >= 0 && (p1.y = curPoint.y + 2) < Y) {ps.add(new Point(p1));}//判斷馬兒可以走4這個位置if ((p1.x = curPoint.x - 2) >= 0 && (p1.y = curPoint.y + 1) < Y) {ps.add(new Point(p1));}return ps;}//根據當前這一步的所有的下一步的選擇位置,進行非遞減排序, 減少回溯的次數public static void sort(ArrayList<Point> ps) {ps.sort(new Comparator<Point>() {@Overridepublic int compare(Point o1, Point o2) {int count1 = next(o1).size();int count2 = next(o2).size();if (count1 < count2) {return -1;} else if (count1 == count2) {return 0;} else {return 1;}}});} }

    運行結果:

    沒有使用貪心算法時運行時間:

    總結

    以上是生活随笔為你收集整理的码农常用10种算法的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    噜噜噜亚洲色成人网站 | 无码人妻精品一区二区三区下载 | 激情综合激情五月俺也去 | 国产办公室秘书无码精品99 | 又紧又大又爽精品一区二区 | 少妇无码一区二区二三区 | 一区二区三区高清视频一 | 性欧美熟妇videofreesex | 国产做国产爱免费视频 | 在线成人www免费观看视频 | 国产性生交xxxxx无码 | 天海翼激烈高潮到腰振不止 | 亚洲精品一区二区三区四区五区 | 日韩精品乱码av一区二区 | 亚洲中文字幕乱码av波多ji | 日日碰狠狠躁久久躁蜜桃 | 蜜臀av在线播放 久久综合激激的五月天 | 国产三级久久久精品麻豆三级 | 成人无码精品1区2区3区免费看 | 亚洲日韩av一区二区三区中文 | 日韩无套无码精品 | 欧美性生交xxxxx久久久 | 午夜福利试看120秒体验区 | 亚洲人成网站免费播放 | 一个人看的视频www在线 | 亚洲中文字幕成人无码 | 少妇性l交大片 | 国产午夜无码精品免费看 | 无码纯肉视频在线观看 | 日韩人妻无码一区二区三区久久99 | 亚洲中文无码av永久不收费 | 青青久在线视频免费观看 | 伦伦影院午夜理论片 | 老熟女乱子伦 | 国产精品第一国产精品 | 亚洲国产高清在线观看视频 | 精品人妻av区 | 亚洲综合精品香蕉久久网 | 亚洲色欲色欲天天天www | 国产精品资源一区二区 | 午夜无码人妻av大片色欲 | 亚洲国产一区二区三区在线观看 | 激情五月综合色婷婷一区二区 | 亚洲热妇无码av在线播放 | 国产精品.xx视频.xxtv | 国产欧美精品一区二区三区 | 无码毛片视频一区二区本码 | 亚洲色无码一区二区三区 | 精品人妻中文字幕有码在线 | 无码av最新清无码专区吞精 | 国产日产欧产精品精品app | 国产在线一区二区三区四区五区 | 一本久道久久综合婷婷五月 | 国产真实乱对白精彩久久 | 中国女人内谢69xxxx | 无码播放一区二区三区 | 国产卡一卡二卡三 | 天天躁夜夜躁狠狠是什么心态 | 香蕉久久久久久av成人 | 日韩人妻无码中文字幕视频 | 奇米影视7777久久精品人人爽 | 国产一精品一av一免费 | 欧美丰满熟妇xxxx | 99久久久无码国产精品免费 | 夜先锋av资源网站 | 亚洲精品午夜国产va久久成人 | 激情五月综合色婷婷一区二区 | 人妻人人添人妻人人爱 | 黑人粗大猛烈进出高潮视频 | 久久综合网欧美色妞网 | 亚洲大尺度无码无码专区 | 国产无遮挡又黄又爽又色 | 人妻体内射精一区二区三四 | 综合激情五月综合激情五月激情1 | 国产精品美女久久久 | 无码成人精品区在线观看 | 国产成人一区二区三区别 | 又大又硬又爽免费视频 | 色婷婷欧美在线播放内射 | 国产偷自视频区视频 | 欧美人与牲动交xxxx | 伊人久久大香线蕉亚洲 | 美女扒开屁股让男人桶 | 国产精品永久免费视频 | 久久久精品国产sm最大网站 | 国产精品怡红院永久免费 | 99久久久无码国产aaa精品 | 蜜桃视频韩日免费播放 | 国内精品人妻无码久久久影院 | 国产黄在线观看免费观看不卡 | 国产午夜视频在线观看 | 免费乱码人妻系列无码专区 | 55夜色66夜色国产精品视频 | 亚洲日韩一区二区三区 | а天堂中文在线官网 | 成人精品天堂一区二区三区 | 麻豆av传媒蜜桃天美传媒 | 久久无码人妻影院 | 亚洲色大成网站www国产 | 亚洲中文无码av永久不收费 | 粉嫩少妇内射浓精videos | 国产午夜手机精彩视频 | 亚洲色大成网站www | 日产精品高潮呻吟av久久 | 精品国产福利一区二区 | 色婷婷av一区二区三区之红樱桃 | 激情五月综合色婷婷一区二区 | 亚洲成色www久久网站 | 国产黑色丝袜在线播放 | 亚洲 高清 成人 动漫 | 曰韩少妇内射免费播放 | 中文字幕乱码人妻无码久久 | 久久国产36精品色熟妇 | 亚洲中文字幕av在天堂 | 色狠狠av一区二区三区 | 久久久久成人精品免费播放动漫 | 成人一在线视频日韩国产 | 久久精品人妻少妇一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 初尝人妻少妇中文字幕 | 67194成是人免费无码 | 久久这里只有精品视频9 | 亚洲精品久久久久avwww潮水 | 天天av天天av天天透 | 亚洲第一网站男人都懂 | 中文字幕亚洲情99在线 | 国产精品香蕉在线观看 | 免费观看激色视频网站 | 精品久久久中文字幕人妻 | 久久久久亚洲精品男人的天堂 | 欧美日韩久久久精品a片 | 久久久精品人妻久久影视 | 人人澡人人透人人爽 | 国产猛烈高潮尖叫视频免费 | 99riav国产精品视频 | 久久精品中文闷骚内射 | 强开小婷嫩苞又嫩又紧视频 | 亚洲爆乳大丰满无码专区 | 亚洲欧美综合区丁香五月小说 | 少妇人妻偷人精品无码视频 | 2020久久香蕉国产线看观看 | 无遮无挡爽爽免费视频 | 丝袜人妻一区二区三区 | 国产人妻人伦精品 | 亚洲毛片av日韩av无码 | 欧美熟妇另类久久久久久不卡 | 内射老妇bbwx0c0ck | 麻豆精品国产精华精华液好用吗 | 精品人妻人人做人人爽 | 熟女俱乐部五十路六十路av | 在线欧美精品一区二区三区 | 国产超级va在线观看视频 | 亚洲午夜福利在线观看 | 亚洲码国产精品高潮在线 | 动漫av网站免费观看 | 国产成人精品优优av | 妺妺窝人体色www婷婷 | 欧美成人高清在线播放 | 成人精品一区二区三区中文字幕 | 少妇激情av一区二区 | 一本无码人妻在中文字幕免费 | 久久精品成人欧美大片 | 欧美激情一区二区三区成人 | 国产激情一区二区三区 | 国产成人无码午夜视频在线观看 | 欧美freesex黑人又粗又大 | 超碰97人人做人人爱少妇 | 2019nv天堂香蕉在线观看 | 亚洲国产精品毛片av不卡在线 | 成人片黄网站色大片免费观看 | 精品国产成人一区二区三区 | 曰本女人与公拘交酡免费视频 | 中文字幕无码热在线视频 | 自拍偷自拍亚洲精品10p | 午夜性刺激在线视频免费 | 激情国产av做激情国产爱 | 人人澡人人妻人人爽人人蜜桃 | 色婷婷av一区二区三区之红樱桃 | 久久99精品久久久久婷婷 | 亚洲午夜无码久久 | 老司机亚洲精品影院 | 亚洲综合在线一区二区三区 | 国产亚洲欧美日韩亚洲中文色 | 亚洲成av人片在线观看无码不卡 | 久久99精品国产.久久久久 | 一本色道久久综合亚洲精品不卡 | 亚洲另类伦春色综合小说 | 久久久久久a亚洲欧洲av冫 | 成人动漫在线观看 | 久久久久99精品国产片 | 色噜噜亚洲男人的天堂 | 精品熟女少妇av免费观看 | 又湿又紧又大又爽a视频国产 | 全黄性性激高免费视频 | 日韩av无码一区二区三区不卡 | 亚洲精品久久久久久一区二区 | 男人扒开女人内裤强吻桶进去 | 亚洲一区二区三区含羞草 | 色窝窝无码一区二区三区色欲 | 一个人看的www免费视频在线观看 | 四十如虎的丰满熟妇啪啪 | 亚洲精品一区三区三区在线观看 | 日产精品99久久久久久 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲色偷偷男人的天堂 | 东北女人啪啪对白 | 中文字幕乱码中文乱码51精品 | 窝窝午夜理论片影院 | 漂亮人妻洗澡被公强 日日躁 | 国产做国产爱免费视频 | 丝袜美腿亚洲一区二区 | 成人精品视频一区二区三区尤物 | 久久久国产一区二区三区 | 熟妇人妻激情偷爽文 | 国产精品二区一区二区aⅴ污介绍 | 少妇一晚三次一区二区三区 | 欧美性黑人极品hd | 久久久久久九九精品久 | 亚洲综合久久一区二区 | 精品久久久久香蕉网 | 免费观看激色视频网站 | 日本一本二本三区免费 | 亚洲欧美日韩综合久久久 | 精品国产av色一区二区深夜久久 | 中文字幕日产无线码一区 | 欧美激情一区二区三区成人 | 无码人妻精品一区二区三区不卡 | 色一情一乱一伦 | 精品国产一区av天美传媒 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 精品国精品国产自在久国产87 | 永久免费观看美女裸体的网站 | 野外少妇愉情中文字幕 | 亚洲午夜久久久影院 | 欧美猛少妇色xxxxx | 中文字幕无码av激情不卡 | 性啪啪chinese东北女人 | 免费观看的无遮挡av | 色五月丁香五月综合五月 | 国产黑色丝袜在线播放 | 亚洲啪av永久无码精品放毛片 | 国产又粗又硬又大爽黄老大爷视 | 人妻尝试又大又粗久久 | 欧洲熟妇精品视频 | 纯爱无遮挡h肉动漫在线播放 | 人妻aⅴ无码一区二区三区 | 国产成人精品优优av | 日本va欧美va欧美va精品 | 麻豆国产人妻欲求不满谁演的 | 亚洲人成无码网www | 亚洲精品午夜国产va久久成人 | av小次郎收藏 | 亚洲中文字幕成人无码 | 永久免费观看美女裸体的网站 | 色一情一乱一伦 | 天天燥日日燥 | 男人的天堂av网站 | 人妻少妇精品无码专区二区 | 亚洲成a人片在线观看日本 | 露脸叫床粗话东北少妇 | 亚洲人成网站在线播放942 | 无码国产激情在线观看 | 日韩欧美成人免费观看 | 少妇久久久久久人妻无码 | 国产成人无码av在线影院 | 亚洲一区二区三区国产精华液 | √天堂资源地址中文在线 | 国产精品久久福利网站 | 成人片黄网站色大片免费观看 | 婷婷色婷婷开心五月四房播播 | 日本在线高清不卡免费播放 | 成人无码精品一区二区三区 | 精品国产精品久久一区免费式 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产成人精品视频ⅴa片软件竹菊 | 少女韩国电视剧在线观看完整 | 久久精品人人做人人综合试看 | 成年女人永久免费看片 | 野外少妇愉情中文字幕 | 波多野42部无码喷潮在线 | 国产成人无码区免费内射一片色欲 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲成色在线综合网站 | 亚洲成a人片在线观看日本 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久亚洲中文字幕精品一区 | 东京热男人av天堂 | 国产亚洲精品久久久闺蜜 | 麻豆蜜桃av蜜臀av色欲av | 午夜福利不卡在线视频 | 牲欲强的熟妇农村老妇女 | 中文无码成人免费视频在线观看 | 少妇厨房愉情理9仑片视频 | 亚洲精品中文字幕 | 亚洲国产精品久久久久久 | 久久精品国产精品国产精品污 | 亚洲日本在线电影 | 国产精品久久久久久亚洲影视内衣 | 亚洲人成影院在线观看 | 免费观看黄网站 | 国产艳妇av在线观看果冻传媒 | 国产综合久久久久鬼色 | 亚洲s色大片在线观看 | 国产内射爽爽大片视频社区在线 | 三上悠亚人妻中文字幕在线 | 无人区乱码一区二区三区 | 又粗又大又硬毛片免费看 | 男女性色大片免费网站 | 日韩人妻系列无码专区 | 欧洲vodafone精品性 | 国产av人人夜夜澡人人爽麻豆 | 一个人看的视频www在线 | 福利一区二区三区视频在线观看 | 强开小婷嫩苞又嫩又紧视频 | 久久久久亚洲精品男人的天堂 | 欧美大屁股xxxxhd黑色 | 国语自产偷拍精品视频偷 | 牛和人交xxxx欧美 | 亚洲色大成网站www | 丰满少妇高潮惨叫视频 | 性做久久久久久久免费看 | 中文字幕精品av一区二区五区 | 国产激情无码一区二区 | 四虎国产精品免费久久 | 国产超碰人人爽人人做人人添 | 亚洲一区二区三区在线观看网站 | 国产三级久久久精品麻豆三级 | 男女猛烈xx00免费视频试看 | 亚洲一区二区三区偷拍女厕 | 久久久中文久久久无码 | 精品国产一区二区三区av 性色 | 中文字幕人妻无码一区二区三区 | 少妇激情av一区二区 | 精品国产aⅴ无码一区二区 | 国产无遮挡又黄又爽又色 | 欧美亚洲日韩国产人成在线播放 | 午夜理论片yy44880影院 | 国产精品自产拍在线观看 | 亚洲 a v无 码免 费 成 人 a v | 国产精品亚洲一区二区三区喷水 | 久精品国产欧美亚洲色aⅴ大片 | 精品亚洲成av人在线观看 | 国产农村妇女高潮大叫 | 高潮毛片无遮挡高清免费 | 国产va免费精品观看 | 国产精品人人妻人人爽 | 国产性生大片免费观看性 | 男人的天堂av网站 | 欧美成人午夜精品久久久 | 老司机亚洲精品影院 | 永久黄网站色视频免费直播 | 粉嫩少妇内射浓精videos | 国产成人精品必看 | 午夜男女很黄的视频 | 图片小说视频一区二区 | 秋霞成人午夜鲁丝一区二区三区 | 国色天香社区在线视频 | 无码av免费一区二区三区试看 | 国产精品久久福利网站 | 国产亚洲视频中文字幕97精品 | 一本精品99久久精品77 | 日本熟妇大屁股人妻 | 亚洲精品一区三区三区在线观看 | 青春草在线视频免费观看 | 特级做a爰片毛片免费69 | 男人扒开女人内裤强吻桶进去 | 国产成人精品视频ⅴa片软件竹菊 | 国产特级毛片aaaaaa高潮流水 | 久久久久久av无码免费看大片 | 在线а√天堂中文官网 | 性开放的女人aaa片 | 日韩精品无码一区二区中文字幕 | 精品国产青草久久久久福利 | 大肉大捧一进一出视频出来呀 | 日韩av无码一区二区三区 | 少妇厨房愉情理9仑片视频 | 国产特级毛片aaaaaa高潮流水 | 激情人妻另类人妻伦 | 一本久道久久综合狠狠爱 | 午夜无码人妻av大片色欲 | 十八禁视频网站在线观看 | 国产精品亚洲五月天高清 | 久久综合香蕉国产蜜臀av | 中文字幕中文有码在线 | 精品日本一区二区三区在线观看 | 国产 浪潮av性色四虎 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲乱码日产精品bd | 中文字幕av日韩精品一区二区 | 四虎国产精品免费久久 | 娇妻被黑人粗大高潮白浆 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 台湾无码一区二区 | 人妻少妇精品无码专区动漫 | 波多野42部无码喷潮在线 | 少妇激情av一区二区 | 中文字幕无线码 | 亚洲 日韩 欧美 成人 在线观看 | 久久精品国产一区二区三区 | 真人与拘做受免费视频 | 中文无码精品a∨在线观看不卡 | 人人澡人人透人人爽 | 国内精品一区二区三区不卡 | 无码人妻丰满熟妇区毛片18 | 国产精品久久久久久久影院 | 99视频精品全部免费免费观看 | 东京无码熟妇人妻av在线网址 | а天堂中文在线官网 | 亚洲国产成人av在线观看 | 亚洲日韩精品欧美一区二区 | 97夜夜澡人人双人人人喊 | 免费播放一区二区三区 | 国产va免费精品观看 | 午夜福利不卡在线视频 | 国内精品人妻无码久久久影院蜜桃 | 亚洲精品久久久久久一区二区 | 精品久久久久久人妻无码中文字幕 | 美女毛片一区二区三区四区 | a在线观看免费网站大全 | 久久综合色之久久综合 | 中文字幕 人妻熟女 | 永久免费精品精品永久-夜色 | 7777奇米四色成人眼影 | 亚洲中文字幕无码中文字在线 | 在线观看国产午夜福利片 | 国产又粗又硬又大爽黄老大爷视 | 亚洲成av人综合在线观看 | 精品无码国产一区二区三区av | 亚洲日韩一区二区三区 | 久久久av男人的天堂 | 国产精品手机免费 | 国产极品美女高潮无套在线观看 | 日产国产精品亚洲系列 | 狂野欧美激情性xxxx | 性欧美熟妇videofreesex | 久久久久99精品国产片 | 日日橹狠狠爱欧美视频 | 亚洲中文字幕在线观看 | 纯爱无遮挡h肉动漫在线播放 | 欧美xxxxx精品 | 亚洲第一网站男人都懂 | 欧美一区二区三区视频在线观看 | 国产无遮挡又黄又爽免费视频 | 亚洲精品中文字幕乱码 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲中文字幕在线无码一区二区 | 久久亚洲中文字幕精品一区 | 亚洲男人av天堂午夜在 | 国产精品99爱免费视频 | www成人国产高清内射 | 久久 国产 尿 小便 嘘嘘 | 亚洲熟悉妇女xxx妇女av | 国产av一区二区精品久久凹凸 | 欧美刺激性大交 | 国产人成高清在线视频99最全资源 | 色综合久久久无码网中文 | 精品欧美一区二区三区久久久 | 中文字幕乱码人妻无码久久 | 国产国产精品人在线视 | 老司机亚洲精品影院无码 | 亚洲中文字幕乱码av波多ji | 亚洲人成网站在线播放942 | 高潮喷水的毛片 | www国产亚洲精品久久网站 | 日日摸天天摸爽爽狠狠97 | 无码乱肉视频免费大全合集 | 成年美女黄网站色大免费视频 | 久久亚洲中文字幕精品一区 | 亚洲爆乳精品无码一区二区三区 | 国产色在线 | 国产 | 狠狠色欧美亚洲狠狠色www | yw尤物av无码国产在线观看 | 国产熟妇高潮叫床视频播放 | 欧美成人高清在线播放 | www一区二区www免费 | 久9re热视频这里只有精品 | 秋霞成人午夜鲁丝一区二区三区 | 欧美激情内射喷水高潮 | 国产免费无码一区二区视频 | 精品日本一区二区三区在线观看 | 亚洲精品一区二区三区在线 | 99久久无码一区人妻 | 欧美日韩一区二区综合 | 夜夜高潮次次欢爽av女 | 亚洲成a人片在线观看无码3d | 国产亚洲精品久久久久久久 | 精品无码av一区二区三区 | 午夜熟女插插xx免费视频 | 久久精品国产99精品亚洲 | 色情久久久av熟女人妻网站 | 强辱丰满人妻hd中文字幕 | 无码乱肉视频免费大全合集 | 日本大香伊一区二区三区 | 九九在线中文字幕无码 | аⅴ资源天堂资源库在线 | 领导边摸边吃奶边做爽在线观看 | 国产成人综合色在线观看网站 | 久久国产自偷自偷免费一区调 | 久激情内射婷内射蜜桃人妖 | 久久久精品国产sm最大网站 | 激情五月综合色婷婷一区二区 | 亚洲七七久久桃花影院 | 丰满岳乱妇在线观看中字无码 | 国产精品内射视频免费 | 亚洲一区二区三区国产精华液 | 国产无套粉嫩白浆在线 | 日韩成人一区二区三区在线观看 | 麻花豆传媒剧国产免费mv在线 | 精品一二三区久久aaa片 | 人人澡人人妻人人爽人人蜜桃 | 亚洲精品一区二区三区在线 | 1000部夫妻午夜免费 | 无码人妻出轨黑人中文字幕 | 欧美精品国产综合久久 | 亚洲综合在线一区二区三区 | 日本熟妇人妻xxxxx人hd | 亚洲中文字幕无码一久久区 | 天堂无码人妻精品一区二区三区 | 国产精品资源一区二区 | 午夜精品一区二区三区的区别 | 青青久在线视频免费观看 | 日韩精品无码免费一区二区三区 | 亚洲精品午夜无码电影网 | 天天综合网天天综合色 | 国产亚洲精品久久久ai换 | 欧美日韩一区二区综合 | 国产精品二区一区二区aⅴ污介绍 | 成 人 网 站国产免费观看 | 国产一区二区三区日韩精品 | 日日摸日日碰夜夜爽av | 学生妹亚洲一区二区 | 色偷偷人人澡人人爽人人模 | 在线播放免费人成毛片乱码 | 黑森林福利视频导航 | 波多野结衣一区二区三区av免费 | 亚洲一区二区三区无码久久 | 在线 国产 欧美 亚洲 天堂 | 美女极度色诱视频国产 | 对白脏话肉麻粗话av | 曰本女人与公拘交酡免费视频 | 草草网站影院白丝内射 | 99久久无码一区人妻 | 亚洲成av人综合在线观看 | 白嫩日本少妇做爰 | 最近免费中文字幕中文高清百度 | 一本久久a久久精品vr综合 | 欧美亚洲国产一区二区三区 | 扒开双腿疯狂进出爽爽爽视频 | 国产精品无码一区二区三区不卡 | 国产精品国产三级国产专播 | 大地资源网第二页免费观看 | 老熟妇乱子伦牲交视频 | 国产明星裸体无码xxxx视频 | a在线亚洲男人的天堂 | 内射欧美老妇wbb | 最近中文2019字幕第二页 | 亚洲成熟女人毛毛耸耸多 | 成人无码视频在线观看网站 | 国产精品香蕉在线观看 | 性欧美熟妇videofreesex | 亚洲精品一区二区三区在线观看 | 国产农村乱对白刺激视频 | 亚洲精品中文字幕乱码 | 国产亚洲视频中文字幕97精品 | 牲欲强的熟妇农村老妇女 | 亚洲成av人片天堂网无码】 | www一区二区www免费 | 99精品国产综合久久久久五月天 | 国产舌乚八伦偷品w中 | 久久久无码中文字幕久... | 久久午夜无码鲁丝片午夜精品 | 久久综合狠狠综合久久综合88 | 狠狠色色综合网站 | 欧美zoozzooz性欧美 | 国内少妇偷人精品视频 | 亚洲の无码国产の无码步美 | 成年美女黄网站色大免费视频 | 老熟女乱子伦 | 国产精品久久久久久亚洲影视内衣 | 香港三级日本三级妇三级 | 欧美野外疯狂做受xxxx高潮 | 国产精品.xx视频.xxtv | 中文字幕 亚洲精品 第1页 | 久久99国产综合精品 | 97夜夜澡人人双人人人喊 | 欧美成人家庭影院 | 无码精品国产va在线观看dvd | 六十路熟妇乱子伦 | 在线a亚洲视频播放在线观看 | 水蜜桃av无码 | 亚洲爆乳精品无码一区二区三区 | 日本熟妇大屁股人妻 | 高清不卡一区二区三区 | 国产精品多人p群无码 | 国产午夜福利亚洲第一 | 中文字幕av日韩精品一区二区 | 少妇人妻偷人精品无码视频 | 天海翼激烈高潮到腰振不止 | 午夜时刻免费入口 | 国内精品九九久久久精品 | 夫妻免费无码v看片 | 丝袜足控一区二区三区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产手机在线αⅴ片无码观看 | 麻豆av传媒蜜桃天美传媒 | 鲁大师影院在线观看 | 中文字幕+乱码+中文字幕一区 | 亚洲精品久久久久久一区二区 | 国产激情无码一区二区app | 2020久久超碰国产精品最新 | 国产亚洲精品精品国产亚洲综合 | 天天躁日日躁狠狠躁免费麻豆 | 国产极品视觉盛宴 | 大肉大捧一进一出视频出来呀 | 日本爽爽爽爽爽爽在线观看免 | 日韩欧美中文字幕公布 | 亚洲精品国产品国语在线观看 | 99久久人妻精品免费一区 | 国产精品亚洲专区无码不卡 | 亚洲色在线无码国产精品不卡 | 国产人妻精品午夜福利免费 | 波多野42部无码喷潮在线 | yw尤物av无码国产在线观看 | 人妻天天爽夜夜爽一区二区 | 午夜无码人妻av大片色欲 | 人人妻人人澡人人爽欧美一区九九 | 久久人妻内射无码一区三区 | 亚洲七七久久桃花影院 | 无套内谢的新婚少妇国语播放 | а天堂中文在线官网 | 亚洲s色大片在线观看 | 乱码午夜-极国产极内射 | 亚洲小说图区综合在线 | 成人av无码一区二区三区 | 丰腴饱满的极品熟妇 | 国产人妻久久精品二区三区老狼 | 成人毛片一区二区 | 人人澡人人妻人人爽人人蜜桃 | 久久精品国产大片免费观看 | 天堂久久天堂av色综合 | 色狠狠av一区二区三区 | 色婷婷香蕉在线一区二区 | 日本熟妇浓毛 | 欧美老熟妇乱xxxxx | 俺去俺来也www色官网 | 亚洲色欲色欲欲www在线 | 人妻无码αv中文字幕久久琪琪布 | 伊人久久婷婷五月综合97色 | 人妻与老人中文字幕 | 国产激情一区二区三区 | 日韩av无码中文无码电影 | 国产成人一区二区三区在线观看 | 成人毛片一区二区 | 亚洲の无码国产の无码影院 | 国产亚洲美女精品久久久2020 | 久久精品人人做人人综合试看 | 99久久精品无码一区二区毛片 | 色五月五月丁香亚洲综合网 | 精品国产精品久久一区免费式 | 丰满肥臀大屁股熟妇激情视频 | av在线亚洲欧洲日产一区二区 | 亚洲自偷自偷在线制服 | 人妻插b视频一区二区三区 | 狂野欧美性猛xxxx乱大交 | 国产精品人妻一区二区三区四 | 蜜臀av无码人妻精品 | 99久久人妻精品免费二区 | 中文无码精品a∨在线观看不卡 | 无码人妻av免费一区二区三区 | 久久精品女人天堂av免费观看 | 午夜无码人妻av大片色欲 | 熟妇女人妻丰满少妇中文字幕 | 东京一本一道一二三区 | 四虎永久在线精品免费网址 | 亚洲精品成人福利网站 | 草草网站影院白丝内射 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲综合伊人久久大杳蕉 | 无码人妻久久一区二区三区不卡 | 2020久久超碰国产精品最新 | 丰腴饱满的极品熟妇 | 亚洲国产精品美女久久久久 | 亚洲精品欧美二区三区中文字幕 | 久久亚洲日韩精品一区二区三区 | 国产精品久免费的黄网站 | 色婷婷香蕉在线一区二区 | 欧美三级不卡在线观看 | 性史性农村dvd毛片 | 国产肉丝袜在线观看 | 少妇久久久久久人妻无码 | 亚洲精品中文字幕乱码 | 欧美性猛交xxxx富婆 | 国产激情综合五月久久 | 欧美 丝袜 自拍 制服 另类 | 成人女人看片免费视频放人 | 午夜熟女插插xx免费视频 | 亚洲成熟女人毛毛耸耸多 | 精品一区二区三区波多野结衣 | 亚洲の无码国产の无码影院 | 人人妻在人人 | 中文毛片无遮挡高清免费 | 男女猛烈xx00免费视频试看 | 国产真人无遮挡作爱免费视频 | 国产三级精品三级男人的天堂 | 精品国产精品久久一区免费式 | 人人澡人摸人人添 | 亚洲精品综合五月久久小说 | 蜜臀aⅴ国产精品久久久国产老师 | 丰满护士巨好爽好大乳 | 全球成人中文在线 | 久青草影院在线观看国产 | 国产绳艺sm调教室论坛 | 18禁黄网站男男禁片免费观看 | 精品欧洲av无码一区二区三区 | 久久人妻内射无码一区三区 | 亚洲成色在线综合网站 | 暴力强奷在线播放无码 | 亚洲成a人一区二区三区 | 亚洲国精产品一二二线 | 久久亚洲精品中文字幕无男同 | 久久午夜无码鲁丝片 | 国产精品怡红院永久免费 | 男人扒开女人内裤强吻桶进去 | 婷婷丁香五月天综合东京热 | 日韩精品无码一本二本三本色 | 亚洲大尺度无码无码专区 | 日韩精品一区二区av在线 | 日本护士xxxxhd少妇 | 天干天干啦夜天干天2017 | 1000部啪啪未满十八勿入下载 | 国产97色在线 | 免 | 久久久精品国产sm最大网站 | 精品偷自拍另类在线观看 | 色综合久久久无码网中文 | 蜜桃视频插满18在线观看 | 色综合久久网 | 国内丰满熟女出轨videos | 亚洲成色www久久网站 | 动漫av一区二区在线观看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 日韩av无码一区二区三区 | 成人无码视频免费播放 | 亚洲日韩一区二区 | 亚洲午夜久久久影院 | 久久久久99精品成人片 | 国产小呦泬泬99精品 | 欧美精品免费观看二区 | 国产成人综合在线女婷五月99播放 | 色老头在线一区二区三区 | 狠狠cao日日穞夜夜穞av | 成熟人妻av无码专区 | 中文字幕无码免费久久9一区9 | 性欧美大战久久久久久久 | 国产乱人无码伦av在线a | 国产农村妇女高潮大叫 | 国产精品二区一区二区aⅴ污介绍 | 夜夜夜高潮夜夜爽夜夜爰爰 | 精品日本一区二区三区在线观看 | 久久国产精品精品国产色婷婷 | 亚洲啪av永久无码精品放毛片 | 国产亚洲精品久久久闺蜜 | 欧美 亚洲 国产 另类 | 欧美黑人乱大交 | 无码人妻丰满熟妇区五十路百度 | 久久综合九色综合欧美狠狠 | 亚洲日本va午夜在线电影 | 波多野结衣乳巨码无在线观看 | 黑人巨大精品欧美一区二区 | 久久精品人人做人人综合试看 | 狠狠色噜噜狠狠狠狠7777米奇 | 露脸叫床粗话东北少妇 | 小泽玛莉亚一区二区视频在线 | 国产福利视频一区二区 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 欧美 日韩 亚洲 在线 | 88国产精品欧美一区二区三区 | 中文字幕无码热在线视频 | 377p欧洲日本亚洲大胆 | 亚洲日本在线电影 | 男女下面进入的视频免费午夜 | 天堂久久天堂av色综合 | 成人片黄网站色大片免费观看 | 成在人线av无码免费 | 亚洲a无码综合a国产av中文 | 成人综合网亚洲伊人 | 帮老师解开蕾丝奶罩吸乳网站 | 永久免费观看美女裸体的网站 | 国产婷婷色一区二区三区在线 | 久久久精品人妻久久影视 | 亚洲自偷自拍另类第1页 | 国产午夜精品一区二区三区嫩草 | 亚洲精品久久久久久一区二区 | 日韩欧美群交p片內射中文 | 国产精品无码久久av | 麻豆果冻传媒2021精品传媒一区下载 | 国产亚洲日韩欧美另类第八页 | 性啪啪chinese东北女人 | 老熟妇仑乱视频一区二区 | 色婷婷久久一区二区三区麻豆 | 2020最新国产自产精品 | 日本护士毛茸茸高潮 | 天堂а√在线地址中文在线 | 色一情一乱一伦 | 美女极度色诱视频国产 | 日本饥渴人妻欲求不满 | 中文字幕无码av激情不卡 | 亚洲成在人网站无码天堂 | 亚洲国产精品久久久天堂 | 亚洲熟妇色xxxxx亚洲 | 女人高潮内射99精品 | 中文字幕人妻无码一夲道 | 色婷婷香蕉在线一区二区 | 四虎永久在线精品免费网址 | 少妇被黑人到高潮喷出白浆 | 日韩精品久久久肉伦网站 | 久久99精品久久久久久 | 天天拍夜夜添久久精品大 | 欧洲极品少妇 | 无码乱肉视频免费大全合集 | 精品久久久中文字幕人妻 | 亚洲无人区午夜福利码高清完整版 | 熟女俱乐部五十路六十路av | 午夜理论片yy44880影院 | av在线亚洲欧洲日产一区二区 | 久久99热只有频精品8 | 小泽玛莉亚一区二区视频在线 | 少妇人妻偷人精品无码视频 | 天天躁夜夜躁狠狠是什么心态 | 色一情一乱一伦一区二区三欧美 | 久久亚洲日韩精品一区二区三区 | 牲欲强的熟妇农村老妇女视频 | 国产绳艺sm调教室论坛 | 国产艳妇av在线观看果冻传媒 | 亚洲国产午夜精品理论片 | 日韩人妻系列无码专区 | 中文字幕精品av一区二区五区 | 国产午夜无码视频在线观看 | 在线欧美精品一区二区三区 | 97色伦图片97综合影院 | 女人和拘做爰正片视频 | 欧美高清在线精品一区 | 帮老师解开蕾丝奶罩吸乳网站 | 国产精品久久福利网站 | 色偷偷人人澡人人爽人人模 | 成人免费视频一区二区 | 国产明星裸体无码xxxx视频 | 亚洲人成影院在线无码按摩店 | 特级做a爰片毛片免费69 | 国产性生大片免费观看性 | 久久亚洲精品成人无码 | 在线成人www免费观看视频 | 正在播放东北夫妻内射 | 又大又黄又粗又爽的免费视频 | 亚洲国产精品无码一区二区三区 | 午夜肉伦伦影院 | 日日夜夜撸啊撸 | 国产av久久久久精东av | √8天堂资源地址中文在线 | 亲嘴扒胸摸屁股激烈网站 | 天海翼激烈高潮到腰振不止 | 在线播放亚洲第一字幕 | 国产在线aaa片一区二区99 | 日日天日日夜日日摸 | 理论片87福利理论电影 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲一区二区三区无码久久 | 免费网站看v片在线18禁无码 | 国产国语老龄妇女a片 | 国产精品自产拍在线观看 | 性做久久久久久久免费看 | 亚洲欧洲中文日韩av乱码 | 亚洲精品久久久久久久久久久 | 成人女人看片免费视频放人 | 在线а√天堂中文官网 | 夜夜躁日日躁狠狠久久av | 精品夜夜澡人妻无码av蜜桃 | 呦交小u女精品视频 | 国产精品亚洲专区无码不卡 | 久久精品中文字幕一区 | 国产成人综合美国十次 | 又湿又紧又大又爽a视频国产 | 国产内射爽爽大片视频社区在线 | 小泽玛莉亚一区二区视频在线 | 亚洲成av人综合在线观看 | 国产美女精品一区二区三区 | 久久久久国色av免费观看性色 | 任你躁在线精品免费 | 午夜精品一区二区三区的区别 | 无码人妻丰满熟妇区五十路百度 | 内射巨臀欧美在线视频 | 日本爽爽爽爽爽爽在线观看免 | 国语精品一区二区三区 | 图片小说视频一区二区 | 性色欲情网站iwww九文堂 | 精品欧洲av无码一区二区三区 | 精品无码国产一区二区三区av | 日本精品久久久久中文字幕 | 大乳丰满人妻中文字幕日本 | 在线精品亚洲一区二区 | 成人综合网亚洲伊人 | 亚洲精品国产a久久久久久 | 好男人www社区 | 国产成人一区二区三区在线观看 | 国产熟妇另类久久久久 | 亚洲gv猛男gv无码男同 | 精品少妇爆乳无码av无码专区 | 在线观看欧美一区二区三区 | 天天拍夜夜添久久精品 | 国产美女极度色诱视频www | 久久精品中文字幕一区 | 久久久成人毛片无码 | 四虎国产精品免费久久 | 午夜熟女插插xx免费视频 | 日本免费一区二区三区最新 | 亚洲色在线无码国产精品不卡 | 麻豆果冻传媒2021精品传媒一区下载 | 国内综合精品午夜久久资源 | 亚洲熟熟妇xxxx | 在线a亚洲视频播放在线观看 | 精品无码av一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 久久午夜无码鲁丝片 | 久久精品国产99精品亚洲 | 免费男性肉肉影院 | 正在播放东北夫妻内射 | 少妇激情av一区二区 | 一二三四社区在线中文视频 | 日日天干夜夜狠狠爱 | 久久99精品国产麻豆蜜芽 | 国产激情无码一区二区 | 一个人看的www免费视频在线观看 | 久久午夜无码鲁丝片午夜精品 | 伊在人天堂亚洲香蕉精品区 | 欧美人与善在线com | 国产极品美女高潮无套在线观看 | 亚洲成av人在线观看网址 | 日日天日日夜日日摸 | 欧美变态另类xxxx | 久久精品中文闷骚内射 | 欧美xxxxx精品 | 国产精品香蕉在线观看 | 中文字幕av无码一区二区三区电影 | av无码电影一区二区三区 | 狠狠综合久久久久综合网 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久综合给合久久狠狠狠97色 | 欧美激情综合亚洲一二区 | 午夜性刺激在线视频免费 | 久久久久久九九精品久 | 乱人伦人妻中文字幕无码久久网 | 又大又硬又黄的免费视频 | 久久精品人人做人人综合 | 国产精品高潮呻吟av久久 | 蜜臀aⅴ国产精品久久久国产老师 | 东京热无码av男人的天堂 | 波多野结衣av在线观看 | 妺妺窝人体色www婷婷 | 77777熟女视频在线观看 а天堂中文在线官网 | 精品国产精品久久一区免费式 | 内射白嫩少妇超碰 | 久久成人a毛片免费观看网站 | 亚洲成色www久久网站 | 成人亚洲精品久久久久 | 自拍偷自拍亚洲精品10p | 一本大道伊人av久久综合 | 国产精品igao视频网 | 老子影院午夜伦不卡 | 国产精品久免费的黄网站 | 国产精品第一国产精品 | 久久久无码中文字幕久... | 国内精品人妻无码久久久影院蜜桃 | 麻豆国产丝袜白领秘书在线观看 | 中国大陆精品视频xxxx | 人妻天天爽夜夜爽一区二区 | 欧美 日韩 亚洲 在线 | 中文字幕亚洲情99在线 | 日本大香伊一区二区三区 | 欧美黑人性暴力猛交喷水 | 国产亚洲精品久久久久久国模美 | 夜先锋av资源网站 | 亚洲va中文字幕无码久久不卡 | 国产疯狂伦交大片 | 日本精品少妇一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 一个人看的www免费视频在线观看 | 亚洲aⅴ无码成人网站国产app | 精品国产精品久久一区免费式 | 国产xxx69麻豆国语对白 | 漂亮人妻洗澡被公强 日日躁 | 久久熟妇人妻午夜寂寞影院 | 嫩b人妻精品一区二区三区 | 噜噜噜亚洲色成人网站 | 乌克兰少妇性做爰 | 久久人妻内射无码一区三区 | 免费无码一区二区三区蜜桃大 | 日日摸天天摸爽爽狠狠97 | 无码人妻出轨黑人中文字幕 | 久久精品99久久香蕉国产色戒 | 无码人妻黑人中文字幕 | 亚洲中文字幕无码中字 | 成人av无码一区二区三区 | 国产一区二区三区日韩精品 | 国产高清av在线播放 | 免费男性肉肉影院 | 色噜噜亚洲男人的天堂 | аⅴ资源天堂资源库在线 | 大地资源中文第3页 | 亚洲精品国偷拍自产在线麻豆 | 好爽又高潮了毛片免费下载 | 国产两女互慰高潮视频在线观看 | a片免费视频在线观看 | 少妇性俱乐部纵欲狂欢电影 | 最近的中文字幕在线看视频 | 国产av无码专区亚洲a∨毛片 | 日本精品少妇一区二区三区 | 国产一区二区三区四区五区加勒比 | 国产特级毛片aaaaaa高潮流水 | 亚洲成av人片在线观看无码不卡 | 红桃av一区二区三区在线无码av | 欧美亚洲日韩国产人成在线播放 | 无码人妻av免费一区二区三区 | 久久国产36精品色熟妇 | 国产婷婷色一区二区三区在线 | 欧美激情内射喷水高潮 | 免费人成在线视频无码 | 亚洲精品中文字幕乱码 | 性欧美牲交在线视频 | 成人片黄网站色大片免费观看 | 水蜜桃亚洲一二三四在线 | 欧美日韩综合一区二区三区 | 精品无码成人片一区二区98 | 亚洲中文字幕在线观看 | 青青久在线视频免费观看 | 无码人妻丰满熟妇区五十路百度 | 精品无码一区二区三区爱欲 | 麻豆av传媒蜜桃天美传媒 | 日本一区二区更新不卡 | 欧美精品在线观看 | 亚洲一区二区观看播放 | 好屌草这里只有精品 | 荫蒂添的好舒服视频囗交 | 日本成熟视频免费视频 | 老熟女重囗味hdxx69 | 国产猛烈高潮尖叫视频免费 | 黄网在线观看免费网站 | 欧美日韩视频无码一区二区三 | 中文无码成人免费视频在线观看 | 网友自拍区视频精品 | av在线亚洲欧洲日产一区二区 | 女人被爽到呻吟gif动态图视看 | 亚洲午夜无码久久 | 国产成人亚洲综合无码 | 精品国产一区二区三区av 性色 | 色婷婷香蕉在线一区二区 | 国产午夜福利100集发布 | 亚洲gv猛男gv无码男同 | 久久无码专区国产精品s | 曰韩少妇内射免费播放 | 亚洲精品无码国产 | 无码av岛国片在线播放 | 婷婷色婷婷开心五月四房播播 | 无码人妻久久一区二区三区不卡 | 欧美亚洲国产一区二区三区 | 欧美大屁股xxxxhd黑色 | 曰韩无码二三区中文字幕 | 红桃av一区二区三区在线无码av | 久久综合网欧美色妞网 | 性欧美videos高清精品 | 九九综合va免费看 | 国产亚洲美女精品久久久2020 | 欧美 日韩 亚洲 在线 | 国产乱码精品一品二品 | 国产成人精品无码播放 | 精品久久8x国产免费观看 | √天堂资源地址中文在线 | 欧美xxxxx精品 | 性生交大片免费看女人按摩摩 | 男女作爱免费网站 | 一本色道久久综合狠狠躁 | 成人免费视频视频在线观看 免费 | 高潮毛片无遮挡高清免费 | 久久五月精品中文字幕 | 国产成人无码区免费内射一片色欲 | 黄网在线观看免费网站 | 国产精品二区一区二区aⅴ污介绍 | 国产精品99久久精品爆乳 | 精品熟女少妇av免费观看 | 内射欧美老妇wbb | 午夜福利试看120秒体验区 | 亚洲国产av美女网站 | 中文字幕久久久久人妻 | 国产三级久久久精品麻豆三级 | 少妇性荡欲午夜性开放视频剧场 | 日本免费一区二区三区最新 | 国内老熟妇对白xxxxhd | 欧美日韩一区二区免费视频 | 日韩欧美中文字幕公布 | 大色综合色综合网站 | 激情内射日本一区二区三区 | 久久久久久久久蜜桃 | 亚洲无人区午夜福利码高清完整版 | 日本欧美一区二区三区乱码 | 欧美日韩视频无码一区二区三 | 久久精品视频在线看15 | av人摸人人人澡人人超碰下载 | 中文字幕无线码 | 熟妇人妻中文av无码 | 人人妻在人人 | 色婷婷久久一区二区三区麻豆 | 亚洲色偷偷男人的天堂 | 亚洲狠狠色丁香婷婷综合 | 精品aⅴ一区二区三区 | 性色欲网站人妻丰满中文久久不卡 | 久久久久久国产精品无码下载 | 国产精品久久久久影院嫩草 | 亚洲精品一区二区三区四区五区 | 亚洲 日韩 欧美 成人 在线观看 | 青青久在线视频免费观看 | 午夜理论片yy44880影院 | 好爽又高潮了毛片免费下载 | 野狼第一精品社区 | 日韩人妻系列无码专区 | 国产无遮挡又黄又爽免费视频 | 日韩成人一区二区三区在线观看 | 国产激情无码一区二区 | 亚拍精品一区二区三区探花 | 大乳丰满人妻中文字幕日本 | 永久免费观看美女裸体的网站 | 欧美日韩亚洲国产精品 | 天天躁日日躁狠狠躁免费麻豆 | 久久亚洲中文字幕精品一区 | 欧美性生交活xxxxxdddd | 成人精品一区二区三区中文字幕 | 国产精品久久国产三级国 | 天天躁夜夜躁狠狠是什么心态 | 亚洲成av人影院在线观看 | 无码吃奶揉捏奶头高潮视频 | 无码吃奶揉捏奶头高潮视频 | 5858s亚洲色大成网站www | 麻豆人妻少妇精品无码专区 | 免费无码的av片在线观看 | 亚洲爆乳精品无码一区二区三区 | 东京热无码av男人的天堂 | 久久久成人毛片无码 | 精品久久综合1区2区3区激情 | 国产精品99爱免费视频 | 俺去俺来也www色官网 | 一本一道久久综合久久 | 女人被爽到呻吟gif动态图视看 | 牲欲强的熟妇农村老妇女视频 | 97精品人妻一区二区三区香蕉 | 精品无人国产偷自产在线 | 亚洲乱码中文字幕在线 | 无码人妻黑人中文字幕 | 四十如虎的丰满熟妇啪啪 | 中国女人内谢69xxxxxa片 | 国产婷婷色一区二区三区在线 | 亚洲欧美中文字幕5发布 | 国产人妻精品一区二区三区 | 午夜熟女插插xx免费视频 | 国产内射老熟女aaaa | 国产区女主播在线观看 | 欧美性猛交xxxx富婆 | 亚洲 欧美 激情 小说 另类 | 又大又紧又粉嫩18p少妇 | 亚洲欧美国产精品专区久久 | 欧美阿v高清资源不卡在线播放 | 亚洲国产精品一区二区第一页 | 国产绳艺sm调教室论坛 | 国产午夜视频在线观看 | 亚洲综合伊人久久大杳蕉 | 又色又爽又黄的美女裸体网站 | 无码国模国产在线观看 | 一本久久伊人热热精品中文字幕 | 免费观看激色视频网站 | 国产精品美女久久久久av爽李琼 | 97夜夜澡人人双人人人喊 | 国产av久久久久精东av | 久久精品中文闷骚内射 | 少妇无码av无码专区在线观看 | 老司机亚洲精品影院无码 | 人妻尝试又大又粗久久 | 久久精品中文闷骚内射 | 亚洲成在人网站无码天堂 | 未满成年国产在线观看 | 樱花草在线社区www | 免费网站看v片在线18禁无码 | 欧洲美熟女乱又伦 | 日本熟妇人妻xxxxx人hd | 国产真实乱对白精彩久久 | 骚片av蜜桃精品一区 | 性生交片免费无码看人 | 日日躁夜夜躁狠狠躁 | 蜜桃视频插满18在线观看 | 永久免费观看国产裸体美女 | 日产精品99久久久久久 | 日产精品高潮呻吟av久久 | 国产黄在线观看免费观看不卡 | 九九在线中文字幕无码 | 久青草影院在线观看国产 | 鲁鲁鲁爽爽爽在线视频观看 | 无码人妻精品一区二区三区下载 | 精品水蜜桃久久久久久久 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产香蕉尹人综合在线观看 | 狠狠色色综合网站 | 色一情一乱一伦一视频免费看 | 天天拍夜夜添久久精品大 | 精品久久久无码中文字幕 | 亚洲日韩av片在线观看 | 蜜桃av抽搐高潮一区二区 | 丰满少妇高潮惨叫视频 | 无码精品国产va在线观看dvd | 成人动漫在线观看 | 国内精品九九久久久精品 | 亚洲一区av无码专区在线观看 | 狠狠综合久久久久综合网 | 欧美xxxx黑人又粗又长 | 亚洲人成无码网www | 奇米影视7777久久精品 | 国产欧美熟妇另类久久久 | 国产又爽又猛又粗的视频a片 | 久久综合网欧美色妞网 | 久久无码人妻影院 | 国产午夜精品一区二区三区嫩草 | 97色伦图片97综合影院 | 女人和拘做爰正片视频 | 思思久久99热只有频精品66 | 亚洲人成网站色7799 | 成人av无码一区二区三区 | 中文字幕av日韩精品一区二区 | 无遮无挡爽爽免费视频 | a片免费视频在线观看 | 无码av最新清无码专区吞精 | 精品国产一区二区三区四区 | 国产肉丝袜在线观看 | 欧美亚洲国产一区二区三区 | 精品国产一区二区三区四区 | 欧美xxxx黑人又粗又长 | www一区二区www免费 | www国产亚洲精品久久网站 | 影音先锋中文字幕无码 | 国产亚洲精品久久久闺蜜 | 精品偷拍一区二区三区在线看 | 久久久久成人片免费观看蜜芽 | 人妻中文无码久热丝袜 | 免费观看又污又黄的网站 | 久久 国产 尿 小便 嘘嘘 | 中国女人内谢69xxxxxa片 | 亚洲欧美日韩综合久久久 | 任你躁在线精品免费 | 男人扒开女人内裤强吻桶进去 | 一本一道久久综合久久 | 国产热a欧美热a在线视频 | 亚洲欧美中文字幕5发布 | 日欧一片内射va在线影院 | 99国产欧美久久久精品 | 中文字幕 人妻熟女 | 亚洲小说春色综合另类 | 亚洲中文字幕无码一久久区 | 日本乱偷人妻中文字幕 | 麻豆精产国品 | 熟女体下毛毛黑森林 | 波多野结衣 黑人 | 中文字幕无码乱人伦 | 成人影院yy111111在线观看 | 麻豆国产97在线 | 欧洲 | 中文字幕亚洲情99在线 | 亚洲乱码中文字幕在线 | 亚洲欧美日韩国产精品一区二区 | 99久久精品无码一区二区毛片 | 无套内谢的新婚少妇国语播放 | 曰韩无码二三区中文字幕 | 久久精品一区二区三区四区 | 人妻尝试又大又粗久久 | 两性色午夜免费视频 | 大屁股大乳丰满人妻 | 激情五月综合色婷婷一区二区 | 国产激情艳情在线看视频 | 99精品国产综合久久久久五月天 | 亚洲a无码综合a国产av中文 | 亚洲熟妇色xxxxx欧美老妇 | 蜜桃视频插满18在线观看 | 一本加勒比波多野结衣 | 动漫av一区二区在线观看 | 荫蒂添的好舒服视频囗交 | 无码av中文字幕免费放 | 久激情内射婷内射蜜桃人妖 | 国产熟女一区二区三区四区五区 | 国产精品18久久久久久麻辣 | 色综合视频一区二区三区 | 国产一区二区三区四区五区加勒比 | 一区二区三区乱码在线 | 欧洲 | 亚洲成av人综合在线观看 | 国产成人无码av片在线观看不卡 | 蜜臀av在线播放 久久综合激激的五月天 | 人妻少妇精品久久 | 国产美女极度色诱视频www | 在线观看免费人成视频 | 一本加勒比波多野结衣 | 日本丰满熟妇videos | 风流少妇按摩来高潮 | 色综合久久久久综合一本到桃花网 | 一二三四社区在线中文视频 | 丰满人妻精品国产99aⅴ | 国产精品人人妻人人爽 | 亚洲欧美中文字幕5发布 | 成人综合网亚洲伊人 | 国产亚洲欧美日韩亚洲中文色 | 国产成人综合色在线观看网站 | ass日本丰满熟妇pics | 人人爽人人澡人人人妻 | 又色又爽又黄的美女裸体网站 | 无码国产乱人伦偷精品视频 | 鲁大师影院在线观看 | 俺去俺来也www色官网 | 成人影院yy111111在线观看 | 任你躁国产自任一区二区三区 | 无码人妻黑人中文字幕 | 亚洲啪av永久无码精品放毛片 | 久久久久免费看成人影片 | 日韩精品无码一本二本三本色 | 亚洲自偷自拍另类第1页 | 欧美zoozzooz性欧美 | 无码毛片视频一区二区本码 | 国内精品久久久久久中文字幕 | 7777奇米四色成人眼影 | 亚洲一区二区三区在线观看网站 | 亚洲成av人在线观看网址 | 国产人妖乱国产精品人妖 | 免费视频欧美无人区码 | 特黄特色大片免费播放器图片 | av在线亚洲欧洲日产一区二区 | 人人超人人超碰超国产 | 国产亚洲人成在线播放 | 人妻互换免费中文字幕 | 亚洲日韩乱码中文无码蜜桃臀网站 | 少妇人妻偷人精品无码视频 | 我要看www免费看插插视频 | 亚洲男人av香蕉爽爽爽爽 | 无码精品国产va在线观看dvd | 亚洲熟熟妇xxxx | 亚洲精品一区二区三区在线观看 | 久久久久国色av免费观看性色 | aa片在线观看视频在线播放 | 国产精品久久国产精品99 | 成 人影片 免费观看 | 午夜熟女插插xx免费视频 | 性色欲情网站iwww九文堂 | 国产精品国产三级国产专播 | 亚洲一区二区三区偷拍女厕 | 国产人妻大战黑人第1集 | 久久精品女人天堂av免费观看 | 日产国产精品亚洲系列 | 秋霞特色aa大片 | 少妇人妻av毛片在线看 | 亚洲国产精品毛片av不卡在线 | 丰满少妇熟乱xxxxx视频 | 中文字幕精品av一区二区五区 | 亚洲精品国产精品乱码视色 | 午夜精品久久久久久久久 | 成人动漫在线观看 | 日本va欧美va欧美va精品 | 欧美日韩在线亚洲综合国产人 | 精品亚洲成av人在线观看 | 性生交片免费无码看人 | 一本久久a久久精品亚洲 | 丰满少妇人妻久久久久久 | 十八禁视频网站在线观看 | 色综合久久久久综合一本到桃花网 | 国产精品18久久久久久麻辣 | 少妇激情av一区二区 | 久久这里只有精品视频9 | 国产无av码在线观看 | 无码中文字幕色专区 | 日本护士xxxxhd少妇 | 97夜夜澡人人爽人人喊中国片 | 伊人久久大香线焦av综合影院 | 国产成人综合在线女婷五月99播放 | 精品亚洲成av人在线观看 | 色综合久久中文娱乐网 | 97久久精品无码一区二区 | 中文字幕无码免费久久99 | 在线天堂新版最新版在线8 | 东京热男人av天堂 | 国产亚洲美女精品久久久2020 | 国产亚av手机在线观看 | 性欧美牲交在线视频 | 国产成人精品久久亚洲高清不卡 | 美女毛片一区二区三区四区 | 色诱久久久久综合网ywww | 久久久久成人精品免费播放动漫 | 乱人伦中文视频在线观看 | 久久精品99久久香蕉国产色戒 | 野狼第一精品社区 | 亚洲色www成人永久网址 | 久久久久久久久蜜桃 | 久久久精品456亚洲影院 | 欧美高清在线精品一区 | 正在播放老肥熟妇露脸 | 国产精品免费大片 | 少妇人妻av毛片在线看 | 国产精品亚洲一区二区三区喷水 | 高潮毛片无遮挡高清免费视频 | 扒开双腿吃奶呻吟做受视频 | 人人妻人人澡人人爽人人精品 | 亚洲精品久久久久中文第一幕 | 国产超碰人人爽人人做人人添 | 青青久在线视频免费观看 | 欧美freesex黑人又粗又大 | 国产亚洲人成在线播放 | 又大又硬又爽免费视频 | 亚洲无人区一区二区三区 | 精品国产乱码久久久久乱码 | 蜜桃臀无码内射一区二区三区 | 激情爆乳一区二区三区 | 亚洲码国产精品高潮在线 | 国产超级va在线观看视频 | 国产成人精品优优av | а天堂中文在线官网 | 欧美性黑人极品hd | 欧美丰满少妇xxxx性 | 波多野结衣aⅴ在线 | 国产精品永久免费视频 | 无码帝国www无码专区色综合 | 最新版天堂资源中文官网 | 日日躁夜夜躁狠狠躁 | 久久亚洲国产成人精品性色 | 乱中年女人伦av三区 | 欧美成人家庭影院 | 狠狠色噜噜狠狠狠7777奇米 | 日本护士毛茸茸高潮 | 久久亚洲精品成人无码 | 国产乱码精品一品二品 | 午夜精品久久久久久久 | 国产成人人人97超碰超爽8 | 日韩精品久久久肉伦网站 | 在线亚洲高清揄拍自拍一品区 | 少妇被黑人到高潮喷出白浆 | 老太婆性杂交欧美肥老太 | 国产农村妇女高潮大叫 | 99riav国产精品视频 | 国产av剧情md精品麻豆 | 人人爽人人澡人人人妻 | 狠狠躁日日躁夜夜躁2020 | 欧美黑人巨大xxxxx | 国内精品人妻无码久久久影院 | 日本精品人妻无码免费大全 | 男女下面进入的视频免费午夜 | 动漫av一区二区在线观看 | 国产在线一区二区三区四区五区 | 色综合久久久无码中文字幕 | 成熟妇人a片免费看网站 | 欧美性猛交xxxx富婆 | 久久综合给久久狠狠97色 | 国产性生交xxxxx无码 | 色老头在线一区二区三区 | 亚洲中文字幕成人无码 | 性欧美疯狂xxxxbbbb | 综合激情五月综合激情五月激情1 | 久久精品女人的天堂av | 国内精品久久久久久中文字幕 | 1000部夫妻午夜免费 | 国产精品久久久久无码av色戒 | 麻豆md0077饥渴少妇 | 亚洲色偷偷偷综合网 | 久久人人爽人人爽人人片ⅴ | 无套内射视频囯产 | 久久无码中文字幕免费影院蜜桃 | 牲欲强的熟妇农村老妇女 | 熟妇人妻无码xxx视频 | 在线视频网站www色 | 午夜男女很黄的视频 | 无码任你躁久久久久久久 | 国产在线精品一区二区三区直播 | 伊人久久大香线焦av综合影院 | 久久久久国色av免费观看性色 | 久久久久99精品成人片 | 欧美精品在线观看 | 奇米影视7777久久精品 | 亚洲国产精品一区二区美利坚 | 88国产精品欧美一区二区三区 | 强奷人妻日本中文字幕 | 欧美精品国产综合久久 | 激情综合激情五月俺也去 | 久久久久久久久888 | 午夜男女很黄的视频 | 亚洲国产午夜精品理论片 | 免费播放一区二区三区 | 最新版天堂资源中文官网 | 一本久久a久久精品vr综合 | 精品乱码久久久久久久 | 久久国产精品二国产精品 | 老司机亚洲精品影院无码 | 精品成人av一区二区三区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 玩弄人妻少妇500系列视频 | 伊人色综合久久天天小片 | 荡女精品导航 | 久久精品无码一区二区三区 | 亚洲最大成人网站 | 亲嘴扒胸摸屁股激烈网站 | 日本精品少妇一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 少妇无码av无码专区在线观看 | 成人无码精品1区2区3区免费看 | 一本色道婷婷久久欧美 | 久久久中文久久久无码 | 亚洲无人区午夜福利码高清完整版 | 老司机亚洲精品影院 | 久久久久成人精品免费播放动漫 | 激情内射亚州一区二区三区爱妻 | 亚洲国产精品一区二区第一页 | 久久久婷婷五月亚洲97号色 | 亚洲欧美日韩综合久久久 | 久久久久久a亚洲欧洲av冫 | 成人欧美一区二区三区 | 牲欲强的熟妇农村老妇女视频 | 日本精品人妻无码免费大全 | 蜜桃视频插满18在线观看 | 未满小14洗澡无码视频网站 | 人妻少妇精品无码专区动漫 | 美女毛片一区二区三区四区 | 亚洲区欧美区综合区自拍区 | 久久精品国产99久久6动漫 | 成人aaa片一区国产精品 | 日韩少妇内射免费播放 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲乱码国产乱码精品精 | 97精品国产97久久久久久免费 | а√天堂www在线天堂小说 | 国产后入清纯学生妹 | 欧美日韩综合一区二区三区 | 亚洲男人av香蕉爽爽爽爽 | 乱人伦人妻中文字幕无码久久网 | 两性色午夜视频免费播放 | 亚洲日韩av一区二区三区四区 | 免费观看激色视频网站 | 久久aⅴ免费观看 | 玩弄少妇高潮ⅹxxxyw | 最新版天堂资源中文官网 | 人妻aⅴ无码一区二区三区 | 久久久久久久人妻无码中文字幕爆 | 人妻少妇精品视频专区 | 中文字幕av日韩精品一区二区 | 扒开双腿疯狂进出爽爽爽视频 | 久久久av男人的天堂 | 精品少妇爆乳无码av无码专区 | 亚洲一区二区三区国产精华液 | 鲁一鲁av2019在线 | 亚洲热妇无码av在线播放 | 日韩在线不卡免费视频一区 | 国产av久久久久精东av | 免费网站看v片在线18禁无码 | 精品国产aⅴ无码一区二区 | 在线播放无码字幕亚洲 | 男女爱爱好爽视频免费看 | 国产精品永久免费视频 | 国产色xx群视频射精 | 久久国产精品偷任你爽任你 | 精品熟女少妇av免费观看 | 国产精品自产拍在线观看 | 人人妻人人澡人人爽精品欧美 | 亚洲人亚洲人成电影网站色 | 一本加勒比波多野结衣 | 国产精品igao视频网 | 天堂久久天堂av色综合 | 久久精品成人欧美大片 | 亚洲精品一区三区三区在线观看 | 国产极品美女高潮无套在线观看 | 九月婷婷人人澡人人添人人爽 | 久久久精品成人免费观看 | 精品国产成人一区二区三区 | 极品嫩模高潮叫床 | 国内少妇偷人精品视频免费 | 中文字幕 人妻熟女 | 欧美黑人性暴力猛交喷水 | 人人妻人人澡人人爽欧美一区 | 乱人伦人妻中文字幕无码 | 4hu四虎永久在线观看 | 高清无码午夜福利视频 | 亚洲 欧美 激情 小说 另类 | 最新版天堂资源中文官网 | 女人被爽到呻吟gif动态图视看 | 久久久亚洲欧洲日产国码αv | 国产黄在线观看免费观看不卡 | 国产av无码专区亚洲a∨毛片 | 亚洲中文字幕在线无码一区二区 | 国产av无码专区亚洲awww | 免费无码一区二区三区蜜桃大 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 老司机亚洲精品影院无码 | 好男人社区资源 | 国产手机在线αⅴ片无码观看 | 久久久亚洲欧洲日产国码αv | 亚无码乱人伦一区二区 | 55夜色66夜色国产精品视频 | 国产真实伦对白全集 | 无遮挡国产高潮视频免费观看 | 久热国产vs视频在线观看 | 丰满少妇熟乱xxxxx视频 | 国产av人人夜夜澡人人爽麻豆 | 欧美熟妇另类久久久久久不卡 | 2020久久香蕉国产线看观看 | 青青草原综合久久大伊人精品 | 精品国产成人一区二区三区 | 内射老妇bbwx0c0ck | 精品欧美一区二区三区久久久 | 少妇无码av无码专区在线观看 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲七七久久桃花影院 | 国产在线一区二区三区四区五区 | 中国女人内谢69xxxx | 午夜男女很黄的视频 | 98国产精品综合一区二区三区 | 麻豆人妻少妇精品无码专区 | 婷婷六月久久综合丁香 | 久久久久久a亚洲欧洲av冫 | 熟妇人妻中文av无码 | 国内精品人妻无码久久久影院蜜桃 | 成年美女黄网站色大免费视频 | 日日碰狠狠丁香久燥 | 中国大陆精品视频xxxx | 熟妇人妻中文av无码 | 欧美丰满熟妇xxxx | 欧美丰满少妇xxxx性 | 亚洲综合精品香蕉久久网 | 免费人成在线观看网站 | 亚洲人交乣女bbw | 无码一区二区三区在线 | 国产一区二区不卡老阿姨 | 荫蒂被男人添的好舒服爽免费视频 | 国产亚洲精品久久久久久 | 牲欲强的熟妇农村老妇女 | 国产人妻大战黑人第1集 | 蜜桃臀无码内射一区二区三区 | 亚洲熟女一区二区三区 | 久久www免费人成人片 | 国语自产偷拍精品视频偷 | 最新国产麻豆aⅴ精品无码 | 日韩成人一区二区三区在线观看 | 色综合久久久无码中文字幕 | 久久天天躁狠狠躁夜夜免费观看 | 久久人人97超碰a片精品 | 久久五月精品中文字幕 | 日本高清一区免费中文视频 | 国产精品多人p群无码 | 欧美午夜特黄aaaaaa片 | 国产无套粉嫩白浆在线 | 国产人成高清在线视频99最全资源 | 蜜桃视频韩日免费播放 | 久久久久久国产精品无码下载 | 日韩欧美中文字幕在线三区 | 中文字幕日产无线码一区 | 精品久久8x国产免费观看 | 97精品国产97久久久久久免费 | 日本免费一区二区三区最新 | 无码人妻丰满熟妇区毛片18 | 欧美精品国产综合久久 | 国产福利视频一区二区 | 西西人体www44rt大胆高清 | 国产两女互慰高潮视频在线观看 | 动漫av一区二区在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 精品国偷自产在线视频 | 国产又爽又黄又刺激的视频 | 国产精品va在线观看无码 | 亚洲码国产精品高潮在线 | 兔费看少妇性l交大片免费 | 国产香蕉尹人视频在线 | 国产精品内射视频免费 | 乱码av麻豆丝袜熟女系列 | 99久久精品国产一区二区蜜芽 | 99久久人妻精品免费二区 | 18禁止看的免费污网站 | 无码任你躁久久久久久久 |