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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

常用的十种算法

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

二分查找算法

  • 前面我們講過了二分查找算法,使用遞歸的方式,下面我們講解二分查找算法的非遞歸方式
  • 二分查找法只適用于從有序的數列種進行查找(比如數字和字母等),將熟練排序后再進行查找
  • 二分查找法的運行時間為對數時間O(log2n),即查找到需要的目標位置最多只需要log2n步。假設從[0,99]的隊列(100個數,即n=100)種尋找目標數30,則需要查找步數log2100,即最多需要查找7次(26<100<27

遞歸方式

public class BinarySearch {public static void main(String[] args) {int arr[] = {1,8,10,89,1000,1000,1000,1234};int findVal = 1000;int val = binarySearch(arr,0,arr.length-1,findVal);System.out.println(val);System.out.println("---------優化后的值------------");ArrayList<Integer> list = binarySearchBetter(arr,0,arr.length-1,findVal);System.out.println(list);}/*** 該情況找到就返回 只適合一個的情況* @param arr* @param left* @param right* @param findVal* @return*/private static int binarySearch(int[] arr, int left, int right, int findVal) {int midIndex =(left+right)/2;//沒找到值if(left>right){System.out.println("沒有找到");return -1;}if(findVal>arr[midIndex]){//右遞歸return binarySearch(arr,midIndex+1,right,findVal);}else if(findVal<arr[midIndex]){//左遞歸return binarySearch(arr,left,midIndex-1,findVal);}else{System.out.println("index = "+midIndex);return arr[midIndex];}}/*** 找到后并不立即返回 而是創建數組 判斷左右相鄰的值是否也相等* @param arr* @param left* @param right* @param findVal* @return*/private static ArrayList<Integer> binarySearchBetter(int[] arr, int left, int right, int findVal) {ArrayList<Integer> list = new ArrayList<>();int midIndex =(left+right)/2;//沒找到值if(left>right){System.out.println("沒有找到");list.add(-1);return list;}if(findVal>arr[midIndex]){//右遞歸return binarySearchBetter(arr,midIndex+1,right,findVal);}else if(findVal<arr[midIndex]){//左遞歸return binarySearchBetter(arr,left,midIndex-1,findVal);}else{list.add(arr[midIndex]);System.out.println("index = "+midIndex);//判斷左邊值是否相等int index = midIndex;while(findVal==arr[index-=1]){System.out.println("index = "+index);list.add(arr[index]);}//判斷右邊值是否相等index = midIndex;while(findVal==arr[index+=1]){System.out.println("index = "+index);list.add(arr[index]);}return list;}} }

非遞歸方式

public class BinarySearch {public static void main(String[] args) {int[] arr = {1,2,3,4,5,8,27,33};int target = 27;int index = binarySearch(arr,target);System.out.println("arr["+index+"] = "+arr[index]);}//二分查找非遞歸實現private static int binarySearch(int[] arr, int target) {int left = 0;int right = arr.length-1;while(left<=right){int mid = (left+right)/2;if(arr[mid]==target){return mid;}else if(arr[mid]>target){right = mid - 1;}else{left = mid + 1;}}return -1;} }

信息打印

分治算法

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

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

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

分治算法的基本步驟
分治發在每一層遞歸上都有三個步驟

  • 分解:將原問題分解為若干個規模較小,相互獨立,與原問題形式相同的子問題
  • 解決:若子問題規模較小而容易被解決則直接解決,否則遞歸第解決各個子問題
  • 合并:將各個子問題的解合并為原問題的解

分治(divide-and-conquer)算法設計模式如下:

if|P|<=n0 then return(ADHOC(P)) //將P分解為較小的子問題P1 P2...Pk for i <- 1 to k do y1 <- divide-and-conquer(Pi) 遞歸解決Pi T <- Merge (y1,y2...yk) 合并子問題 return T

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

分治算法實踐-漢諾塔

漢諾塔的傳說
漢諾塔又稱河內塔 問題是源于印度一個古老傳說的益智玩具。大梵天創造世界的時候做了三個金剛石柱子,在一根柱子上從下往上按照大小順序裸著64片黃金圓盤。大梵天命令婆羅門把圓盤從下面開始按照大小順便重新擺放在另一根柱子上。并且規定在小圓盤上不能放大圓盤,在三根柱子之間一次只能移動一個圓盤。
假如沒一秒鐘一次,共需要多長時間呢?移完這些金片需要5845.54億年以上,太陽系的預期壽命據說也就是數百億年,真的過了5845.54億年,地球上的一切生命連同梵塔,廟宇等,都早已灰飛煙滅。

漢諾塔演示過程:
如果一個盤子 A->C
如果我們有n>=2情況,
我們總是可以看做是兩個盤 1 最下邊的盤 2上面的盤
先把最上面的盤 A->B
把最下邊的盤 A->C
把B塔的所有盤 從B->C

代碼實習

public class DACHannoiTower {public static void main(String[] args) {hannoiTower(5,"S","T","D");}/*** 分治算法 處理漢諾塔* @param num 金片數量* @param A S 開始位置* @param B T 中轉位置* @param C D 目的地*/private static void hannoiTower(int num, String A, String B, String C) {if(num == 1){System.out.println("第1塊從"+A+"->"+C);}else{//分為個盤子 1 最下面的一個盤子 2最上面的其他盤子看做一個// 先把最上面的盤 A->B 過程中會先放到ChannoiTower(num-1,A,C,B);//把最下邊的盤 A->CSystem.out.println("第"+num+"塊從"+A+"->"+C);//把B塔的所有盤 從B->C 過程中會先放到AhannoiTower(num-1,B,A,C);}} }

信息打印

動態規劃算法

動態規劃算法介紹

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

應用場景-背包問題

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

  • 要求達到目標為裝入背包的總價值最大,并且重量不超出
  • 要求裝入的物品不能重復
物品重量價格
吉他(G)11500
音響(S)43000
電腦(L)32000

思路分析和圖解
背包問題主要是指一個給定容量的背包,若干具有一定價值和重量的物品,如何選擇物品放入背包使物品的價值最大。其中又分01背包和完全背包(完全背包指的是:每種物品都有無限件可用)這里的問題屬于01背包,即每個物品最多放一個。而無限背包可用轉化為01背包。

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

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

代碼實現

public class DynamicKnapsackProblem {public static void main(String[] args) {int[] w = {1,4,3};//每件物品的重量int[] val = {1500,3000,2000};// 物品的價格int c = 4;//背包的容量int n = w.length;//物品的個數//創建二維數組 v[i][j] 表示在前i個物品中能夠裝入容量為j的背包中的最大值int[][] v = new int[n+1][c+1];//初始化第一行 和第一列的數據 在本案例中可以不用處理,因為默認就是0for (int i = 0; i < v.length; i++) {v[i][0]=0;}for (int i = 0; i < v[0].length; i++) {v[0][i]=0;}// 根據前面的公式來動態規劃處理for (int i = 1; i < v.length; i++) {// 不處理第一行for (int j = 1; j < v[0].length; j++) {// 不處理第一列if(w[i-1]>j){v[i][j]=v[i-1][j];}else{v[i][j]=Math.max(v[i-1][j],val[i-1]+v[i-1][j-w[i-1]]);}}}for (int i = 0; i < v.length; i++) {System.out.println(Arrays.toString(v[i]));}} }

信息打印

以上代碼并不完全,因為并不知道裝入了什么;還需要優化處理

整體代碼

public class DynamicKnapsackProblem {public static void main(String[] args) {int[] w = {1,4,3};//每件物品的重量int[] val = {1500,3000,2000};// 物品的價格int c = 4;//背包的容量int n = w.length;//物品的個數//創建二維數組 v[i][j] 表示在前i個物品中能夠裝入容量為j的背包中的最大值int[][] v = new int[n+1][c+1];//創建二維數組 記錄存放路徑int[][] path = new int[n+1][c+1];//初始化第一行 和第一列的數據 在本案例中可以不用處理,因為默認就是0for (int i = 0; i < v.length; i++) {v[i][0]=0;}for (int i = 0; i < v[0].length; i++) {v[0][i]=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開始的所有需要減一 -1 以保證 從數組第一個值開始取值v[i][j]=v[i-1][j];}else{//v[i][j]=Math.max(v[i-1][j],val[i-1]+v[i-1][j-w[i-1]]);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]];path[i][j]=1;//修改路徑的值}else{v[i][j] = v[i-1][j];}}}}for (int i = 0; i < v.length; i++) {System.out.println(Arrays.toString(v[i]));}System.out.println("--------------");for (int i = 0; i < v.length; i++) {System.out.println(Arrays.toString(path[i]));}for (int i = 0; i < path.length; i++) {for (int j = 0; j < path[0].length; j++) {if(path[i][j]==1){System.out.println("第"+i+"個商品放入背包");}}}System.out.println("--------------");int i = path.length-1; //行的最大下標int j = path[0].length-1;//列的最大下標while(i>0&&j>0){ //逆向遍歷if(path[i][j]==1){System.out.println("第"+i+"個商品放入背包");j -= w[i-1]; //背包減去容量}i--;}} }

信息打印

KMP算法

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

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

暴力匹配法

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

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

代碼實現

public class KMPViolenceMatch {public static void main(String[] args) {String str1 = "BBC ABCDABABC DABCDABDE";String str2 = "ABCDABD";int index = violenceMatch(str1,str2);System.out.println("匹配的起始位置:"+index);}private static int violenceMatch(String str1, String str2) {char[] source = str1.toCharArray();char[] target = str2.toCharArray();int i = 0; //char1的下標int j = 0; //char2的下標//確保數組不越界while (i<source.length&&j<target.length){if(target[j]==source[i]){i++;//字符串數組往后移動j++;}else{i = i-j+1; // 如果有匹配過 但沒完全匹配上 i歸位從剛進入的下一個節點開始j = 0; // j 需要從第一個位置開始重新匹配}}if(j==target.length){return i-target.length;}return -1;} }

KMP算法介紹

  • Kunth-Morris-Pratt 字符串查找算法,簡稱"KMP算法",常用于在一個文本串中查找一個模式串的出現位置,這個算法由
  • KMP是一個解決模式串在文本串是否出現過,如果出現過,最早出現的位置經典算法Kunth、Morris及Pratt三個人于1977年聯合發表,故用這個方式命名算法
  • KMP 方法就利用了之前判斷過信息,通過一個next數組,保存模式串中前后最長公共子序列的長度,每次回溯時,通過next數組找到,前面匹配過的位置,省去了大量的計算時間
  • 參考資料:

字符串匹配問題:

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

思路分析圖解

  • 1.首先,用str1的第一個字符串和str2的第一個字符去比較,不符合,關鍵詞向后移動一位
  • 2。重復第一步,還是不符合,在移
  • 3.一直重復,知道str1有一個字符與str2的第一個字符符合為止
  • 4.接著比較字符串和搜索詞的下一個字符,還是符合。
  • 5.遇見str1有一個字符與str2對應的字符不符合
  • 6.這時,想到的是繼續遍歷str1的下一個字符,重復第1步。(其實是很不明智的,因為此時BCD已經比較過了,沒必要在做重復的工作,一個基本事實是,當空格與D不匹配時,你其實知道前面六個字符是“ABCDAB”。KMP算法的想法是,設法利用這個已知信息,不要把“搜索位置”一回到已經比較過的位置,繼續把它向后移,這樣就提高了效率。)
  • 7.怎么做到把剛剛重復的步驟省略掉?可以懟str2計算出一張《部分匹配表》,這張表的產生后面會介紹
  • 8.已知空格與D不匹配時,前面六個字符“ABCDAB”是匹配的。查表可知,最后一個匹配字符B對應的“部分匹配值”為2,因此按照下面的公司算出向后移動的位數:
    == 移動位數 = 已匹配的字符數 - 對應的部分匹配值==
    因為6 - 2 = 4 ,所有將搜索詞向后移動4位
  • 9.因為空格與C不匹配,搜索詞還要繼續往后移。這時,已匹配的字符數為2(“AB”),對應的“部分匹配值”為0;所以,移動位數 =2-0=2,于是將搜索詞向后移動2位。
  • 10.因為空格與A不匹配,繼續后移一位。
  • 11.逐位比較,直到發現C與D不匹配,繼續將搜索詞先后移動4位
  • 12.逐位比較,直到搜索詞最后一位,發現完全匹配,于是搜索完成。如果還要繼續搜索(即找出全部匹配),移動位數=7-0,再將搜索詞向后移動7位,這里就不在重復了。
  • 13.介紹《部分匹配表》怎么產生的
    先介紹前綴,后綴是什么
    字符串: “bread”
    前綴: b br bre brea
    后綴: read ead ad d

    “部分匹配值”就是“前綴”和“后綴”的最長的共有元素的長度。以“ABCDABD”為列:
1 “A”的前綴和后綴都為空集,共有元素的長度為0;2 “AB”的前綴為[A]和后綴為[B],共有元素的長度為0;3 “ABC”的前綴為[A AB]和后綴為[BC C],共有元素的長度為0;4 “ABCD”的前綴為[A AB ABC]和后綴為[BCD CD D],共有元素的長度為0;5 “ABCDA”的前綴為[A AB ABC ABCD]和后綴為[BCDA CDA DA A],共有元素的長度為1;6 “ABCDAB”的前綴為[A AB ABC ABCD ABCDA]和后綴為[BCDAB CDAB DAB AB B],共有元素的長度為2;7 “ABCDABD”的前綴為[A AB ABC ABCD ABCDA ABCDAB]和后綴為[BCDABD CDABD DABD ABD BD D],共有元素的長度為0;
  • 14.“部分匹配”的實質是,有時候,字符串頭部和尾部會有重復。比如:“ABCDAB”之中有兩個“AB”,那么他的“部分匹配”就是2(“AB的長度”)。搜索詞移動的時候,第一個“AB”向后移動4位(字符串長度-部分匹配值),就可以來到第二個“AB”的位置

    到此KMP算法思想分析完畢!

代碼實現

public class KMPMatch {public static void main(String[] args) {String str1 = "BBC ABCDABABC DABCDABDE";String str2 = "ABCDABD";int[] next = KMPMatch(str2);System.out.println("部分匹配表:"+ Arrays.toString(next));int index = KMPSearch(str1,str2,next);System.out.println("匹配到的起始索引:"+index);}private 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;}}return -1;}private static int[] KMPMatch(String str2) {int[] next = new int[str2.length()];//i 從1開始 因為判斷的是從第二個字符串開始 與前面是否相同for (int i = 1,j = 0; i <str2.length(); i++) {// 當str.charAt(i) != str.charAt(j) 需要從next[j - 1]獲取新得節點// 直到發現有str.charAt(i) == str.charAt(j)成立時推出// KMP算法的核心while(j>0&&str2.charAt(i)!=str2.charAt(j)){j = next[j-1];}// 滿足str.charAt(i) == str.charAt(j)條件時 部分匹配值 + 1if(str2.charAt(i)==str2.charAt(j)){j++;}next[i]=j;}return next;} }

信息打印

貪心算法

貪心算法介紹

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

應用場景-集合覆蓋問題

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

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

思路分析

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

廣播臺數量n子集總數2n需要的時間
5323.2秒
101024102.4秒
32429496729613.6年
1001.26*10034*1023

使用貪心算法,效率高:

  • 目前并沒有算法可以快速計算得到準備的值,使用貪心算法,則可以得到非常接近的解,并且效率高。選擇策略上,因為需要覆蓋全部地區的最小集合;
  • 遍歷所有的廣播臺,找到一個覆蓋了最多未覆蓋的地區的電臺(此電臺可能包含一些已覆蓋的地區,但沒有關系)
  • 將這個電臺加入到一個集合中(比如ArrayList),想辦法把該電臺覆蓋的地區在下次比較時去掉。
  • 重復第一步知道覆蓋了全部地區

代碼實現

public class GreedyAlgorithm {public static void main(String[] args) {Map<String, Set<String>> broadcast = new HashMap<>();Set<String> k1 = new HashSet<>();k1.add("北京");k1.add("上海");k1.add("天津");Set<String> k2 = new HashSet<>();k2.add("廣州");k2.add("上海");k2.add("深圳");Set<String> k3 = new HashSet<>();k3.add("成都");k3.add("上海");k3.add("杭州");Set<String> k4 = new HashSet<>();k4.add("上海");k4.add("天津");Set<String> k5 = new HashSet<>();k5.add("杭州");k5.add("大連");broadcast.put("k1",k1);broadcast.put("k2",k2);broadcast.put("k3",k3);broadcast.put("k4",k4);broadcast.put("k5",k5);Set<String> allArea = new HashSet<>();for (Map.Entry<String,Set<String>> entry:broadcast.entrySet()){allArea.addAll(entry.getValue());}System.out.println(allArea);//定義一個集合存儲需要選擇的電臺List<String> selects = new ArrayList<>();//定義一個臨時集合 取交集 判斷交集的大小Set<String> tempArea = new HashSet<>();//定義一個最大key的變量String maxKey = "";while(allArea.size()>0){//需要清空數據maxKey = "";for (String key:broadcast.keySet()){//需要清空臨時set元素tempArea.clear();//kn 不能直接用tempArea臨時集合結束 會清空集合Set<String> kn = broadcast.get(key);tempArea.addAll(kn);//將臨時set中的元素與所有地區的元素取交集并存放在tempArea中tempArea.retainAll(allArea);if(tempArea.size()>0&&("".equals(maxKey) || tempArea.size() > broadcast.get(key).size())){maxKey = key;}}if(!"".equals(maxKey)){selects.add(maxKey);//從所有集合中去掉已經選中的地區allArea.removeAll(broadcast.get(maxKey));}}System.out.println("選擇的電臺:"+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條邊連接即可,但是總里程不是最小的
    正確的思路,就是盡可能的選擇少的線路,并且每條路線最小,保證總里程數最少

最小生成樹

修路問題本質就是最小生成樹問題,先介紹一下最下生成樹(Min 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
  • 重復步驟②,直到U與V相等,即所有頂點都被標記為訪問過,此時D中有n-1條邊
  • 提示:單獨看步驟很難理解,我們通過代碼來講解,比較好理解

圖解普利姆算法

代碼實現

public class PrimAlgorithm {public static void main(String[] args) {char[] data = new char[]{'A','B','C','D','E','F','G'};int verxs = data.length;//鄰接矩陣的關系使用二維數組表示,10000 這個大數,表示兩個點不聯通int [][]weight=new int[][]{{10000,5,7,10000,10000,10000,2}, // A{5,10000,10000,9,10000,10000,3}, // B{7,10000,10000,10000,8,10000,10000}, // C{10000,9,10000,10000,10000,4,10000}, // D{10000,10000,8,10000,10000,5,4}, // E{10000,10000,10000,4,5,10000,6}, // F{2,3,10000,10000,4,6,10000}}; // GMGraph mGraph = new MGraph(verxs);MinTree minTree = new MinTree();minTree.createGraph(mGraph,verxs,data,weight);minTree.showGraph(mGraph);minTree.prim(mGraph,0);} }class MinTree{/**** @param mGraph 圖對象* @param verxs 圖的個數* @param data 圖的頂點值* @param weight 圖的鄰接矩陣*/public void createGraph(MGraph mGraph,int verxs,char[] data, int[][] weight){for (int i = 0; i < verxs; i++) {mGraph.data[i] = data[i];for (int j = 0; j < verxs; j++) {mGraph.wight[i][j] = weight[i][j];}}}public void showGraph(MGraph mGraph){for(int[] col:mGraph.wight){System.out.println(Arrays.toString(col));}}/**** @param mGraph 圖* @param v 表示從第幾個頂點開始生產 傳入0 表示從A 開始*/public void prim(MGraph mGraph, int v) {int[] visited = new int[mGraph.verxs];visited[v] = 1;//記錄兩個頂點的下標int h1 = -1; //開始位置int h2 = -1; //結束位置//記錄最小的權值int minWeight = 10000;for (int n = 1; n < mGraph.verxs; n++) {//大循環表示選擇多少條邊 有n個頂點 連接只需要n-1個邊 所有n 從1開始for (int i = 0; i < mGraph.verxs; i++) {// 表示被訪問過的for (int j = 0; j < mGraph.verxs; j++) {//表示為訪問的if(visited[i]==1&&visited[j]==0&&mGraph.wight[i][j]<minWeight){minWeight = mGraph.wight[i][j];h1=i;h2=j;}}}//找到一條邊System.out.println("<"+mGraph.data[h1]+","+mGraph.data[h2]+"> => "+minWeight);minWeight = 10000;visited[h2] = 1;}} }class MGraph{int verxs;char[] data;int[][] wight;public MGraph(int verxs){this.verxs = verxs;data = new char[verxs];wight = new int[verxs][verxs];} }

打印信息

克魯斯卡爾算法

應場景-公交站問題

看一個應用場景和問題

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

克魯斯卡爾算法介紹

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

克魯斯卡爾算法圖解說明

以城市公交問題來圖解說明 克魯斯卡爾算法原理與步驟
在含有n個頂點的聯調圖中選擇n-1條邊,構成一顆極小連通子圖,并使用該連通子圖中n-1條邊上權值之和達到最小,則稱其為連通網的最小生成樹。

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>的權值最小,將邊<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>

總結:
根據前面介紹的克魯斯卡爾算法介紹,我們了解到克魯斯卡爾需要解決2個問題:

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

舉例說明:

在將<E,F> <C,D> <D,E> 加入到最小生成樹R中之后,這幾天邊的頂點就都有了終點:
1 C的終點是F
2 D的終點是F
3 E的終點是F
4 F的終點是F

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

代碼實現

public class KruskalAlgoritm {private int[][] matrix;private char[] vertex;private int edgeNum;private static final int INF = Integer.MAX_VALUE;public static void main(String[] args) {char[] vertex = new char[]{'A','B','C','D','E','F','G'};//克魯斯卡爾算法的鄰接矩陣( 其實真正的有效值僅為一般 <AB><BA>是一樣的)int matrix[][] = { // 自己和自己為0/*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}};KruskalAlgoritm kruskal = new KruskalAlgoritm(vertex,matrix);kruskal.showMatrix();EData[] edgeData = kruskal.getEdgeData();System.out.println("未排序:"+Arrays.toString(edgeData));kruskal.sortEData(edgeData);System.out.println("已排序:"+Arrays.toString(edgeData));kruskal.kruskal(edgeData);}/*** 克魯斯卡爾算法* @param edgeData 傳入已經排序好的數組*/private void kruskal(EData[] edgeData) {int index = 0;// 最后結果數組的索引// 用于保存"已有最小生成數" 中的每個頂點 在最小生成數中的每個終點int[] ends = new int[edgeNum];//創建結果數組 保存最后的生成數EData[] res = new EData[vertex.length-1];// 遍歷edges 數組, 將邊添加到最小生成樹中, 判斷是準備加入的邊是否形成回路, 如果沒有 則加入resint p1;int p2;for (int i = 0; i < edgeNum; i++) {p1 =getPosition(edgeData[i].start); // 獲取到第i條邊的第一個頂點 (起點)p2 =getPosition(edgeData[i].end);// 獲取到第i條邊的第二個頂點 (終點)// 獲取 p1 這個頂點在已有的最小生成數中的終點是哪個int m = getEnd(ends,p1);int n = getEnd(ends,p2);// 判斷是否構成回路if(m!=n){ends[m]=n; // 設置m在"當前最小生成數" 中的終點為 nres[index++] = edgeData[i];}}System.out.println(Arrays.toString(res));}/*** 根據頂點獲取索引* @param ch* @return*/private int getPosition(char ch){for (int i = 0; i < vertex.length; i++) {if(vertex[i]==ch){return i;}}return -1;}/*個人理解判斷回路的方法還可以通過判斷是否訪問的節點來實現 如圖普利姆算法當中一樣 后期自己會嘗試實現看看*//*** 獲取下班為i的頂點的終點 用于判斷兩個頂點終點是否相同* @param ends 記錄了各個頂點對應的終點的下標是哪個* @param i 傳入的頂點對應的下標* @return 返回下標為i 的頂點的終點對應的下標*/private int getEnd(int[] ends,int i){while(ends[i]!=0){i = ends[i];}return i;}/*** 排序* @param edgeData*/public void sortEData(EData[] edgeData){for (int i = 0; i < edgeData.length; i++) {for (int j = i+1; j < edgeData.length; j++) {if(edgeData[i].weight>edgeData[j].weight){EData temp = edgeData[i];edgeData[i] = edgeData[j];edgeData[j] = temp;}}}}/*** 通過matrix鄰接矩陣來 獲取圖中的邊 EData[]放入數組中 后面需要遍歷該數組** @return EData[] 形式 [['A', 'B', 12],['B', 'F', 7] .....]*/public EData[] getEdgeData(){EData[] data = new EData[edgeNum];int index = 0;//該方式求出的值會將<AB><BA> 看著不同的值 // for (int i = 0; i < matrix.length; i++) { // for (int j = 0; j < matrix[i].length; j++) { // if(matrix[i][j]!=INF && matrix[i][j]!=0 ){ // data[index++] = new EData(vertex[i],vertex[j],matrix[i][j]); // } // } // }for (int i = 0; i < vertex.length; i++) {for (int j = i+1; j < vertex.length; j++) {if(matrix[i][j]!=INF && matrix[i][j]!=0 ){data[index++] = new EData(vertex[i],vertex[j],matrix[i][j]);}}}return data;}public KruskalAlgoritm(char[] vertex,int[][] matrix){this.vertex= vertex;this.matrix= matrix;for (int i = 0; i < vertex.length; i++) {for (int j = i+1; j < vertex.length; j++) {if(matrix[i][j]!=INF && matrix[i][j]!=0){edgeNum++;}}}}public void showMatrix(){for (int i = 0; i < matrix.length; i++) {System.out.println(Arrays.toString(matrix[i]));}} }/*** 創建一個類EData 它的對象實例就表示一條邊*/ class EData implements Comparable<EData>{public char start;// 邊的一個點 可以理解為起點public char end; // 邊的另外一個頂點 可以理解為終點public int weight;// 邊的權值public EData(char start,char end,int weight) {this.start = start;this.end = end;this.weight = weight;}@Overridepublic String toString() {return "EData<" + start + "," + end +"> = " + weight ;}@Overridepublic int compareTo(EData o) {//從小到大return this.weight-o.weight;} }

信息打印

迪杰斯特拉算法

應用場景-最短路徑問題

看一個應用場景和問題:

  • 戰爭時期,某村有7個村莊(A,B,C,D,E,F,G)現有六個郵差,從G點出發,需要分別把郵件分別送到A,B,C,D,E,F,G六個村莊
  • 各個村莊的距離用邊線表示(權),比如A-B距離5公里
    如何計算出G村莊到其他各個村莊的最短距離?

迪杰斯特拉算法介紹

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

  • 設置出發點為v,頂點集合V{v1,v2,vi…},v到V中各墊點的距離構成距離構成距離集合dis,dis{d1,d2,di…},
    dis集合記錄著v到圖中各頂點的距離(到自身可以看作0,v到vi距離對應為di)
  • 從dis中選擇值最小的di并移出dis,同時移出V集合中對應的頂點vi,此時的v到vi即為最短路徑
  • 更新dis集合,更新規則為:比較v到V集合中頂點的距離值,與v通過vi到V集合中頂點的距離值,保留值較小的一個(同時也應該更新頂點的前驅節點為vi,表明是同vi達到的)
  • 重復執行兩步驟,直到最短路徑頂點為目標頂點即可結束。

圖解過程

代碼實現

public class DijkstraAlgorithm {public static final int INF = 65535;public static void main(String[] args) {char[] vertexs = {'A','B','C','D','E','F','G'};int[][] matrix = new int[vertexs.length][vertexs.length];matrix[0]=new int[]{INF,5,7,INF,INF,INF,2};matrix[1]=new int[]{5,INF,INF,9,INF,INF,3};matrix[2]=new int[]{7,INF,INF,INF,8,INF,INF};matrix[3]=new int[]{INF,9,INF,INF,INF,4,INF};matrix[4]=new int[]{INF,INF,8,INF,INF,5,4};matrix[5]=new int[]{INF,INF,INF,4,5,INF,6};matrix[6]=new int[]{2,3,INF,INF,4,6,INF};Graph graph = new Graph(vertexs,matrix);graph.showGraph();graph.dijkstra(6);graph.showDijkstra();} }class Graph{private char[] vertexs;private int[][] matrix;private VisitedVertex visitedVertex;public Graph(char[] vertexs,int[][] matrix){this.vertexs = vertexs;this.matrix = matrix;}public void showGraph(){for (int i = 0; i < matrix.length; i++) {System.out.println(Arrays.toString(matrix[i]));}}/*** 迪杰斯特拉算法實現* @param index*/public void dijkstra(int index){this.visitedVertex = new VisitedVertex(vertexs.length,index);update(index);//更新index頂點 到周圍頂點的距離和前驅頂點for (int i = 0; i < vertexs.length; i++) {index = visitedVertex.updateArr(); //選擇并返回新的訪問頂點update(index);//更新index頂點 到周圍頂點的距離和前驅頂點}}public void showDijkstra(){visitedVertex.show();}/*** 更新index下標周圍頂點的距離 和頂點的前驅頂點* @param index*/private void update(int index){int d = 0;for (int i = 0; i < matrix[index].length; i++) {//出發頂點到index頂點的距離+從index頂點到距離到i頂點的距離d = visitedVertex.getDis(index)+matrix[index][i];//如果頂點i沒有被訪問過 且 小于出發點到i的距離就需要更新if(!visitedVertex.in(i) && d < visitedVertex.getDis(i)){visitedVertex.updatePre(i,index);//更新i頂點的前驅為index頂點visitedVertex.updateDis(i,d); // 更新出發頂點的j節點的距離}}} }class VisitedVertex{// 記錄每個頂點是否訪問過 1 訪問過 0 未訪問public int[] alreadyArr;// 每個下標對應的值為第一個頂點的下標public int[] preVisited;// 記錄出頂點到其他所有頂點的距離public int[] dis;/**** @param length 頂點數組長度* @param index 出發頂點對應的下標*/public VisitedVertex(int length,int index){this.alreadyArr = new int[length];this.preVisited = new int[length];this.dis = new int[length];//初始化dis為 最大值Arrays.fill(dis,DijkstraAlgorithm.INF);//設置起點為開始值alreadyArr[index] = 1;// 自己到自己的距離為0dis[index] = 0;}/*** 判斷index下標是否被訪問過* @param index* @return 訪問過 返回true 否則false*/public boolean in(int index){return alreadyArr[index] == 1;}/*** 更新index下標的距離* @param index 下標* @param d 距離*/public void updateDis(int index,int d){dis[index] = d;}/*** 更新pre為索引的頂點的前驅為index索引的節點* @param index 下標* @param pre 距離*/public void updatePre(int pre,int index){preVisited[pre] = index;}/*** 返回出發頂點到index頂點的距離* @param index* @return*/public int getDis(int index){return dis[index];}/*** 繼續選擇并返回新的訪問節點* 比如這里的G完后 就是A作為新的訪問頂點(不是出發點)* @return*/public int updateArr(){int min = DijkstraAlgorithm.INF;int index = 0;for (int i = 0; i <alreadyArr.length; i++) {if(alreadyArr[i]==0&&dis[i]<min){min = dis[i];index = i;}}alreadyArr[index] = 1;return index;}public void show(){System.out.println("alreadyArr");for (int i = 0; i < alreadyArr.length; i++) {System.out.print(alreadyArr[i] + " ");}System.out.println();System.out.println("preVisited");for (int i = 0; i < preVisited.length; i++) {System.out.print(preVisited[i] + " ");}System.out.println();System.out.println("dis");for (int i = 0; i < dis.length; i++) {System.out.print(dis[i] + " ");}System.out.println();System.out.println("------打印信息調整------");// 為了便于好看最短距離 打印信息調整 2 3 9 10 4 6 0char[] vertexs = {'A','B','C','D','E','F','G'};for (int i = 0; i < vertexs.length; i++) {System.out.print(vertexs[i]+"("+dis[i]+")");}} }

信息打印

佛洛伊德算法

佛洛伊德算法介紹

  • 和Dijkstra算法一樣,佛洛佛洛伊德算法也是一種用于尋找給定的加權圖中頂點間最短路徑的算法。該算法名稱以創始人之一命令
  • 佛洛伊德算法計算圖中各個頂點之間的最短路徑
  • 迪杰斯特拉算法用于計算圖中某一個頂點到其他頂點最短路徑
  • 佛洛伊德算法VS迪杰斯特拉算法:迪杰斯特拉算法利用通過選定的訪問頂點,求出從出發訪問頂點到其他頂點的最短路徑:佛洛伊德算法中每個頂頂啊都是出發訪問點,所以需要將每一個頂點看做被訪問頂點,求出從每一個頂點到其他頂點的最短路徑。

佛洛伊德算法圖解分析

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

佛洛伊德算法步驟
第一輪循環中,以A(下標為:0)作為中間頂點【即把A作為中間頂點的所有情況都進行遍歷,就會得到更新距離表 和前驅關系】;
分析如下:

  • 以A頂點作為中間頂點是B->A->C的距離由N->9,同理C到B:C->A->G的距離由N->12,同理G到C
  • 更換中間頂點,循環執行操作,知道所有頂點都作為中間頂點更新后,計算結束

代碼實現

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 };GraphFloyd floyd = new GraphFloyd(vertex.length,matrix,vertex);floyd.showGraph();floyd.floyd();System.out.println("-----算法計算后----------");floyd.showGraph();} }class GraphFloyd{private char[] vertex;//存放頂點的數組private int[][] dis;//存放從各個頂點出發 到其他頂點的距離private int[][] pre;//保存到達目標節點的前驅節點public GraphFloyd(int length,int[][] matrix,char[] vertex){this.vertex = vertex;this.dis = matrix;this.pre = new int[length][length];// 對pre數組初始化, 存放的是前驅頂點的下標 初始化每一行都是當前節點的下標for (int i = 0; i < length; i++) {Arrays.fill(pre[i],i);}}public void showGraph(){for (int k = 0; k < dis.length; k++) {for (int i = 0; i < dis.length; i++) {System.out.print(vertex[pre[k][i]]+" ");}System.out.println();}System.out.println("----到各個頂點的距離--");for (int k = 0; k < dis.length; k++) {for (int i = 0; i < dis.length; i++) {System.out.print(vertex[k]+"->"+vertex[i]+"("+dis[k][i]+") ");}System.out.println();}}public void floyd(){int len;//距離//從中間頂點的變量 k 是中間頂點下標for (int k = 0; k <vertex.length; k++) {//從i頂點開始出發for (int i = 0; i < vertex.length; i++) {// 到大j頂點for (int j = 0; j < vertex.length; j++) {// 從i ->k ->j 的距離len = dis[i][k]+dis[k][j];if(len<dis[i][j]){//小于當前的值dis[i][j]=len;//更新距離表pre[i][j]=pre[k][j];// 更新前驅頂點}}}}} }

信息打印

馬踏棋盤算法

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

  • 馬踏棋盤算法也被稱為騎士周游問題
  • 將馬隨機放在國際象棋8X8棋盤中Board[07][07]的某個方格中,馬按走棋規則(馬走日子)進行移動,要求每個方格只進入一次,走遍棋盤上全部64個方格
  • 游戲演示:http://www.4399.com/flash/146267_2.html

圖解馬踏棋盤游戲實現

  • 馬踏棋盤問題實際上是圖的深度優先搜索(DFS)的應用
  • 如果使用回溯(就是深度優先搜索)來解決,假如馬兒踏了53個點,如圖:走到了第53個,坐標(1,0),發現已經走到盡頭,沒辦法,那就只能回退,
    查看其它的路徑,就在棋盤上不停的回溯…

    解決步驟與思路
  • 創建棋盤chessBoard,是一個二維數組
  • 將當初位置設置為已經訪問,然后根據當前位置,計算馬兒還能能走那些位置,并放入到一個集合中ArrayList,最多有8個位置,每走一步就使用step+1
  • 遍歷ArrayList中存在的所有位置,看看那個是可以走通,如果可以走通,就繼續,走不通,就回溯
  • 判斷馬兒是否完成了任務,使用step和應該走的步數比較,如果沒有達到數量,則表示沒有完成任務,將整個棋盤置0

注意:馬的不同做法(策略),會得到不同的結果,效率也會有影響

代碼實現

public class HorseChess {private static int x;//棋盤的列private static int y;//棋盤的行//標記各個位置是否被訪問過private static boolean[] visited;//標記棋盤所有位置是否被訪問過private static boolean finished;public static void main(String[] args) {//棋盤大小x = 6;y = 6;//其實位置int row = 2;int col = 4;int[][] chessBoard = new int[x][y];visited = new boolean[x*y];long start = System.currentTimeMillis();traversalChessBoard(chessBoard,row-1,col-1,1);long end = System.currentTimeMillis();System.out.println("功共耗時 " + (end - start) + "毫秒");for (int[] rows:chessBoard) {System.out.println(Arrays.toString(rows));}}private static void traversalChessBoard(int[][] chessBoard, int row, int col, int step) {//馬的其實位置設置chessBoard[row][col] = step;//記錄該空格為訪問過visited[row*x+col] = true;ArrayList<Point> listPoint = nextList(new Point(row, col));//遍歷集合while (!listPoint.isEmpty()){//取出走一步Point remove = listPoint.remove(0);//如果沒有被訪問就繼續 y 為行 x 為列if(!visited[remove.y*x+remove.x]){traversalChessBoard(chessBoard,remove.y,remove.x,step+1);}}//判斷是否成功走完// step < x * y 情況有兩種 棋盤到目前位置棋盤未走完 棋盤處于回溯過程if(x*y>step&&!finished){chessBoard[row][col]=0;visited[row*x+col] = false;}else{finished = true;}}/*** 根據當前位置point 計算馬兒 還能走那些位置* @param current* @return*/private static ArrayList<Point> nextList(Point current){ArrayList<Point> list = new ArrayList<Point>();Point point = new Point();//棋盤5的位置if((point.x=current.x-2)>=0&&(point.y=current.y-1)>=0){list.add(new Point(point));}//棋盤6的位置if((point.x=current.x-1)>=0&&(point.y=current.y-2)>=0){list.add(new Point(point));}//棋盤7的位置if((point.x=current.x+1)< x &&(point.y=current.y-2)>=0){list.add(new Point(point));}//棋盤0的位置if((point.x=current.x+2)< x &&(point.y=current.y-1)>=0){list.add(new Point(point));}//棋盤1的位置if((point.x=current.x+2)< x &&(point.y=current.y+1)<y){list.add(new Point(point));}//棋盤2的位置if((point.x=current.x+1)< x &&(point.y=current.y+2)<y){list.add(new Point(point));}//棋盤3的位置if((point.x=current.x-1)>=0 &&(point.y=current.y+2)<y){list.add(new Point(point));}//棋盤3的位置if((point.x=current.x-2)>=0 &&(point.y=current.y+1)<y){list.add(new Point(point));}return list;} }

信息打印

用貪心算法優化代碼:

public class HorseChess {private static int x;//棋盤的列private static int y;//棋盤的行//標記各個位置是否被訪問過private static boolean[] visited;//標記棋盤所有位置是否被訪問過private static boolean finished;public static void main(String[] args) {//棋盤大小x = 8;y = 8;//其實位置int row = 2;int col = 4;int[][] chessBoard = new int[x][y];visited = new boolean[x*y];long start = System.currentTimeMillis();traversalChessBoard(chessBoard,row-1,col-1,1);long end = System.currentTimeMillis();System.out.println("功共耗時 " + (end - start) + "毫秒");for (int[] rows:chessBoard) {System.out.println(Arrays.toString(rows));}}private static void traversalChessBoard(int[][] chessBoard, int row, int col, int step) {//馬的其實位置設置chessBoard[row][col] = step;//記錄該空格為訪問過visited[row*x+col] = true;ArrayList<Point> listPoint = nextList(new Point(row, col));sort(listPoint);//遍歷集合while (!listPoint.isEmpty()){//取出走一步Point remove = listPoint.remove(0);//如果沒有被訪問就繼續 y 為行 x 為列if(!visited[remove.y*x+remove.x]){traversalChessBoard(chessBoard,remove.y,remove.x,step+1);}}//判斷是否成功走完// step < x * y 情況有兩種 棋盤到目前位置棋盤未走完 棋盤處于回溯過程if(x*y>step&&!finished){chessBoard[row][col]=0;visited[row*x+col] = false;}else{finished = true;}}/*** 根據當前位置point 計算馬兒 還能走那些位置* @param current* @return*/private static ArrayList<Point> nextList(Point current){ArrayList<Point> list = new ArrayList<Point>();Point point = new Point();//棋盤5的位置if((point.x=current.x-2)>=0&&(point.y=current.y-1)>=0){list.add(new Point(point));}//棋盤6的位置if((point.x=current.x-1)>=0&&(point.y=current.y-2)>=0){list.add(new Point(point));}//棋盤7的位置if((point.x=current.x+1)< x &&(point.y=current.y-2)>=0){list.add(new Point(point));}//棋盤0的位置if((point.x=current.x+2)< x &&(point.y=current.y-1)>=0){list.add(new Point(point));}//棋盤1的位置if((point.x=current.x+2)< x &&(point.y=current.y+1)<y){list.add(new Point(point));}//棋盤2的位置if((point.x=current.x+1)< x &&(point.y=current.y+2)<y){list.add(new Point(point));}//棋盤3的位置if((point.x=current.x-1)>=0 &&(point.y=current.y+2)<y){list.add(new Point(point));}//棋盤3的位置if((point.x=current.x-2)>=0 &&(point.y=current.y+1)<y){list.add(new Point(point));}return list;}private static void sort(ArrayList<Point> list){list.sort((p1,p2)->{ArrayList<Point> list1 = nextList(p1);ArrayList<Point> list2 = nextList(p2);if(list1.size()>list2.size()){return 1;}else if(list1.size()<list2.size()){return -1;}else {return 0;}});} }

8X8優化前等了很久還是沒有打印信息

8X8優化后打印信息

至此花了近3個月終于學習完了數據結構與算法這部分知識,希望能入個門。

總結

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

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

免费无码一区二区三区蜜桃大 | 草草网站影院白丝内射 | 日韩精品乱码av一区二区 | 强伦人妻一区二区三区视频18 | 无码av免费一区二区三区试看 | 国产精品久久久久久亚洲毛片 | 午夜福利试看120秒体验区 | 国产办公室秘书无码精品99 | 久久99久久99精品中文字幕 | 久久精品国产日本波多野结衣 | 日本一区二区三区免费高清 | 麻豆国产丝袜白领秘书在线观看 | 欧美性猛交xxxx富婆 | 国内综合精品午夜久久资源 | 伊人久久大香线蕉午夜 | 无码人妻精品一区二区三区不卡 | www成人国产高清内射 | 欧美 日韩 亚洲 在线 | 大乳丰满人妻中文字幕日本 | 成在人线av无码免观看麻豆 | 色婷婷av一区二区三区之红樱桃 | 白嫩日本少妇做爰 | 色婷婷av一区二区三区之红樱桃 | 久久久久久九九精品久 | 日本精品人妻无码77777 天堂一区人妻无码 | 国产热a欧美热a在线视频 | 欧美熟妇另类久久久久久多毛 | 精品亚洲韩国一区二区三区 | 妺妺窝人体色www婷婷 | 亚洲国产精华液网站w | 精品午夜福利在线观看 | 日日躁夜夜躁狠狠躁 | 欧美激情综合亚洲一二区 | 国产做国产爱免费视频 | 婷婷丁香六月激情综合啪 | 奇米影视7777久久精品人人爽 | 国产精品无码mv在线观看 | 久久久亚洲欧洲日产国码αv | 国产午夜手机精彩视频 | 精品久久久久久亚洲精品 | 东京热男人av天堂 | 精品亚洲成av人在线观看 | 99久久精品日本一区二区免费 | 亚洲中文字幕在线无码一区二区 | 亚洲国产欧美国产综合一区 | 成人性做爰aaa片免费看不忠 | 精品国产国产综合精品 | 欧美黑人乱大交 | 97人妻精品一区二区三区 | 成人影院yy111111在线观看 | 高清国产亚洲精品自在久久 | 国产熟女一区二区三区四区五区 | 精品一二三区久久aaa片 | 精品久久综合1区2区3区激情 | 亚洲国产一区二区三区在线观看 | 国产成人一区二区三区别 | 国产午夜精品一区二区三区嫩草 | 东京一本一道一二三区 | 国产麻豆精品精东影业av网站 | 国产激情综合五月久久 | 老熟女重囗味hdxx69 | 国产精品美女久久久 | 女人被男人躁得好爽免费视频 | 四虎4hu永久免费 | 国产亚洲欧美日韩亚洲中文色 | 97无码免费人妻超级碰碰夜夜 | 精品无码成人片一区二区98 | 色欲av亚洲一区无码少妇 | 午夜成人1000部免费视频 | 国产97人人超碰caoprom | 大色综合色综合网站 | 亚洲精品久久久久中文第一幕 | 亚洲精品成人av在线 | 少妇无码一区二区二三区 | 国产精品无码久久av | 激情爆乳一区二区三区 | 76少妇精品导航 | 国产明星裸体无码xxxx视频 | 久久成人a毛片免费观看网站 | 日韩欧美成人免费观看 | av无码久久久久不卡免费网站 | 国产9 9在线 | 中文 | 日韩人妻系列无码专区 | 久久精品人人做人人综合 | 综合人妻久久一区二区精品 | 精品偷自拍另类在线观看 | 色综合久久中文娱乐网 | 色综合天天综合狠狠爱 | 狠狠色噜噜狠狠狠7777奇米 | 18禁黄网站男男禁片免费观看 | 永久免费观看国产裸体美女 | 88国产精品欧美一区二区三区 | 午夜福利一区二区三区在线观看 | 妺妺窝人体色www婷婷 | 人妻尝试又大又粗久久 | 国产极品美女高潮无套在线观看 | 女人被男人躁得好爽免费视频 | 蜜桃臀无码内射一区二区三区 | 三上悠亚人妻中文字幕在线 | 日本熟妇大屁股人妻 | 国产xxx69麻豆国语对白 | 国产特级毛片aaaaaa高潮流水 | 国产熟妇另类久久久久 | 又粗又大又硬又长又爽 | 天天拍夜夜添久久精品大 | 97久久精品无码一区二区 | 欧美35页视频在线观看 | 国产亚洲欧美日韩亚洲中文色 | 国产莉萝无码av在线播放 | 久久无码人妻影院 | 日本精品久久久久中文字幕 | 久久亚洲精品中文字幕无男同 | 久久成人a毛片免费观看网站 | 国产在线无码精品电影网 | 欧美日韩一区二区综合 | 亚洲经典千人经典日产 | 日本在线高清不卡免费播放 | 18禁黄网站男男禁片免费观看 | 在线亚洲高清揄拍自拍一品区 | 欧美zoozzooz性欧美 | 国产免费观看黄av片 | 天堂久久天堂av色综合 | 一本精品99久久精品77 | 免费观看激色视频网站 | 午夜无码人妻av大片色欲 | 国产两女互慰高潮视频在线观看 | 精品亚洲成av人在线观看 | 亚洲欧美综合区丁香五月小说 | 亚洲精品午夜国产va久久成人 | 亚洲伊人久久精品影院 | 真人与拘做受免费视频一 | 精品成在人线av无码免费看 | 伊人久久大香线焦av综合影院 | 国产尤物精品视频 | 丰满岳乱妇在线观看中字无码 | 婷婷丁香五月天综合东京热 | 日本精品少妇一区二区三区 | 国产成人无码午夜视频在线观看 | 中文字幕 人妻熟女 | 国产美女精品一区二区三区 | 又紧又大又爽精品一区二区 | 国产熟女一区二区三区四区五区 | 国精产品一区二区三区 | 51国偷自产一区二区三区 | 国产激情艳情在线看视频 | 国产手机在线αⅴ片无码观看 | 一本久久伊人热热精品中文字幕 | 麻豆md0077饥渴少妇 | 在线观看国产午夜福利片 | 荫蒂被男人添的好舒服爽免费视频 | 久久久久久九九精品久 | 国内少妇偷人精品视频免费 | 国产肉丝袜在线观看 | 国产精品自产拍在线观看 | 夜夜躁日日躁狠狠久久av | 无码一区二区三区在线 | ass日本丰满熟妇pics | 亚洲精品一区二区三区四区五区 | 久久成人a毛片免费观看网站 | 久久精品女人的天堂av | 亲嘴扒胸摸屁股激烈网站 | 国产性生大片免费观看性 | 国产精品久久久av久久久 | 一本久久a久久精品亚洲 | 精品夜夜澡人妻无码av蜜桃 | 99久久人妻精品免费二区 | 大地资源网第二页免费观看 | 精品偷自拍另类在线观看 | 性生交大片免费看l | 成人无码视频免费播放 | 久久精品女人天堂av免费观看 | 麻豆md0077饥渴少妇 | 麻豆av传媒蜜桃天美传媒 | 国内少妇偷人精品视频免费 | 国产成人综合在线女婷五月99播放 | 98国产精品综合一区二区三区 | 99久久人妻精品免费二区 | av无码电影一区二区三区 | 国产性生交xxxxx无码 | 成人性做爰aaa片免费看 | 女人被男人爽到呻吟的视频 | 久久久精品人妻久久影视 | 男女作爱免费网站 | 婷婷色婷婷开心五月四房播播 | 无码人妻丰满熟妇区五十路百度 | 国产做国产爱免费视频 | 亚洲 另类 在线 欧美 制服 | av香港经典三级级 在线 | 国产精品久久久午夜夜伦鲁鲁 | 在线观看国产一区二区三区 | 国产精品丝袜黑色高跟鞋 | 色综合久久中文娱乐网 | 国产精品久久久久无码av色戒 | 国产sm调教视频在线观看 | 国产美女精品一区二区三区 | 玩弄中年熟妇正在播放 | 国产一精品一av一免费 | 国产成人久久精品流白浆 | 国产亚洲人成a在线v网站 | 77777熟女视频在线观看 а天堂中文在线官网 | 狠狠综合久久久久综合网 | 国产亚av手机在线观看 | 久久久久亚洲精品中文字幕 | 97精品国产97久久久久久免费 | а√资源新版在线天堂 | 久久精品无码一区二区三区 | 2019nv天堂香蕉在线观看 | 黑人玩弄人妻中文在线 | 国产精品人妻一区二区三区四 | 特黄特色大片免费播放器图片 | 中文字幕av伊人av无码av | 色欲综合久久中文字幕网 | 性色av无码免费一区二区三区 | 亚洲а∨天堂久久精品2021 | 欧美精品无码一区二区三区 | 激情国产av做激情国产爱 | 久久综合激激的五月天 | 国产精品无码一区二区三区不卡 | 久久无码专区国产精品s | 国产人妖乱国产精品人妖 | 欧美 丝袜 自拍 制服 另类 | 成人毛片一区二区 | 精品国产福利一区二区 | 黑人巨大精品欧美一区二区 | 国产在线aaa片一区二区99 | 久久综合久久自在自线精品自 | 国产无av码在线观看 | 成熟人妻av无码专区 | 久久久久人妻一区精品色欧美 | 亚洲精品一区二区三区在线观看 | 无码成人精品区在线观看 | 国产av一区二区三区最新精品 | 欧美成人家庭影院 | 亚洲另类伦春色综合小说 | 欧美高清在线精品一区 | 午夜精品久久久久久久 | 丝袜人妻一区二区三区 | 免费网站看v片在线18禁无码 | 激情五月综合色婷婷一区二区 | 久久久中文字幕日本无吗 | v一区无码内射国产 | 麻花豆传媒剧国产免费mv在线 | 无码人妻黑人中文字幕 | 一本久道久久综合狠狠爱 | 亚洲另类伦春色综合小说 | 四十如虎的丰满熟妇啪啪 | 天干天干啦夜天干天2017 | 无套内谢的新婚少妇国语播放 | 亚洲熟妇色xxxxx欧美老妇 | 日本在线高清不卡免费播放 | 天堂一区人妻无码 | 国产情侣作爱视频免费观看 | 欧美日韩久久久精品a片 | 久久久中文久久久无码 | 国产莉萝无码av在线播放 | 男女猛烈xx00免费视频试看 | 黑人玩弄人妻中文在线 | 一本久久a久久精品亚洲 | 亚洲区欧美区综合区自拍区 | 国产97人人超碰caoprom | 熟女少妇人妻中文字幕 | 久久综合给合久久狠狠狠97色 | 中文字幕乱码中文乱码51精品 | 欧美激情内射喷水高潮 | 奇米影视7777久久精品 | 在线观看欧美一区二区三区 | 三级4级全黄60分钟 | 久久久中文久久久无码 | 精品国产一区av天美传媒 | 亚洲中文字幕久久无码 | 国产人妻精品一区二区三区 | 国产精品无码永久免费888 | 少妇人妻大乳在线视频 | 中文字幕人妻无码一区二区三区 | 久久精品中文字幕大胸 | 粗大的内捧猛烈进出视频 | 国产亚洲精品久久久久久久久动漫 | 少妇性l交大片欧洲热妇乱xxx | 高清国产亚洲精品自在久久 | 色欲久久久天天天综合网精品 | 亚洲国产成人a精品不卡在线 | 两性色午夜视频免费播放 | 久久精品无码一区二区三区 | 疯狂三人交性欧美 | 久久www免费人成人片 | 久久99精品国产麻豆 | 色综合久久久无码网中文 | 日产精品99久久久久久 | 久久人人爽人人爽人人片av高清 | 中文字幕av日韩精品一区二区 | 麻豆精品国产精华精华液好用吗 | 久久国产精品二国产精品 | 成人精品视频一区二区 | 久久国产精品精品国产色婷婷 | 成人一在线视频日韩国产 | 国内精品一区二区三区不卡 | 日韩av无码一区二区三区不卡 | 国产 浪潮av性色四虎 | 欧美黑人性暴力猛交喷水 | 亚洲成av人片天堂网无码】 | 日日摸夜夜摸狠狠摸婷婷 | 美女黄网站人色视频免费国产 | 中文字幕无码免费久久99 | 色综合天天综合狠狠爱 | 亚洲区欧美区综合区自拍区 | 精品偷拍一区二区三区在线看 | 性欧美大战久久久久久久 | 丝袜 中出 制服 人妻 美腿 | 亚洲精品一区二区三区四区五区 | 久久精品国产日本波多野结衣 | 国内精品九九久久久精品 | 日日摸天天摸爽爽狠狠97 | 国产9 9在线 | 中文 | 中文字幕人妻无码一夲道 | 99久久婷婷国产综合精品青草免费 | 四虎国产精品免费久久 | 亚洲综合精品香蕉久久网 | 欧美刺激性大交 | 国产明星裸体无码xxxx视频 | 大乳丰满人妻中文字幕日本 | 国产在线aaa片一区二区99 | 国产精品手机免费 | 欧美freesex黑人又粗又大 | 中文字幕乱妇无码av在线 | 亚洲 a v无 码免 费 成 人 a v | 中文字幕av无码一区二区三区电影 | 亚洲国产av精品一区二区蜜芽 | 奇米影视888欧美在线观看 | 亚洲中文字幕无码一久久区 | 波多野结衣乳巨码无在线观看 | 天堂无码人妻精品一区二区三区 | 久久国产精品萌白酱免费 | 国产无遮挡又黄又爽免费视频 | 啦啦啦www在线观看免费视频 | 老子影院午夜伦不卡 | 黑人巨大精品欧美一区二区 | 欧美精品免费观看二区 | 久久久精品欧美一区二区免费 | 成人免费视频在线观看 | 激情内射亚州一区二区三区爱妻 | 亚洲娇小与黑人巨大交 | 国产在线精品一区二区高清不卡 | 国产亚洲精品久久久久久 | 性生交大片免费看女人按摩摩 | 精品国产福利一区二区 | 色欲久久久天天天综合网精品 | 无码国产乱人伦偷精品视频 | 欧美三级a做爰在线观看 | 亚洲 a v无 码免 费 成 人 a v | 激情亚洲一区国产精品 | 欧美人与牲动交xxxx | 国产成人综合色在线观看网站 | 丰满少妇熟乱xxxxx视频 | 日本护士毛茸茸高潮 | 久久久中文久久久无码 | 国产婷婷色一区二区三区在线 | 麻豆蜜桃av蜜臀av色欲av | 久久久无码中文字幕久... | 亚洲色大成网站www国产 | 久久精品国产日本波多野结衣 | 免费网站看v片在线18禁无码 | 中文字幕日韩精品一区二区三区 | 国产精品久久久久久亚洲毛片 | 成人欧美一区二区三区黑人免费 | 午夜无码区在线观看 | 天堂久久天堂av色综合 | yw尤物av无码国产在线观看 | 国产亚洲精品久久久ai换 | 国产亲子乱弄免费视频 | 欧美猛少妇色xxxxx | 黑人粗大猛烈进出高潮视频 | 丁香花在线影院观看在线播放 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲男女内射在线播放 | 狠狠亚洲超碰狼人久久 | 色综合天天综合狠狠爱 | 免费国产成人高清在线观看网站 | 一本大道伊人av久久综合 | 国产极品美女高潮无套在线观看 | 亚洲成av人片在线观看无码不卡 | 极品尤物被啪到呻吟喷水 | 国产黄在线观看免费观看不卡 | 欧美黑人性暴力猛交喷水 | 亚洲伊人久久精品影院 | 性欧美videos高清精品 | 又大又硬又爽免费视频 | 国产sm调教视频在线观看 | 国产亚洲人成在线播放 | 亚洲国产精品美女久久久久 | 国产精品久久福利网站 | 国产精品va在线播放 | 欧美人与物videos另类 | 亚洲人成网站在线播放942 | 极品嫩模高潮叫床 | 丝袜美腿亚洲一区二区 | 久久www免费人成人片 | 欧美三级不卡在线观看 | 国产精品久免费的黄网站 | 中文字幕精品av一区二区五区 | 精品无人国产偷自产在线 | 国产成人无码一二三区视频 | 日日碰狠狠躁久久躁蜜桃 | 国产97人人超碰caoprom | 又色又爽又黄的美女裸体网站 | 成人免费视频在线观看 | 大肉大捧一进一出视频出来呀 | 女人高潮内射99精品 | 久久99精品国产麻豆 | 亚洲天堂2017无码 | 三上悠亚人妻中文字幕在线 | 纯爱无遮挡h肉动漫在线播放 | 色五月五月丁香亚洲综合网 | 中文字幕精品av一区二区五区 | 久久人人97超碰a片精品 | 无码av中文字幕免费放 | 国产亚洲精品久久久久久国模美 | 人妻aⅴ无码一区二区三区 | 国产精品欧美成人 | 亚洲欧美国产精品专区久久 | 亚洲毛片av日韩av无码 | 久久国内精品自在自线 | 亚洲中文字幕va福利 | 少妇愉情理伦片bd | 国产在线一区二区三区四区五区 | 欧美阿v高清资源不卡在线播放 | 成人亚洲精品久久久久软件 | 人人妻人人澡人人爽人人精品 | 伊人久久大香线蕉亚洲 | 狠狠躁日日躁夜夜躁2020 | 欧美日韩视频无码一区二区三 | 宝宝好涨水快流出来免费视频 | 亚洲自偷精品视频自拍 | 中文无码伦av中文字幕 | 久久久中文久久久无码 | 无码人妻精品一区二区三区下载 | 亚洲精品欧美二区三区中文字幕 | 亚洲va中文字幕无码久久不卡 | 少妇厨房愉情理9仑片视频 | 日本大乳高潮视频在线观看 | 清纯唯美经典一区二区 | 亚洲综合无码一区二区三区 | 亚洲一区二区三区 | 国产午夜手机精彩视频 | 永久免费观看国产裸体美女 | 欧美性生交xxxxx久久久 | 久久亚洲a片com人成 | 久久99热只有频精品8 | 无码人妻少妇伦在线电影 | 国产真实伦对白全集 | 亚洲午夜久久久影院 | 九九久久精品国产免费看小说 | 亚洲熟熟妇xxxx | 亚洲人亚洲人成电影网站色 | 色一情一乱一伦一视频免费看 | aⅴ在线视频男人的天堂 | 成熟人妻av无码专区 | 牲欲强的熟妇农村老妇女视频 | 国产无av码在线观看 | 香港三级日本三级妇三级 | 色五月丁香五月综合五月 | 国产欧美精品一区二区三区 | 国产农村乱对白刺激视频 | 精品国产aⅴ无码一区二区 | 久久综合狠狠综合久久综合88 | 色综合久久久无码网中文 | 免费国产成人高清在线观看网站 | 国产性生交xxxxx无码 | 中文久久乱码一区二区 | 久久精品国产精品国产精品污 | 日本xxxx色视频在线观看免费 | 无码人妻丰满熟妇区毛片18 | 欧美乱妇无乱码大黄a片 | 97夜夜澡人人爽人人喊中国片 | 亚洲 激情 小说 另类 欧美 | 亚洲人成无码网www | 永久免费观看国产裸体美女 | 国产成人综合色在线观看网站 | 精品国偷自产在线视频 | 欧美国产日韩久久mv | 爱做久久久久久 | 丰满诱人的人妻3 | 国产超级va在线观看视频 | 亚洲色www成人永久网址 | 青春草在线视频免费观看 | 久久久久免费看成人影片 | 国产内射爽爽大片视频社区在线 | 亚洲一区二区三区偷拍女厕 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 欧洲熟妇色 欧美 | 国产精品沙发午睡系列 | 少妇性荡欲午夜性开放视频剧场 | 综合激情五月综合激情五月激情1 | 亚洲成a人片在线观看无码3d | 亚洲成av人综合在线观看 | 玩弄中年熟妇正在播放 | 国产精品久久久久久亚洲影视内衣 | 国内少妇偷人精品视频免费 | 亚洲伊人久久精品影院 | 18禁止看的免费污网站 | 日本丰满护士爆乳xxxx | 亚洲中文字幕久久无码 | 香蕉久久久久久av成人 | 亚洲精品中文字幕久久久久 | 国精产品一区二区三区 | 国产精品香蕉在线观看 | 日本大香伊一区二区三区 | 免费观看的无遮挡av | 98国产精品综合一区二区三区 | 免费人成在线视频无码 | 熟妇人妻无码xxx视频 | 国产色xx群视频射精 | 成人片黄网站色大片免费观看 | 亚洲成在人网站无码天堂 | 牲交欧美兽交欧美 | 国产午夜无码精品免费看 | 精品无人区无码乱码毛片国产 | 欧美一区二区三区视频在线观看 | 国产无遮挡吃胸膜奶免费看 | 无码av免费一区二区三区试看 | 狠狠色欧美亚洲狠狠色www | 久9re热视频这里只有精品 | 亚洲成a人片在线观看无码3d | 国产真实乱对白精彩久久 | 欧美人与善在线com | 成人试看120秒体验区 | 欧美肥老太牲交大战 | 老司机亚洲精品影院 | 熟女少妇人妻中文字幕 | 精品国偷自产在线视频 | 亚洲第一无码av无码专区 | 成人三级无码视频在线观看 | 久久99精品国产麻豆 | 无码精品国产va在线观看dvd | 久久97精品久久久久久久不卡 | 亚洲精品美女久久久久久久 | 免费国产成人高清在线观看网站 | 精品人妻中文字幕有码在线 | 欧美精品在线观看 | 亚洲国产精品无码久久久久高潮 | 无码免费一区二区三区 | 人妻少妇精品久久 | 色婷婷综合中文久久一本 | 亚洲理论电影在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 人妻无码久久精品人妻 | 免费播放一区二区三区 | 超碰97人人做人人爱少妇 | 国产无遮挡又黄又爽免费视频 | 麻豆av传媒蜜桃天美传媒 | 亚洲自偷精品视频自拍 | 国产热a欧美热a在线视频 | 免费观看的无遮挡av | 久久久久成人片免费观看蜜芽 | 亚洲国产一区二区三区在线观看 | 中文字幕av无码一区二区三区电影 | 久久亚洲中文字幕无码 | 999久久久国产精品消防器材 | 美女扒开屁股让男人桶 | 丰满人妻被黑人猛烈进入 | 中文字幕人妻无码一夲道 | 色五月五月丁香亚洲综合网 | 精品日本一区二区三区在线观看 | 国产片av国语在线观看 | 妺妺窝人体色www婷婷 | 亚洲爆乳精品无码一区二区三区 | 动漫av网站免费观看 | 人人妻人人澡人人爽欧美一区 | av无码电影一区二区三区 | 成在人线av无码免费 | 欧美第一黄网免费网站 | 国产av剧情md精品麻豆 | 成人无码精品1区2区3区免费看 | 久久国产精品萌白酱免费 | 国产精品香蕉在线观看 | 无码人妻黑人中文字幕 | 在线观看免费人成视频 | 男女下面进入的视频免费午夜 | 亚洲区欧美区综合区自拍区 | 国产艳妇av在线观看果冻传媒 | 伊人色综合久久天天小片 | 国产香蕉97碰碰久久人人 | 无码人妻丰满熟妇区毛片18 | 亚拍精品一区二区三区探花 | 色爱情人网站 | 国产精品久久国产三级国 | 55夜色66夜色国产精品视频 | 成人性做爰aaa片免费看不忠 | 巨爆乳无码视频在线观看 | 99国产精品白浆在线观看免费 | 97久久国产亚洲精品超碰热 | 国产精品丝袜黑色高跟鞋 | 天堂亚洲2017在线观看 | 国产精品嫩草久久久久 | 在线视频网站www色 | 亚洲人成网站在线播放942 | 强伦人妻一区二区三区视频18 | 亚洲 另类 在线 欧美 制服 | 色综合久久久久综合一本到桃花网 | 巨爆乳无码视频在线观看 | 国产午夜无码视频在线观看 | 国产av无码专区亚洲awww | 欧美精品国产综合久久 | 国产三级久久久精品麻豆三级 | 99久久精品无码一区二区毛片 | 青青久在线视频免费观看 | 久久99精品国产麻豆 | 国产精品久久久午夜夜伦鲁鲁 | 色婷婷av一区二区三区之红樱桃 | 国产亚av手机在线观看 | 激情爆乳一区二区三区 | 亚洲欧美中文字幕5发布 | 麻豆蜜桃av蜜臀av色欲av | 亚洲色偷偷男人的天堂 | 三级4级全黄60分钟 | 日本熟妇乱子伦xxxx | 亚洲一区二区三区香蕉 | 爆乳一区二区三区无码 | 国产精品怡红院永久免费 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久久亚洲欧洲日产国码αv | 欧美人妻一区二区三区 | 性啪啪chinese东北女人 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 中文字幕无线码 | 免费观看黄网站 | 人妻少妇精品久久 | 久久国产精品萌白酱免费 | 撕开奶罩揉吮奶头视频 | 欧美丰满少妇xxxx性 | 初尝人妻少妇中文字幕 | 国产婷婷色一区二区三区在线 | 麻豆精品国产精华精华液好用吗 | 国产艳妇av在线观看果冻传媒 | 国产69精品久久久久app下载 | 久久久精品456亚洲影院 | 国内少妇偷人精品视频 | 99久久人妻精品免费二区 | 亚洲国产精品无码久久久久高潮 | 黑人巨大精品欧美一区二区 | 一本加勒比波多野结衣 | 丰满少妇女裸体bbw | 97精品人妻一区二区三区香蕉 | 亚洲色欲色欲天天天www | 日日摸天天摸爽爽狠狠97 | 永久免费精品精品永久-夜色 | 熟女体下毛毛黑森林 | 精品久久综合1区2区3区激情 | 欧洲欧美人成视频在线 | 夜夜躁日日躁狠狠久久av | 99麻豆久久久国产精品免费 | 日韩av激情在线观看 | 女高中生第一次破苞av | 免费男性肉肉影院 | 狂野欧美性猛交免费视频 | 国产av无码专区亚洲awww | 欧美第一黄网免费网站 | 国产成人亚洲综合无码 | 一本久道久久综合婷婷五月 | 亚洲 激情 小说 另类 欧美 | 久久久久人妻一区精品色欧美 | 中文字幕久久久久人妻 | 7777奇米四色成人眼影 | 欧美人与牲动交xxxx | 亚洲成a人片在线观看无码 | 国产无遮挡吃胸膜奶免费看 | 国产特级毛片aaaaaaa高清 | 午夜熟女插插xx免费视频 | 欧美激情内射喷水高潮 | 国产成人无码a区在线观看视频app | 欧美国产日韩亚洲中文 | 国产麻豆精品一区二区三区v视界 | 久久精品国产99久久6动漫 | 18禁黄网站男男禁片免费观看 | 俺去俺来也在线www色官网 | 欧美freesex黑人又粗又大 | 亚洲国产精品久久久天堂 | 乱人伦人妻中文字幕无码 | 黑人大群体交免费视频 | 国产成人精品一区二区在线小狼 | 免费无码的av片在线观看 | 国产亚洲tv在线观看 | 99视频精品全部免费免费观看 | 丰满人妻被黑人猛烈进入 | 成熟人妻av无码专区 | 动漫av一区二区在线观看 | 领导边摸边吃奶边做爽在线观看 | 久久久久久久女国产乱让韩 | 日本一卡2卡3卡四卡精品网站 | 国产成人精品无码播放 | 精品久久综合1区2区3区激情 | 国产亚洲人成a在线v网站 | 久久久久亚洲精品男人的天堂 | 人人妻人人澡人人爽欧美一区九九 | 性生交片免费无码看人 | 成人无码精品1区2区3区免费看 | 日韩无套无码精品 | 久久久久久久人妻无码中文字幕爆 | 国产精品国产三级国产专播 | 精品人人妻人人澡人人爽人人 | 色情久久久av熟女人妻网站 | 小sao货水好多真紧h无码视频 | 色欲av亚洲一区无码少妇 | 黑人大群体交免费视频 | 国产又爽又猛又粗的视频a片 | 国产亚洲精品精品国产亚洲综合 | 久久久成人毛片无码 | 国产精品久久久久久久9999 | 免费无码av一区二区 | 国产色视频一区二区三区 | 最新国产麻豆aⅴ精品无码 | 中文无码精品a∨在线观看不卡 | 国产精品18久久久久久麻辣 | 久久国产精品_国产精品 | 亚洲国产精品毛片av不卡在线 | 国产精品.xx视频.xxtv | 日韩av无码一区二区三区不卡 | 在线成人www免费观看视频 | 国产精品久久国产三级国 | 欧美黑人乱大交 | 国产精品亚洲综合色区韩国 | 在线播放免费人成毛片乱码 | 丝袜人妻一区二区三区 | 日本一卡2卡3卡四卡精品网站 | 成人女人看片免费视频放人 | 亚洲人成人无码网www国产 | 一个人看的www免费视频在线观看 | 久久精品国产精品国产精品污 | 亚洲 日韩 欧美 成人 在线观看 | 国产精品国产三级国产专播 | 骚片av蜜桃精品一区 | 色综合视频一区二区三区 | 无人区乱码一区二区三区 | 日日躁夜夜躁狠狠躁 | 少妇无码一区二区二三区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲啪av永久无码精品放毛片 | 日韩无套无码精品 | 俺去俺来也在线www色官网 | 无套内谢老熟女 | 色狠狠av一区二区三区 | 国产网红无码精品视频 | 久久久久久a亚洲欧洲av冫 | 野狼第一精品社区 | 亚洲精品成人福利网站 | 久久亚洲日韩精品一区二区三区 | 一本大道伊人av久久综合 | 少妇性俱乐部纵欲狂欢电影 | 久久精品人妻少妇一区二区三区 | 51国偷自产一区二区三区 | 男女作爱免费网站 | 少妇性荡欲午夜性开放视频剧场 | 中文字幕无码av激情不卡 | 亚洲精品午夜无码电影网 | 性史性农村dvd毛片 | 欧美丰满少妇xxxx性 | 国产成人无码区免费内射一片色欲 | 麻豆蜜桃av蜜臀av色欲av | 一本大道久久东京热无码av | 久久99精品国产麻豆 | 久久午夜无码鲁丝片秋霞 | 久久综合激激的五月天 | 无遮挡啪啪摇乳动态图 | 无码人妻精品一区二区三区不卡 | 久久久久人妻一区精品色欧美 | 国产精品99爱免费视频 | 久久五月精品中文字幕 | 成年美女黄网站色大免费视频 | 久精品国产欧美亚洲色aⅴ大片 | 国产口爆吞精在线视频 | 亚洲欧美日韩综合久久久 | 永久黄网站色视频免费直播 | 女人高潮内射99精品 | 中文字幕av无码一区二区三区电影 | 曰本女人与公拘交酡免费视频 | 亚洲成a人片在线观看无码3d | 中文字幕乱码人妻二区三区 | 高潮喷水的毛片 | 一本久久伊人热热精品中文字幕 | 欧美放荡的少妇 | 人妻无码αv中文字幕久久琪琪布 | 亚洲国产精品久久人人爱 | 精品国产aⅴ无码一区二区 | 国产亚洲精品久久久久久大师 | 国产精品久久久久久久9999 | 搡女人真爽免费视频大全 | 99久久精品无码一区二区毛片 | 亚洲熟妇色xxxxx欧美老妇y | 国产成人无码a区在线观看视频app | 亚洲精品久久久久久久久久久 | 国产成人无码一二三区视频 | 久久久久久亚洲精品a片成人 | 97久久国产亚洲精品超碰热 | 亚洲 a v无 码免 费 成 人 a v | 亚洲一区二区三区香蕉 | 亚洲精品综合一区二区三区在线 | 亚洲精品午夜无码电影网 | 国产99久久精品一区二区 | 亚洲а∨天堂久久精品2021 | 欧美人与物videos另类 | 亚洲色欲色欲欲www在线 | 欧美激情一区二区三区成人 | 亚洲 高清 成人 动漫 | 夜夜高潮次次欢爽av女 | 亚洲国产精品久久久久久 | 熟妇女人妻丰满少妇中文字幕 | 欧美真人作爱免费视频 | 亚洲区欧美区综合区自拍区 | 久久精品国产亚洲精品 | 99精品国产综合久久久久五月天 | 丁香花在线影院观看在线播放 | 精品国偷自产在线视频 | 国产亚洲精品久久久久久大师 | 亚洲综合色区中文字幕 | 一本久久a久久精品亚洲 | 男女超爽视频免费播放 | 久久国内精品自在自线 | 久久亚洲a片com人成 | 永久免费精品精品永久-夜色 | 国内精品一区二区三区不卡 | 成人一区二区免费视频 | 国产av一区二区精品久久凹凸 | 九九热爱视频精品 | 中文字幕日韩精品一区二区三区 | 欧美野外疯狂做受xxxx高潮 | 三上悠亚人妻中文字幕在线 | 精品偷拍一区二区三区在线看 | 日韩亚洲欧美精品综合 | 色老头在线一区二区三区 | 色欲综合久久中文字幕网 | 人妻无码αv中文字幕久久琪琪布 | 国内精品人妻无码久久久影院蜜桃 | 欧美国产亚洲日韩在线二区 | 亚洲国产精品成人久久蜜臀 | 中文亚洲成a人片在线观看 | 久久综合给合久久狠狠狠97色 | 高清国产亚洲精品自在久久 | 亚洲の无码国产の无码步美 | 色婷婷综合中文久久一本 | 国产国语老龄妇女a片 | 扒开双腿吃奶呻吟做受视频 | √天堂资源地址中文在线 | 国产人妻精品一区二区三区不卡 | 免费看男女做好爽好硬视频 | 精品国产aⅴ无码一区二区 | 亚洲精品一区二区三区婷婷月 | 国产人妻大战黑人第1集 | 国产激情精品一区二区三区 | 亚洲精品国产精品乱码视色 | 久久国产自偷自偷免费一区调 | 亚洲中文字幕无码中文字在线 | 免费无码一区二区三区蜜桃大 | 国产午夜无码视频在线观看 | 亚洲精品无码人妻无码 | 999久久久国产精品消防器材 | 日韩 欧美 动漫 国产 制服 | 精品熟女少妇av免费观看 | 国产亚洲精品久久久久久 | 日韩欧美群交p片內射中文 | 亚洲小说春色综合另类 | 人人妻人人澡人人爽人人精品 | 精品久久久无码人妻字幂 | 色情久久久av熟女人妻网站 | 又粗又大又硬又长又爽 | 国产成人综合在线女婷五月99播放 | 无码成人精品区在线观看 | 图片小说视频一区二区 | 秋霞成人午夜鲁丝一区二区三区 | 老熟女重囗味hdxx69 | 一本久道久久综合狠狠爱 | 欧洲熟妇精品视频 | 国产av久久久久精东av | 大屁股大乳丰满人妻 | 亚洲无人区一区二区三区 | 久久久中文字幕日本无吗 | 中文字幕人成乱码熟女app | 女高中生第一次破苞av | 亚洲一区二区三区四区 | 精品国产一区二区三区四区在线看 | 欧美丰满熟妇xxxx性ppx人交 | 澳门永久av免费网站 | 日日碰狠狠躁久久躁蜜桃 | 国产精品久久福利网站 | 亚洲va中文字幕无码久久不卡 | 色综合久久久无码中文字幕 | 内射白嫩少妇超碰 | 国产精品人人爽人人做我的可爱 | 国产疯狂伦交大片 | 日本护士xxxxhd少妇 | 成人无码精品一区二区三区 | 色婷婷av一区二区三区之红樱桃 | 亚洲乱码日产精品bd | 国产人成高清在线视频99最全资源 | 亚洲人成网站色7799 | 国产免费久久久久久无码 | 少妇性l交大片欧洲热妇乱xxx | 免费中文字幕日韩欧美 | 欧美色就是色 | 激情综合激情五月俺也去 | 国产精品无套呻吟在线 | 欧美激情一区二区三区成人 | 亚洲精品www久久久 | 日韩成人一区二区三区在线观看 | 牲欲强的熟妇农村老妇女 | 亚洲精品久久久久久一区二区 | 国产人成高清在线视频99最全资源 | 欧美性生交活xxxxxdddd | 欧美老人巨大xxxx做受 | 在线观看免费人成视频 | 欧美激情一区二区三区成人 | 99精品国产综合久久久久五月天 | 玩弄中年熟妇正在播放 | 国产又粗又硬又大爽黄老大爷视 | 久久精品人妻少妇一区二区三区 | 精品国产aⅴ无码一区二区 | 精品无码成人片一区二区98 | 国产精品香蕉在线观看 | 国产亚洲精品精品国产亚洲综合 | 男女爱爱好爽视频免费看 | 国产特级毛片aaaaaa高潮流水 | 四虎国产精品免费久久 | 国产人妻精品一区二区三区不卡 | 99久久久无码国产精品免费 | 国产乱码精品一品二品 | 欧美亚洲日韩国产人成在线播放 | 性开放的女人aaa片 | 又粗又大又硬又长又爽 | 无码人妻出轨黑人中文字幕 | 国产亚洲精品久久久久久 | 国产香蕉97碰碰久久人人 | 色 综合 欧美 亚洲 国产 | 真人与拘做受免费视频 | 欧美日韩视频无码一区二区三 | 日本精品少妇一区二区三区 | 国产成人精品三级麻豆 | 麻豆国产丝袜白领秘书在线观看 | 日产精品99久久久久久 | 午夜福利不卡在线视频 | 精品少妇爆乳无码av无码专区 | 日韩少妇内射免费播放 | 亚洲中文字幕在线观看 | 无码播放一区二区三区 | 亚洲欧美日韩成人高清在线一区 | 免费观看激色视频网站 | 少妇性俱乐部纵欲狂欢电影 | 婷婷五月综合缴情在线视频 | 久久亚洲中文字幕精品一区 | 久久久精品欧美一区二区免费 | 丁香啪啪综合成人亚洲 | 99精品久久毛片a片 | www一区二区www免费 | 思思久久99热只有频精品66 | 任你躁在线精品免费 | 免费观看的无遮挡av | 国产精品人人妻人人爽 | 久久国产精品精品国产色婷婷 | 桃花色综合影院 | 精品欧洲av无码一区二区三区 | аⅴ资源天堂资源库在线 | 亚洲日本在线电影 | 亚洲国产精品久久久天堂 | 亚洲精品鲁一鲁一区二区三区 | 日韩精品成人一区二区三区 | 18禁黄网站男男禁片免费观看 | 亚洲呦女专区 | 5858s亚洲色大成网站www | 性做久久久久久久免费看 | 欧美猛少妇色xxxxx | 欧美成人高清在线播放 | 亚洲成a人片在线观看日本 | √天堂中文官网8在线 | 国产亚洲精品久久久久久国模美 | aⅴ亚洲 日韩 色 图网站 播放 | 国产超级va在线观看视频 | 国产成人精品优优av | 麻豆国产97在线 | 欧洲 | 夜精品a片一区二区三区无码白浆 | 中文精品无码中文字幕无码专区 | av无码久久久久不卡免费网站 | 东京热一精品无码av | 中文字幕无码乱人伦 | 牛和人交xxxx欧美 | 日韩人妻系列无码专区 | 亚洲国产午夜精品理论片 | 欧美大屁股xxxxhd黑色 | 亚洲日韩av片在线观看 | 亚洲国精产品一二二线 | 亚洲啪av永久无码精品放毛片 | 97无码免费人妻超级碰碰夜夜 | 无码播放一区二区三区 | 女人和拘做爰正片视频 | 国产精品成人av在线观看 | 性史性农村dvd毛片 | 亚洲中文字幕av在天堂 | 国产莉萝无码av在线播放 | 国产乡下妇女做爰 | 秋霞成人午夜鲁丝一区二区三区 | 国产精品高潮呻吟av久久4虎 | 精品无码成人片一区二区98 | 国产莉萝无码av在线播放 | 67194成是人免费无码 | 成人欧美一区二区三区黑人免费 | 久久精品成人欧美大片 | 成 人 网 站国产免费观看 | 欧美乱妇无乱码大黄a片 | 18精品久久久无码午夜福利 | 国产无遮挡吃胸膜奶免费看 | 国产色精品久久人妻 | 中国大陆精品视频xxxx | 午夜精品久久久久久久 | 国产精品无码永久免费888 | 国产肉丝袜在线观看 | av小次郎收藏 | 99久久精品无码一区二区毛片 | 18黄暴禁片在线观看 | 国产精品久久久久无码av色戒 | 国产精品成人av在线观看 | 少妇无码一区二区二三区 | 毛片内射-百度 | 欧洲欧美人成视频在线 | 亚洲综合在线一区二区三区 | 又大又紧又粉嫩18p少妇 | 超碰97人人做人人爱少妇 | 国产成人人人97超碰超爽8 | 久久久久久久人妻无码中文字幕爆 | 搡女人真爽免费视频大全 | 久久久久久久女国产乱让韩 | 亚洲精品国产a久久久久久 | 日本va欧美va欧美va精品 | 日韩精品久久久肉伦网站 | 国产色xx群视频射精 | 老子影院午夜伦不卡 | 中文字幕无线码免费人妻 | 嫩b人妻精品一区二区三区 | 男女爱爱好爽视频免费看 | 领导边摸边吃奶边做爽在线观看 | 牲交欧美兽交欧美 | 欧美 亚洲 国产 另类 | 欧美日韩视频无码一区二区三 | 亚洲成在人网站无码天堂 | 久久 国产 尿 小便 嘘嘘 | 国产疯狂伦交大片 | 少妇一晚三次一区二区三区 | 亚洲综合无码久久精品综合 | 久久99精品久久久久久动态图 | 国产av人人夜夜澡人人爽麻豆 | 免费国产成人高清在线观看网站 | 久9re热视频这里只有精品 | 99久久久无码国产精品免费 | 国产精品无码成人午夜电影 | 99久久人妻精品免费一区 | 国产色在线 | 国产 | 亚洲天堂2017无码中文 | 爱做久久久久久 | 国产又粗又硬又大爽黄老大爷视 | 亚洲精品综合五月久久小说 | 老熟女重囗味hdxx69 | 99精品国产综合久久久久五月天 | 奇米影视7777久久精品 | 成年美女黄网站色大免费视频 | 久久人人爽人人爽人人片ⅴ | 激情内射亚州一区二区三区爱妻 | 最近中文2019字幕第二页 | 免费人成在线观看网站 | 国产口爆吞精在线视频 | 国产卡一卡二卡三 | 乱人伦人妻中文字幕无码久久网 | 国产超级va在线观看视频 | 国产成人人人97超碰超爽8 | 亚洲精品国产品国语在线观看 | 午夜福利一区二区三区在线观看 | 久久亚洲中文字幕无码 | 亚洲欧美日韩综合久久久 | 日韩亚洲欧美精品综合 | 亚欧洲精品在线视频免费观看 | 久久精品一区二区三区四区 | 久久精品国产日本波多野结衣 | 男女猛烈xx00免费视频试看 | 一区二区三区乱码在线 | 欧洲 | 荡女精品导航 | 亚洲理论电影在线观看 | 亚洲午夜福利在线观看 | 精品无人国产偷自产在线 | 亚洲狠狠婷婷综合久久 | 精品欧美一区二区三区久久久 | 伊人色综合久久天天小片 | 婷婷丁香五月天综合东京热 | 扒开双腿吃奶呻吟做受视频 | 国产精品第一国产精品 | 久久99热只有频精品8 | 亚洲欧美日韩国产精品一区二区 | 国产成人综合美国十次 | 99er热精品视频 | 欧美日韩在线亚洲综合国产人 | 成 人 网 站国产免费观看 | 丰满人妻精品国产99aⅴ | 日本在线高清不卡免费播放 | 99精品视频在线观看免费 | 国产成人精品优优av | 成人一在线视频日韩国产 | 老熟妇仑乱视频一区二区 | 中文字幕av日韩精品一区二区 | 人人妻人人澡人人爽人人精品 | 未满成年国产在线观看 | 久久久av男人的天堂 | 日日麻批免费40分钟无码 | 日本一卡2卡3卡四卡精品网站 | 色偷偷人人澡人人爽人人模 | 亚洲区小说区激情区图片区 | 精品熟女少妇av免费观看 | 亚洲精品午夜国产va久久成人 | 国产人妻精品午夜福利免费 | 亚洲综合无码久久精品综合 | 国产口爆吞精在线视频 | 国产在线一区二区三区四区五区 | 中文字幕人妻丝袜二区 | 日韩精品成人一区二区三区 | 国产无av码在线观看 | 欧美国产日韩亚洲中文 | 亚洲毛片av日韩av无码 | 精品成人av一区二区三区 | 国产成人精品三级麻豆 | 亚洲日本在线电影 | 鲁鲁鲁爽爽爽在线视频观看 | av香港经典三级级 在线 | 大地资源网第二页免费观看 | 亚洲人成网站免费播放 | 国产精品美女久久久网av | 99久久亚洲精品无码毛片 | 纯爱无遮挡h肉动漫在线播放 | 狠狠色色综合网站 | 精品无码国产自产拍在线观看蜜 | 九九在线中文字幕无码 | 亚洲自偷自拍另类第1页 | 国语自产偷拍精品视频偷 | 久久精品国产亚洲精品 | 日日橹狠狠爱欧美视频 | 在线观看国产一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | аⅴ资源天堂资源库在线 | 狠狠亚洲超碰狼人久久 | 亚洲欧洲日本无在线码 | 亚洲第一无码av无码专区 | 亚洲成a人片在线观看无码3d | 免费观看又污又黄的网站 | 99久久久国产精品无码免费 | 亚洲爆乳精品无码一区二区三区 | 欧美人与善在线com | 中文字幕av日韩精品一区二区 | 无码人妻丰满熟妇区毛片18 | 国产精品亚洲а∨无码播放麻豆 | 国产内射老熟女aaaa | 成人无码精品一区二区三区 | 国产精品久久久久久亚洲毛片 | 人人澡人摸人人添 | 一区二区三区高清视频一 | 亚洲另类伦春色综合小说 | 亚洲精品一区二区三区大桥未久 | 又大又黄又粗又爽的免费视频 | 欧美精品无码一区二区三区 | 少妇愉情理伦片bd | 日韩人妻系列无码专区 | 99在线 | 亚洲 | 午夜精品久久久内射近拍高清 | 亚洲欧美精品aaaaaa片 | 久久精品国产一区二区三区肥胖 | 色综合视频一区二区三区 | 亚洲国产精华液网站w | 欧美一区二区三区 | 国产超级va在线观看视频 | 久久99精品国产麻豆蜜芽 | 欧美亚洲日韩国产人成在线播放 | 大胆欧美熟妇xx | 性啪啪chinese东北女人 | aⅴ亚洲 日韩 色 图网站 播放 | 色 综合 欧美 亚洲 国产 | 99国产欧美久久久精品 | 久久综合九色综合97网 | 99re在线播放 | 久精品国产欧美亚洲色aⅴ大片 | 成人无码精品1区2区3区免费看 | 夜夜躁日日躁狠狠久久av | 超碰97人人射妻 | 人妻与老人中文字幕 | 动漫av一区二区在线观看 | 成人三级无码视频在线观看 | 成人欧美一区二区三区黑人 | 青草青草久热国产精品 | 国产手机在线αⅴ片无码观看 | 亚洲国精产品一二二线 | 小sao货水好多真紧h无码视频 | 日韩少妇白浆无码系列 | 亚洲国产一区二区三区在线观看 | 美女毛片一区二区三区四区 | 少妇一晚三次一区二区三区 | 偷窥日本少妇撒尿chinese | 99久久精品无码一区二区毛片 | 国产成人精品久久亚洲高清不卡 | 欧美35页视频在线观看 | 精品无码一区二区三区的天堂 | 99久久无码一区人妻 | 久久精品国产一区二区三区肥胖 | 成人综合网亚洲伊人 | 女人色极品影院 | 国产亚洲日韩欧美另类第八页 | 玩弄人妻少妇500系列视频 | 精品无码国产一区二区三区av | 宝宝好涨水快流出来免费视频 | 久久国语露脸国产精品电影 | 最近中文2019字幕第二页 | 亚洲人亚洲人成电影网站色 | 高清国产亚洲精品自在久久 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 在线观看国产午夜福利片 | 久久久久亚洲精品中文字幕 | 熟女少妇人妻中文字幕 | 无套内射视频囯产 | 国产精品欧美成人 | 成人性做爰aaa片免费看不忠 | 亚洲另类伦春色综合小说 | 亚洲精品综合五月久久小说 | 久久精品国产99久久6动漫 | 精品日本一区二区三区在线观看 | 国产三级精品三级男人的天堂 | 人人妻人人澡人人爽欧美精品 | 亚洲aⅴ无码成人网站国产app | v一区无码内射国产 | 老司机亚洲精品影院无码 | 欧美 日韩 亚洲 在线 | 国产精品毛多多水多 | 国产成人无码av片在线观看不卡 | 老太婆性杂交欧美肥老太 | 久久99精品久久久久婷婷 | 黑人巨大精品欧美黑寡妇 | 亚洲男人av香蕉爽爽爽爽 | 久久久久se色偷偷亚洲精品av | 荫蒂被男人添的好舒服爽免费视频 | av在线亚洲欧洲日产一区二区 | 一本久久伊人热热精品中文字幕 | 国产成人无码a区在线观看视频app | 性欧美熟妇videofreesex | √8天堂资源地址中文在线 | 丝袜美腿亚洲一区二区 | 性生交大片免费看l | 97久久超碰中文字幕 | 亚洲精品国产品国语在线观看 | 少妇性俱乐部纵欲狂欢电影 | 亚洲色大成网站www | 国产一区二区不卡老阿姨 | 人妻体内射精一区二区三四 | 亚洲精品国产a久久久久久 | 色一情一乱一伦一视频免费看 | www一区二区www免费 | 国产精品理论片在线观看 | 久久久久久亚洲精品a片成人 | 亚洲精品成人福利网站 | 亚洲精品鲁一鲁一区二区三区 | 久久精品视频在线看15 | 无码人妻黑人中文字幕 | 青青久在线视频免费观看 | 初尝人妻少妇中文字幕 | 久久午夜无码鲁丝片 | 婷婷五月综合激情中文字幕 | 亚洲国精产品一二二线 | 免费国产黄网站在线观看 | 欧美熟妇另类久久久久久多毛 | 国产精品美女久久久网av | 一本大道久久东京热无码av | 国产9 9在线 | 中文 | 日韩精品成人一区二区三区 | 人妻有码中文字幕在线 | 人人爽人人澡人人人妻 | 久久亚洲中文字幕无码 | 成人亚洲精品久久久久软件 | 丰满诱人的人妻3 | 无码精品国产va在线观看dvd | 波多野结衣乳巨码无在线观看 | 欧美性黑人极品hd | 亚洲欧美日韩国产精品一区二区 | 欧美亚洲日韩国产人成在线播放 | 色爱情人网站 | 大乳丰满人妻中文字幕日本 | 国产精品无码一区二区三区不卡 | 色欲综合久久中文字幕网 | 亚洲第一无码av无码专区 | 日本丰满护士爆乳xxxx | 欧洲极品少妇 | 国产成人一区二区三区在线观看 | 97无码免费人妻超级碰碰夜夜 | 男人扒开女人内裤强吻桶进去 | 免费人成在线视频无码 | 无码播放一区二区三区 | 少妇激情av一区二区 | 国产综合色产在线精品 | 女人被爽到呻吟gif动态图视看 | 乌克兰少妇xxxx做受 | 成在人线av无码免观看麻豆 | 丰满诱人的人妻3 | 天堂在线观看www | 日本一区二区三区免费高清 | 亚洲精品成a人在线观看 | 免费无码的av片在线观看 | 香港三级日本三级妇三级 | 亚洲综合另类小说色区 | 熟女体下毛毛黑森林 | 日韩人妻系列无码专区 | 少妇人妻偷人精品无码视频 | 77777熟女视频在线观看 а天堂中文在线官网 | 精品 日韩 国产 欧美 视频 | 国产精品久久国产三级国 | 国产又粗又硬又大爽黄老大爷视 | 夜夜高潮次次欢爽av女 | 强伦人妻一区二区三区视频18 | 欧美人与牲动交xxxx | 久久精品国产亚洲精品 | 强辱丰满人妻hd中文字幕 | 最近中文2019字幕第二页 | 少女韩国电视剧在线观看完整 | 伊人久久大香线蕉av一区二区 | 18无码粉嫩小泬无套在线观看 | 国产精品18久久久久久麻辣 | 综合激情五月综合激情五月激情1 | 男人的天堂av网站 | 国产内射老熟女aaaa | 人人澡人人透人人爽 | 日韩欧美中文字幕公布 | 少妇激情av一区二区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 少妇厨房愉情理9仑片视频 | 久久精品中文闷骚内射 | 性生交大片免费看l | 97夜夜澡人人爽人人喊中国片 | 亚洲自偷自拍另类第1页 | 国产精品久久久久久亚洲影视内衣 | 国产人成高清在线视频99最全资源 | 在线播放免费人成毛片乱码 | 国产又爽又猛又粗的视频a片 | 国产亚洲视频中文字幕97精品 | 精品国精品国产自在久国产87 | 精品人妻人人做人人爽 | 免费看男女做好爽好硬视频 | 国产熟女一区二区三区四区五区 | 精品久久久久久人妻无码中文字幕 | 久久久久久久女国产乱让韩 | 久久精品中文字幕大胸 | 美女黄网站人色视频免费国产 | 国产黄在线观看免费观看不卡 | 亚洲无人区一区二区三区 | 亚洲色欲久久久综合网东京热 | 丰满岳乱妇在线观看中字无码 | 日韩精品乱码av一区二区 | 成人无码精品1区2区3区免费看 | 中文字幕乱码人妻二区三区 | 精品亚洲韩国一区二区三区 | 欧洲欧美人成视频在线 | 亚洲国产av精品一区二区蜜芽 | 娇妻被黑人粗大高潮白浆 | 波多野结衣 黑人 | 久久人人爽人人爽人人片ⅴ | 日本丰满护士爆乳xxxx | 亚洲乱码国产乱码精品精 | 国产成人一区二区三区别 | 在线а√天堂中文官网 | 国产高清不卡无码视频 | 国产成人精品视频ⅴa片软件竹菊 | 精品无码国产自产拍在线观看蜜 | 国产精品美女久久久网av | 欧美阿v高清资源不卡在线播放 | 成 人影片 免费观看 | 大乳丰满人妻中文字幕日本 | 少妇被黑人到高潮喷出白浆 | 国产精品va在线播放 | 未满小14洗澡无码视频网站 | 国产艳妇av在线观看果冻传媒 | 午夜成人1000部免费视频 | 日韩精品乱码av一区二区 | 久久久久成人片免费观看蜜芽 | 国产成人精品视频ⅴa片软件竹菊 | 免费观看的无遮挡av | 亲嘴扒胸摸屁股激烈网站 | 久久亚洲中文字幕精品一区 | 偷窥日本少妇撒尿chinese | 日日摸日日碰夜夜爽av | 亚洲熟妇自偷自拍另类 | 少妇被粗大的猛进出69影院 | 十八禁视频网站在线观看 | 鲁一鲁av2019在线 | 久久精品中文闷骚内射 | 国产在线精品一区二区高清不卡 | 99精品久久毛片a片 | 成人无码精品1区2区3区免费看 | 日本熟妇人妻xxxxx人hd | 亚洲自偷精品视频自拍 | 少妇无套内谢久久久久 | 亚洲精品久久久久久久久久久 | 超碰97人人做人人爱少妇 | 乱人伦人妻中文字幕无码 | 亚洲精品国偷拍自产在线麻豆 | 欧美成人高清在线播放 | 日本欧美一区二区三区乱码 | 少妇高潮喷潮久久久影院 | 蜜臀av在线播放 久久综合激激的五月天 | 久久99久久99精品中文字幕 | 女人被男人爽到呻吟的视频 | 亚洲男人av香蕉爽爽爽爽 | 国产一区二区三区日韩精品 | 国产后入清纯学生妹 | 亚洲一区av无码专区在线观看 | 久久精品无码一区二区三区 | 撕开奶罩揉吮奶头视频 | 巨爆乳无码视频在线观看 | 美女黄网站人色视频免费国产 | 国产一区二区三区精品视频 | 性欧美牲交xxxxx视频 | 国产女主播喷水视频在线观看 | 亚洲综合伊人久久大杳蕉 | 樱花草在线播放免费中文 | 丰腴饱满的极品熟妇 | 性欧美videos高清精品 | 伊人色综合久久天天小片 | 图片小说视频一区二区 | 特黄特色大片免费播放器图片 | а√天堂www在线天堂小说 | 妺妺窝人体色www在线小说 | 无码一区二区三区在线观看 | 久久精品中文字幕一区 | 少妇人妻av毛片在线看 | 欧美国产日韩久久mv | 两性色午夜免费视频 | 亚洲成a人片在线观看无码 | 国产精品久久久久无码av色戒 | 久精品国产欧美亚洲色aⅴ大片 | 日本丰满护士爆乳xxxx | 日本熟妇乱子伦xxxx | 国产午夜手机精彩视频 | 爱做久久久久久 | 日韩成人一区二区三区在线观看 | 久久久久久国产精品无码下载 | 国产人妻大战黑人第1集 | 久久久久人妻一区精品色欧美 | 国产特级毛片aaaaaa高潮流水 | 国产成人久久精品流白浆 | 无码av岛国片在线播放 | 亚洲最大成人网站 | 日本大乳高潮视频在线观看 | 国产三级久久久精品麻豆三级 | 野狼第一精品社区 | 大地资源网第二页免费观看 | 亚洲一区二区三区在线观看网站 | 99久久久国产精品无码免费 | 亚洲精品无码人妻无码 | 无码精品人妻一区二区三区av | 国产sm调教视频在线观看 | 日韩av激情在线观看 | 欧美xxxxx精品 | 国产激情无码一区二区 | 中文字幕无线码免费人妻 | 东京无码熟妇人妻av在线网址 | 久久亚洲精品中文字幕无男同 | 亚洲а∨天堂久久精品2021 | 久久无码人妻影院 | 香蕉久久久久久av成人 | 日韩av无码一区二区三区不卡 | 全球成人中文在线 | 九九久久精品国产免费看小说 | 人人妻人人澡人人爽欧美精品 | 夜夜高潮次次欢爽av女 | 激情五月综合色婷婷一区二区 | 日韩人妻无码一区二区三区久久99 | 国产精品18久久久久久麻辣 | 久久视频在线观看精品 | 久久97精品久久久久久久不卡 | 性欧美熟妇videofreesex | 国产性生交xxxxx无码 | av无码不卡在线观看免费 | 国产在线精品一区二区三区直播 | 曰本女人与公拘交酡免费视频 | 日韩 欧美 动漫 国产 制服 | 暴力强奷在线播放无码 | 日韩av无码一区二区三区不卡 | 日韩av无码一区二区三区不卡 | 九九久久精品国产免费看小说 | 欧美国产亚洲日韩在线二区 | 日韩av无码中文无码电影 | 国产免费久久久久久无码 | 国产亚洲精品久久久久久大师 | 亚洲gv猛男gv无码男同 | 日韩欧美中文字幕在线三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 欧美日韩亚洲国产精品 | 一本色道久久综合狠狠躁 | 精品一区二区三区波多野结衣 | 在线播放亚洲第一字幕 | 亚洲热妇无码av在线播放 | 国产三级久久久精品麻豆三级 | 激情内射亚州一区二区三区爱妻 | 宝宝好涨水快流出来免费视频 | 欧美真人作爱免费视频 | 亚洲精品国产a久久久久久 | 97久久超碰中文字幕 | 亚洲自偷自偷在线制服 | 国产亚洲精品久久久久久 | 中文字幕无线码免费人妻 | 4hu四虎永久在线观看 | a国产一区二区免费入口 | 少妇久久久久久人妻无码 | 人人超人人超碰超国产 | 久久精品人妻少妇一区二区三区 | 久久伊人色av天堂九九小黄鸭 | 天天拍夜夜添久久精品 | 国产在线精品一区二区三区直播 | 伊人久久大香线蕉av一区二区 | 亚洲 高清 成人 动漫 | 亚洲成熟女人毛毛耸耸多 | v一区无码内射国产 | 国产亚洲人成a在线v网站 | 国产午夜亚洲精品不卡下载 | 亚洲精品午夜国产va久久成人 | 欧美国产日韩久久mv | 欧美老人巨大xxxx做受 | 波多野结衣av一区二区全免费观看 | 国产97人人超碰caoprom | 亚洲熟女一区二区三区 | 亚洲熟妇自偷自拍另类 | av无码不卡在线观看免费 | 无码人妻av免费一区二区三区 | 丝袜美腿亚洲一区二区 | 思思久久99热只有频精品66 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲日韩一区二区三区 | 成人性做爰aaa片免费看 | 亚洲色欲色欲欲www在线 | 久久精品女人的天堂av | 人妻少妇精品无码专区二区 | 国产av久久久久精东av | 又大又硬又爽免费视频 | 久久99精品国产麻豆 | 无码午夜成人1000部免费视频 | 人妻无码αv中文字幕久久琪琪布 | 性生交大片免费看女人按摩摩 | 亚洲国产av精品一区二区蜜芽 | 国产 浪潮av性色四虎 | 中文毛片无遮挡高清免费 | 日韩成人一区二区三区在线观看 | 国产97色在线 | 免 | 精品午夜福利在线观看 | 午夜成人1000部免费视频 | 一本色道久久综合亚洲精品不卡 | 亚洲色欲色欲欲www在线 | 亚洲aⅴ无码成人网站国产app | 亚洲成av人片天堂网无码】 | 国产亚洲日韩欧美另类第八页 | 永久免费精品精品永久-夜色 | 99精品国产综合久久久久五月天 | 亚洲精品久久久久久久久久久 | 内射老妇bbwx0c0ck | 精品一区二区不卡无码av | 亚洲区欧美区综合区自拍区 | 一本久道久久综合狠狠爱 | 亚洲色欲色欲天天天www | 欧美zoozzooz性欧美 | 国产成人综合美国十次 | 精品无人国产偷自产在线 | 久久熟妇人妻午夜寂寞影院 | 九一九色国产 | 欧美丰满熟妇xxxx性ppx人交 | 午夜福利试看120秒体验区 | 中文字幕av无码一区二区三区电影 | 色窝窝无码一区二区三区色欲 | 国产婷婷色一区二区三区在线 | 国产真实伦对白全集 | 草草网站影院白丝内射 | 国产精品成人av在线观看 | 欧美日韩视频无码一区二区三 | 伊人久久大香线蕉av一区二区 | 乌克兰少妇性做爰 | 亚洲国产精品美女久久久久 | 又大又黄又粗又爽的免费视频 | 国产99久久精品一区二区 | 俺去俺来也www色官网 | 日本高清一区免费中文视频 | 性做久久久久久久久 | 国产熟女一区二区三区四区五区 | 日韩在线不卡免费视频一区 | 牛和人交xxxx欧美 | 日韩少妇白浆无码系列 | 无码人妻久久一区二区三区不卡 | 强辱丰满人妻hd中文字幕 | 国产精品成人av在线观看 | 国内揄拍国内精品少妇国语 | 久久久无码中文字幕久... | 国产性生交xxxxx无码 | 亚洲成av人影院在线观看 | 综合人妻久久一区二区精品 | 大色综合色综合网站 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲自偷自拍另类第1页 | 蜜臀av无码人妻精品 | 亚洲の无码国产の无码影院 | 国产精品理论片在线观看 | 国产suv精品一区二区五 | 人人澡人人透人人爽 | 久久aⅴ免费观看 | 草草网站影院白丝内射 | 国产成人无码a区在线观看视频app | 少妇无码吹潮 | 国产片av国语在线观看 | 国产综合色产在线精品 | 国产黑色丝袜在线播放 | 欧美日韩视频无码一区二区三 | 国产av一区二区精品久久凹凸 | 蜜桃av抽搐高潮一区二区 | 国产色视频一区二区三区 | 18禁黄网站男男禁片免费观看 | 精品成在人线av无码免费看 | 成在人线av无码免观看麻豆 | 成人三级无码视频在线观看 | 欧美性猛交内射兽交老熟妇 | 国产精品无码一区二区三区不卡 | 国语精品一区二区三区 | 日日碰狠狠躁久久躁蜜桃 | a片免费视频在线观看 | 日本免费一区二区三区最新 | 真人与拘做受免费视频一 | 久久99久久99精品中文字幕 | 超碰97人人做人人爱少妇 | 性做久久久久久久久 | 在线成人www免费观看视频 | 色婷婷久久一区二区三区麻豆 | 成人精品视频一区二区 | 国产极品美女高潮无套在线观看 | 无码毛片视频一区二区本码 | 色老头在线一区二区三区 | 亚洲乱码中文字幕在线 | 日本在线高清不卡免费播放 | 国产成人久久精品流白浆 | 98国产精品综合一区二区三区 | 桃花色综合影院 | 无遮挡啪啪摇乳动态图 | 国产精品怡红院永久免费 | 久久久中文久久久无码 | 清纯唯美经典一区二区 | 国产精品va在线播放 | 大地资源网第二页免费观看 | 色欲人妻aaaaaaa无码 | 久久精品人人做人人综合试看 | 18禁止看的免费污网站 | 欧美兽交xxxx×视频 | 丰满少妇女裸体bbw | 成年美女黄网站色大免费全看 | 亚洲精品久久久久中文第一幕 | 精品亚洲成av人在线观看 | 双乳奶水饱满少妇呻吟 | 内射白嫩少妇超碰 | 偷窥日本少妇撒尿chinese | 成人性做爰aaa片免费看不忠 | 99在线 | 亚洲 | 中文字幕人妻无码一区二区三区 | 88国产精品欧美一区二区三区 | 激情内射日本一区二区三区 | 亚洲男女内射在线播放 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲一区二区三区国产精华液 | 无码人妻精品一区二区三区不卡 | 亚洲の无码国产の无码影院 | 青草青草久热国产精品 | 永久免费精品精品永久-夜色 | 1000部夫妻午夜免费 | 十八禁视频网站在线观看 | 日本欧美一区二区三区乱码 | 精品久久久久香蕉网 | 九九在线中文字幕无码 | 高潮喷水的毛片 | 国产无av码在线观看 | 成人性做爰aaa片免费看不忠 | 国产特级毛片aaaaaa高潮流水 |