国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Java求最小生成樹(shù)的兩種算法詳解

 更新時(shí)間:2022年01月25日 15:34:03   作者:劉Java  
最小生成樹(shù)(Minimum Spanning Tree):在連通圖的所有生成樹(shù)中,所有邊的權(quán)值和最小的生成樹(shù),稱(chēng)為最小生成樹(shù)。這篇文章主要介紹了求最小生成樹(shù)的兩種方法:Prim算法和Kruskal算法,需要的可以參考一下

介紹了圖的最小生成樹(shù)的概念,然后介紹了求最小生成樹(shù)的兩種算法:Prim算法和Kruskal算法的原理,最后提供了基于鄰接矩陣和鄰接鏈表的圖對(duì)兩種算法的Java實(shí)現(xiàn)。

閱讀本文需要一定的圖的基礎(chǔ),如果對(duì)于圖不是太明白的可以看看這篇文章:Java數(shù)據(jù)結(jié)構(gòu)之圖的原理與實(shí)現(xiàn)。

1 最小生成樹(shù)的概述

生成樹(shù)(SpanningTree):一個(gè)連通圖的生成樹(shù)是指一個(gè)連通子圖,它含有圖中全部n個(gè)頂點(diǎn),但只有足以構(gòu)成一棵樹(shù)的n-1條邊。一顆有n個(gè)頂點(diǎn)的生成樹(shù)有且僅有n-1條邊,如果生成樹(shù)中再添加一條邊,則必定成環(huán)。

最小生成樹(shù)(Minimum Spanning Tree):在連通圖的所有生成樹(shù)中,所有邊的權(quán)值和最小的生成樹(shù),稱(chēng)為最小生成樹(shù)。

在生活中,圖形結(jié)構(gòu)的應(yīng)用是最廣泛的。比如常見(jiàn)的通信網(wǎng)絡(luò)搭建路線選擇,村莊可以看作頂點(diǎn),村莊之間如果有通信路徑,則算作兩點(diǎn)之間的邊或者弧,兩個(gè)村莊之間的通信成本,可以看作邊或者弧的權(quán)值。

上圖就是生活中通信網(wǎng)絡(luò)搭建路線的選擇映射到圖形結(jié)構(gòu)的案例。頂點(diǎn)作為村莊,村莊之間如果有通信路徑則擁有邊,村莊的之間的通信搭建成本則是邊的權(quán)值。

一種很常見(jiàn)的需求是要求對(duì)于能夠通信的村莊都必須通信,并且通信建設(shè)成本和最小,畢竟經(jīng)費(fèi)“有限”,省下來(lái)的經(jīng)費(fèi),嘿嘿!

上面的問(wèn)題,轉(zhuǎn)換為數(shù)學(xué)模型,就是求一個(gè)圖的最小生成樹(shù)的問(wèn)題,即:選出一條路線,連通了所有能夠連通頂點(diǎn),并且權(quán)值和最小。這樣的問(wèn)題已經(jīng)有了很多種解法,最經(jīng)典的有兩種算法,普里姆(Prim)算法和克魯斯卡爾(Kruskal)算法。

2 普里姆算法(Prim)

2.1 原理

普里姆(Prim)算法是以某頂點(diǎn)為起點(diǎn),假設(shè)所有頂點(diǎn)均未連接,逐步找各頂點(diǎn)上最小權(quán)值的邊來(lái)連接并構(gòu)建最小生成樹(shù)。是以點(diǎn)為目標(biāo)去構(gòu)建最小生成樹(shù)。

具體的步驟是: 首先隨機(jī)選取一個(gè)頂點(diǎn)a,尋找頂點(diǎn)a可連接所有的頂點(diǎn),選擇一個(gè)權(quán)值低的頂點(diǎn)進(jìn)行連接;然后尋找與這兩個(gè)頂點(diǎn)或可連接的所有頂點(diǎn),選擇一個(gè)權(quán)值低的頂點(diǎn)與其中一個(gè)頂點(diǎn)進(jìn)行連接;如此往復(fù)n-1次,每次選擇距離任意一個(gè)已連接末端頂點(diǎn)最短的頂點(diǎn)(而不是距離首個(gè)頂點(diǎn)最短的頂點(diǎn))進(jìn)行連接,直到所有的頂點(diǎn)都進(jìn)行連接,至此最小生成樹(shù)構(gòu)建完畢。

2.2 案例分析

該案例對(duì)應(yīng)著下面實(shí)現(xiàn)代碼中的案例。

在上面的圖中,首先選擇頂點(diǎn)A作為已連接點(diǎn),尋找頂點(diǎn)A可連接所有的頂點(diǎn)C、D、F,選擇一個(gè)權(quán)值低的頂點(diǎn)進(jìn)行連接,這里選擇A-C;

然后尋找與A或C可連接的所有頂點(diǎn)(排除已連接的點(diǎn)),找到B、D、F,一共有4條邊可選,A-D、A-F、C-B、C-D,選擇一個(gè)權(quán)值低的頂點(diǎn)與其中一個(gè)頂點(diǎn)進(jìn)行連接,這里明顯選擇A-D連接;

然后尋找與A或C或D可連接的所有頂點(diǎn)(排除已連接的點(diǎn)),找到B、F,一共有3條邊可選,C-B、D-B、A-F,選擇一個(gè)權(quán)值低的頂點(diǎn)與其中一個(gè)頂點(diǎn)進(jìn)行連接,這里明顯選擇A-F連接;

然后尋找與A或C或D或F可連接的所有頂點(diǎn)(排除已連接的點(diǎn)),找到B、G,一共有3條邊可選,C-B、D-B、F-G,選擇一個(gè)權(quán)值低的頂點(diǎn)與其中一個(gè)頂點(diǎn)進(jìn)行連接,這里明顯選擇C-B連接;

然后尋找與A或C或D或F或B可連接的所有頂點(diǎn)(排除已連接的點(diǎn)),找到E、G,一共有2條邊可選,B-E、F-G,選擇一個(gè)權(quán)值低的頂點(diǎn)與其中一個(gè)頂點(diǎn)進(jìn)行連接,這里明顯選擇B-E連接;

然后尋找與A或C或D或F或B或E可連接的所有頂點(diǎn)(排除已連接的點(diǎn)),找到G,一共有2條邊可選,E-G、F-G,選擇一個(gè)權(quán)值低的頂點(diǎn)與其中一個(gè)頂點(diǎn)進(jìn)行連接,這里明顯選擇E-G連接;

所有的頂點(diǎn)連接完畢,此時(shí)最小生成樹(shù)已經(jīng)構(gòu)建好了,最小權(quán)值為23。

3 克魯斯卡爾算法(Kruskal)

3.1 原理

克魯斯卡爾算法(Kruskal)根據(jù)邊的權(quán)值以遞增的方式逐漸建立最小生成樹(shù),是以邊為目標(biāo)去構(gòu)建最小生成樹(shù)。

具體的步驟是: 將加權(quán)圖每個(gè)頂點(diǎn)都看做森林,然后將圖中每條鄰接邊的權(quán)值按照升序的方式進(jìn)行排列,接著從排列好的鄰接邊表中抽取權(quán)值最小的邊,寫(xiě)入該邊的起始頂點(diǎn)和結(jié)束頂點(diǎn),連接頂點(diǎn)將森林構(gòu)成樹(shù),然后讀取起始結(jié)束頂點(diǎn)的鄰接邊,優(yōu)先抽取權(quán)值小的鄰接邊,繼續(xù)連接頂點(diǎn)將森林構(gòu)成樹(shù)。添加鄰接邊的要求是加入到圖中的鄰接邊不構(gòu)成回路(環(huán))。如此反復(fù)進(jìn)行,直到已經(jīng)添加n-1條邊為止。至此最小生成樹(shù)構(gòu)建完畢。

3.2 案例分析

該案例對(duì)應(yīng)著下面實(shí)現(xiàn)代碼中的案例,傳統(tǒng)Kruskal算法過(guò)程如下:

首先獲取邊集數(shù)組并按照權(quán)值重小到大進(jìn)行排序,在代碼中的排序本人直接使用的sort排序,也可以自己實(shí)現(xiàn)堆排序,排序后結(jié)果如下:

Edge{from=A, to=C, weight=1}
Edge{from=D, to=A, weight=2}
Edge{from=A, to=F, weight=3}
Edge{from=B, to=C, weight=4}
Edge{from=C, to=D, weight=5}
Edge{from=E, to=G, weight=6}
Edge{from=E, to=B, weight=7}
Edge{from=D, to=B, weight=8}
Edge{from=F, to=G, weight=9}

循環(huán)取出第1條邊A-C,判斷與已經(jīng)找到的最小生成樹(shù)不會(huì)形成環(huán),權(quán)值總和增加1,繼續(xù);

循環(huán)取出第2條邊D-A,判斷與已經(jīng)找到的最小生成樹(shù)不會(huì)形成環(huán),權(quán)值總和增加2,繼續(xù);

循環(huán)取出第3條邊A-F,判斷與已經(jīng)找到的最小生成樹(shù)不會(huì)形成環(huán),權(quán)值總和增加3,繼續(xù);

循環(huán)取出第4條邊B-C,判斷與已經(jīng)找到的最小生成樹(shù)不會(huì)形成環(huán),權(quán)值總和增加4,繼續(xù);

循環(huán)取出第5條邊C-D,判斷與已經(jīng)找到的最小生成樹(shù)會(huì)形成環(huán),該條邊丟棄,繼續(xù);

循環(huán)取出第6條邊E-G,判斷與已經(jīng)找到的最小生成樹(shù)不會(huì)形成環(huán),權(quán)值總和增加6,繼續(xù);

循環(huán)取出第7條邊E-B,判斷與已經(jīng)找到的最小生成樹(shù)不會(huì)形成環(huán),權(quán)值總和增加7,繼續(xù);

循環(huán)取出第8條邊D-B,判斷與已經(jīng)找到的最小生成樹(shù)會(huì)形成環(huán),該條邊丟棄,繼續(xù);

循環(huán)取出第9條邊F-G,判斷與已經(jīng)找到的最小生成樹(shù)會(huì)形成環(huán),該條邊丟棄,繼續(xù);

此時(shí)循環(huán)結(jié)束,那么最小生成樹(shù)也已經(jīng)找到了,最小生成樹(shù)的權(quán)值總和為23。

上面步驟中,判斷是否形成環(huán)很關(guān)鍵,通常的做法是,對(duì)已經(jīng)找到的最小生成樹(shù)的頂點(diǎn)進(jìn)行排序(從起點(diǎn)到終點(diǎn)),然后每新添加一條邊,就使用新添加邊的起點(diǎn)和終點(diǎn)取最小二叉樹(shù)中尋找,排序后的終點(diǎn),找到的終點(diǎn)一致,則說(shuō)明最小生成樹(shù)加上這條邊就會(huì)形成環(huán),否則說(shuō)明不會(huì),那么更新排序的終點(diǎn)。

4 鄰接矩陣加權(quán)圖實(shí)現(xiàn)

這里的實(shí)現(xiàn)能夠構(gòu)造一個(gè)基于鄰接矩陣實(shí)現(xiàn)無(wú)向加權(quán)圖的類(lèi),并且提供深度優(yōu)先遍歷和廣度優(yōu)先遍歷的方法,提供獲取邊集數(shù)組的方法,提供Prim和Kruskal兩種求最小生成樹(shù)的方法。

/**
 * 無(wú)向加權(quán)圖鄰接矩陣實(shí)現(xiàn)
 * {@link MatrixPrimAndKruskal#MatrixPrimAndKruskal(E[], Edge[])}  構(gòu)建無(wú)向加權(quán)圖
 * {@link MatrixPrimAndKruskal#DFS()}  深度優(yōu)先遍歷無(wú)向加權(quán)圖
 * {@link MatrixPrimAndKruskal#BFS()}  廣度優(yōu)先遍歷無(wú)向加權(quán)圖
 * {@link MatrixPrimAndKruskal#toString()}  輸出無(wú)向加權(quán)圖
 * {@link MatrixPrimAndKruskal#prim()}  Prim算法實(shí)現(xiàn)最小生成樹(shù)
 * {@link MatrixPrimAndKruskal#kruskal()}   Kruskal算法實(shí)現(xiàn)最小生成樹(shù)
 * {@link MatrixPrimAndKruskal#kruskalAndPrim()}  Kruskal算法結(jié)合Prim算法實(shí)現(xiàn)最小生成樹(shù)
 * {@link MatrixPrimAndKruskal#getEdges()}  獲取邊集數(shù)組
 *
 * @author lx
 * @date 2020/5/14 18:13
 */
public class MatrixPrimAndKruskal<E> {

    /**
     * 頂點(diǎn)數(shù)組
     */
    private Object[] vertexs;

    /**
     * 鄰接矩陣
     */
    private int[][] matrix;

    /**
     *
     */
    private Edge<E>[] edges;

    /**
     * 由于是加權(quán)圖,這里設(shè)置一個(gè)邊的權(quán)值上限,任何邊的最大權(quán)值不能大于等于該值,在實(shí)際應(yīng)用中,該值應(yīng)該根據(jù)實(shí)際情況確定
     */
    private static final int NO_EDGE = 99;


    /**
     * 邊對(duì)象,具有權(quán)值,在構(gòu)建加權(quán)無(wú)向圖時(shí)使用
     */
    private static class Edge<E> {

        private E from;
        private E to;
        private int weight;

        public Edge(E from, E to, int weight) {
            this.from = from;
            this.to = to;
            this.weight = weight;
        }

        @Override
        public String toString() {
            return "Edge{" +
                    "from=" + from +
                    ", to=" + to +
                    ", weight=" + weight +
                    '}';
        }
    }

    /**
     * 創(chuàng)建無(wú)向加權(quán)圖
     *
     * @param vertexs 頂點(diǎn)數(shù)組
     * @param edges   邊對(duì)象數(shù)組
     */
    public MatrixPrimAndKruskal(Object[] vertexs, Edge<E>[] edges) {
        //初始化邊數(shù)組
        this.edges = edges;
        // 初始化頂點(diǎn)數(shù)組,并添加頂點(diǎn)
        this.vertexs = Arrays.copyOf(vertexs, vertexs.length);
        // 初始化邊矩陣,并預(yù)先填充邊信息
        this.matrix = new int[vertexs.length][vertexs.length];
        for (int i = 0; i < vertexs.length; i++) {
            for (int j = 0; j < vertexs.length; j++) {
                if (i == j) {
                    this.matrix[i][j] = 0;
                } else {
                    this.matrix[i][j] = NO_EDGE;
                }
            }
        }
        for (Edge<E> edge : edges) {
            // 讀取一條邊的起始頂點(diǎn)和結(jié)束頂點(diǎn)索引值
            int p1 = getPosition(edge.from);
            int p2 = getPosition(edge.to);
            //對(duì)稱(chēng)的兩個(gè)點(diǎn)位都置為edge.weight,無(wú)向圖可以看作相互可達(dá)的有向圖
            this.matrix[p1][p2] = edge.weight;
            this.matrix[p2][p1] = edge.weight;
        }
    }

    /**
     * 獲取某條邊的某個(gè)頂點(diǎn)所在頂點(diǎn)數(shù)組的索引位置
     *
     * @param e 頂點(diǎn)的值
     * @return 所在頂點(diǎn)數(shù)組的索引位置, 或者-1 - 表示不存在
     */
    private int getPosition(E e) {
        for (int i = 0; i < vertexs.length; i++) {
            if (vertexs[i] == e) {
                return i;
            }
        }
        return -1;
    }


    /**
     * 深度優(yōu)先搜索遍歷圖,類(lèi)似于樹(shù)的前序遍歷,
     */
    public void DFS() {
        //新建頂點(diǎn)訪問(wèn)標(biāo)記數(shù)組,對(duì)應(yīng)每個(gè)索引對(duì)應(yīng)相同索引的頂點(diǎn)數(shù)組中的頂點(diǎn)
        boolean[] visited = new boolean[vertexs.length];
        //初始化所有頂點(diǎn)都沒(méi)有被訪問(wèn)
        for (int i = 0; i < vertexs.length; i++) {
            visited[i] = false;
        }
        System.out.println("DFS: ");
        for (int i = 0; i < vertexs.length; i++) {
            if (!visited[i]) {
                DFS(i, visited);
            }
        }
        System.out.println();
    }

    /**
     * 深度優(yōu)先搜索遍歷圖的遞歸實(shí)現(xiàn),類(lèi)似于樹(shù)的先序遍歷
     * 因此模仿樹(shù)的先序遍歷,同樣借用棧結(jié)構(gòu),這里使用的是方法的遞歸,隱式的借用棧
     *
     * @param i       頂點(diǎn)索引
     * @param visited 訪問(wèn)標(biāo)志數(shù)組
     */
    private void DFS(int i, boolean[] visited) {
        visited[i] = true;
        System.out.print(vertexs[i] + " ");
        // 遍歷該頂點(diǎn)的所有鄰接點(diǎn)。若該鄰接點(diǎn)是沒(méi)有訪問(wèn)過(guò),那么繼續(xù)遞歸遍歷領(lǐng)接點(diǎn)
        for (int w = firstVertex(i); w >= 0; w = nextVertex(i, w)) {
            if (!visited[w]) {
                DFS(w, visited);
            }
        }
    }


    /**
     * 廣度優(yōu)先搜索圖,類(lèi)似于樹(shù)的層序遍歷
     * 因此模仿樹(shù)的層序遍歷,同樣借用隊(duì)列結(jié)構(gòu)
     */
    public void BFS() {
        // 輔組隊(duì)列
        Queue<Integer> indexLinkedList = new LinkedList<>();
        //新建頂點(diǎn)訪問(wèn)標(biāo)記數(shù)組,對(duì)應(yīng)每個(gè)索引對(duì)應(yīng)相同索引的頂點(diǎn)數(shù)組中的頂點(diǎn)
        boolean[] visited = new boolean[vertexs.length];
        for (int i = 0; i < vertexs.length; i++) {
            visited[i] = false;
        }
        System.out.println("BFS: ");
        for (int i = 0; i < vertexs.length; i++) {
            if (!visited[i]) {
                visited[i] = true;
                System.out.print(vertexs[i] + " ");
                indexLinkedList.add(i);
            }
            if (!indexLinkedList.isEmpty()) {
                //j索引出隊(duì)列
                Integer j = indexLinkedList.poll();
                //繼續(xù)訪問(wèn)j的鄰接點(diǎn)
                for (int k = firstVertex(j); k >= 0; k = nextVertex(j, k)) {
                    if (!visited[k]) {
                        visited[k] = true;
                        System.out.print(vertexs[k] + " ");
                        //繼續(xù)入隊(duì)列
                        indexLinkedList.add(k);
                    }
                }
            }
        }
        System.out.println();
    }

    /**
     * 返回頂點(diǎn)v的第一個(gè)鄰接頂點(diǎn)的索引,失敗則返回-1
     *
     * @param v 頂點(diǎn)v在數(shù)組中的索引
     * @return 返回頂點(diǎn)v的第一個(gè)鄰接頂點(diǎn)的索引,失敗則返回-1
     */
    private int firstVertex(int v) {
        //如果索引超出范圍,則返回-1
        if (v < 0 || v > (vertexs.length - 1)) {
            return -1;
        }
        /*根據(jù)鄰接矩陣的規(guī)律:頂點(diǎn)索引v對(duì)應(yīng)著邊二維矩陣的matrix[v][i]一行記錄
         * 從i=0開(kāi)始*/
        for (int i = 0; i < vertexs.length; i++) {
            if (matrix[v][i] != 0 && matrix[v][i] != NO_EDGE) {
                return i;
            }
        }
        return -1;
    }

    /**
     * 返回頂點(diǎn)v相對(duì)于w的下一個(gè)鄰接頂點(diǎn)的索引,失敗則返回-1
     *
     * @param v 頂點(diǎn)索引
     * @param w 第一個(gè)鄰接點(diǎn)索引
     * @return 返回頂點(diǎn)v相對(duì)于w的下一個(gè)鄰接頂點(diǎn)的索引,失敗則返回-1
     */
    private int nextVertex(int v, int w) {
        //如果索引超出范圍,則返回-1
        if (v < 0 || v > (vertexs.length - 1) || w < 0 || w > (vertexs.length - 1)) {
            return -1;
        }
        /*根據(jù)鄰接矩陣的規(guī)律:頂點(diǎn)索引v對(duì)應(yīng)著邊二維矩陣的matrix[v][i]一行記錄
         * 由于鄰接點(diǎn)w的索引已經(jīng)獲取了,所以從i=w+1開(kāi)始尋找*/
        for (int i = w + 1; i < vertexs.length; i++) {
            if (matrix[v][i] != 0 && matrix[v][i] != NO_EDGE) {
                return i;
            }
        }
        return -1;
    }

    /**
     * 輸出圖
     *
     * @return 輸出圖字符串
     */
    @Override
    public String toString() {
        StringBuilder stringBuilder = new StringBuilder();
        for (int i = 0; i < vertexs.length; i++) {
            for (int j = 0; j < vertexs.length; j++) {
                stringBuilder.append(matrix[i][j]).append("\t");
            }
            stringBuilder.append("\n");
        }
        return stringBuilder.toString();
    }

    /**
     * Prim算法求最小生成樹(shù)
     */
    public void prim() {
        System.out.println("prim: ");
        //對(duì)應(yīng)節(jié)點(diǎn)應(yīng)該被連接的前驅(qū)節(jié)點(diǎn),用來(lái)輸出
        //默認(rèn)為0,即前驅(qū)結(jié)點(diǎn)為第一個(gè)節(jié)點(diǎn)
        int[] mid = new int[matrix.length];
        //如果某頂點(diǎn)作為末端頂點(diǎn)被連接,對(duì)應(yīng)位置應(yīng)該為true
        //第一個(gè)頂點(diǎn)默認(rèn)被連接
        boolean[] connected = new boolean[matrix.length];
        connected[0] = true;
        //存儲(chǔ)未連接頂點(diǎn)到已連接頂點(diǎn)的最短距離(最小權(quán))
        int[] dis = new int[matrix.length];
        //首先將矩陣第一行即其他頂點(diǎn)到0索引頂點(diǎn)的權(quán)值拷貝進(jìn)去
        System.arraycopy(matrix[0], 0, dis, 0, matrix.length);
        //存儲(chǔ)路徑長(zhǎng)度
        int sum = 0;
        //最小權(quán)值
        int min;
        /*默認(rèn)第一個(gè)頂點(diǎn)已經(jīng)找到了,因此最多還要需要大循環(huán)n-1次*/
        for (int k = 1; k < matrix.length; k++) {
            min = NO_EDGE;
            //最小權(quán)值的頂點(diǎn)的索引
            int minIndex = 0;
            /*尋找權(quán)值最小的且未被連接的頂點(diǎn)索引*/
            for (int i = 1; i < matrix.length; i++) {
                //排除已連接的頂點(diǎn),排除權(quán)值等于0的值,這里權(quán)值等于0表示已生成的最小生成樹(shù)的頂點(diǎn)都未能與該頂點(diǎn)連接
                if (!connected[i] && dis[i] != 0 && dis[i] < min) {
                    min = dis[i];
                    minIndex = i;
                }
            }
            //如果沒(méi)找到,那么該圖可能不是連通圖,直接返回了,此時(shí)最小生成樹(shù)沒(méi)啥意義
            if (minIndex == 0) {
                return;
            }
            //權(quán)值和增加
            sum += min;
            //該新連接頂點(diǎn)對(duì)應(yīng)的索引值變成true,表示已被連接,后續(xù)判斷時(shí)跳過(guò)該頂點(diǎn)
            connected[minIndex] = true;
            //輸出對(duì)應(yīng)的前驅(qū)頂點(diǎn)到該最小頂點(diǎn)的權(quán)值
            System.out.println(vertexs[mid[minIndex]] + " ---> " + vertexs[minIndex] + " 權(quán)值:" + min);
            /*在新頂點(diǎn)minIndex加入之前的其他所有頂點(diǎn)到連接頂點(diǎn)最小的權(quán)值已經(jīng)計(jì)算過(guò)了
            因此只需要更新其他未連接頂點(diǎn)到新連接頂點(diǎn)minIndex是否還有更短的權(quán)值,有的話就更新找到距離已連接的頂點(diǎn)權(quán)最小的頂點(diǎn)*/
            for (int i = 1; i < matrix.length; i++) {
                //如果該頂點(diǎn)未連接
                if (!connected[i]) {
                    /*如果新頂點(diǎn)到未連接頂點(diǎn)i的權(quán)值不為0,并且比原始頂點(diǎn)到未連接頂點(diǎn)i的權(quán)值還要小,那么更新對(duì)應(yīng)位置的最小權(quán)值*/
                    if (matrix[minIndex][i] != 0 && dis[i] > matrix[minIndex][i]) {
                        //更新最小權(quán)值
                        dis[i] = matrix[minIndex][i];
                        //更新前驅(qū)節(jié)點(diǎn)索引為新加入節(jié)點(diǎn)索引
                        mid[i] = minIndex;
                    }
                }

            }
        }
        System.out.println("sum: " + sum);
    }


    /**
     * Kruskal算法求最小生成樹(shù)傳統(tǒng)實(shí)現(xiàn),要求知道邊集數(shù)組,和頂點(diǎn)數(shù)組
     */
    public void kruskal() {
        System.out.println("Kruskal: ");
        //由于創(chuàng)建圖的時(shí)候保存了邊集數(shù)組,這里直接使用就行了
        //Edge[] edges = getEdges();
        //this.edges=edges;
        //對(duì)邊集數(shù)組進(jìn)行排序
        Arrays.sort(this.edges, Comparator.comparingInt(o -> o.weight));
        // 用于保存已有最小生成樹(shù)中每個(gè)頂點(diǎn)在該最小樹(shù)中的最終終點(diǎn)的索引
        int[] vends = new int[this.edges.length];
        //能夠知道終點(diǎn)索引范圍是[0,this.edges.length-1],因此填充edges.length表示沒(méi)有終點(diǎn)
        Arrays.fill(vends, this.edges.length);
        int sum = 0;
        for (Edge<E> edge : this.edges) {
            // 獲取第i條邊的起點(diǎn)索引from
            int from = getPosition(edge.from);
            // 獲取第i條邊的終點(diǎn)索引to
            int to = getPosition(edge.to);
            // 獲取頂點(diǎn)from在"已有的最小生成樹(shù)"中的終點(diǎn)
            int m = getEndIndex(vends, from);
            // 獲取頂點(diǎn)to在"已有的最小生成樹(shù)"中的終點(diǎn)
            int n = getEndIndex(vends, to);
            // 如果m!=n,意味著沒(méi)有形成環(huán)路,則可以添加,否則直接跳過(guò),進(jìn)行下一條邊的判斷
            if (m != n) {
                //添加設(shè)置原始終點(diǎn)索引m在已有的最小生成樹(shù)中的終點(diǎn)為n
                vends[m] = n;
                System.out.println(vertexs[from] + " ---> " + vertexs[to] + " 權(quán)值:" + edge.weight);
                sum += edge.weight;
            }
        }
        System.out.println("sum: " + sum);
        //System.out.println(Arrays.toString(this.edges));
    }

    /**
     * 獲取頂點(diǎn)索引i的終點(diǎn)如果沒(méi)有終點(diǎn)則返回頂點(diǎn)索引本身
     *
     * @param vends 頂點(diǎn)在最小生成樹(shù)中的終點(diǎn)
     * @param i     頂點(diǎn)索引
     * @return 頂點(diǎn)索引i的終點(diǎn)如果沒(méi)有終點(diǎn)則返回頂點(diǎn)索引本身
     */
    private int getEndIndex(int[] vends, int i) {
        //這里使用循環(huán)查找的邏輯,尋找的是最終的終點(diǎn)
        while (vends[i] != this.edges.length) {
            i = vends[i];
        }
        return i;
    }

    /**
     * 如果沒(méi)有現(xiàn)成的邊集數(shù)組,那么根據(jù)鄰接矩陣結(jié)構(gòu)獲取圖中的邊集數(shù)組
     *
     * @return 圖的邊集數(shù)組
     */
    private Edge[] getEdges() {
        List<Edge> edges = new ArrayList<>();
        /*遍歷矩陣數(shù)組 只需要遍歷一半就行了*/
        for (int i = 0; i < vertexs.length; i++) {
            for (int j = i + 1; j < vertexs.length; j++) {
                //如果存在邊
                if (matrix[i][j] != NO_EDGE && matrix[i][j] != 0) {
                    edges.add(new Edge<>(vertexs[i], vertexs[j], matrix[i][j]));
                    //edges[index++] = new Edge(vertexs[i], vertexs[j], matrix[i][j]);
                }
            }
        }
        return edges.toArray(new Edge[0]);
    }

    /**
     * Kruskal結(jié)合Prim算法.不需要知道邊集,只需要矩陣數(shù)組,和頂點(diǎn)數(shù)組
     * 同樣是求最小權(quán)值的邊,但是有一個(gè)默認(rèn)起點(diǎn)頂點(diǎn),該起點(diǎn)可以是要求[0,頂點(diǎn)數(shù)量-1]之間的任意值,同時(shí)查找最小權(quán)的邊。
     * 可能會(huì)有Bug,目前未發(fā)現(xiàn)
     */
    public void kruskalAndPrim() {
        System.out.println("kruskalAndPrim: ");
        //已經(jīng)找到的邊攜帶的頂點(diǎn)對(duì)應(yīng)的索引將變?yōu)閠rue,其余未找到邊對(duì)應(yīng)的頂點(diǎn)將是false
        boolean[] connected = new boolean[matrix.length];
        //這里選擇第一個(gè)頂點(diǎn)為起點(diǎn),表示以該頂點(diǎn)開(kāi)始尋找包含該頂點(diǎn)的最小邊
        connected[0] = true;
        int sum = 0, n1 = 0, n2 = 0;
        //最小權(quán)值
        int min;
        while (true) {
            min = NO_EDGE;
            /*找出所有帶有已找到頂點(diǎn)的邊中,最小權(quán)值的邊,只需要尋找對(duì)稱(chēng)矩陣的一半即可*/
            //第一維
            for (int i = 0; i < matrix.length; i++) {
                //第二維
                for (int j = i + 1; j < matrix.length; j++) {
                    //排除等于0的,排除兩個(gè)頂點(diǎn)都找到了的,這里實(shí)際上已經(jīng)隱含了排除環(huán)的邏輯,如果某條邊的兩個(gè)頂點(diǎn)都找到了,那么如果算上該條邊,肯定會(huì)形成環(huán)
                    //尋找剩下的最小的權(quán)值的邊
                    if (matrix[i][j] != 0 && connected[i] != connected[j] && matrix[i][j] < min) {
                        min = matrix[i][j];
                        n1 = i;
                        n2 = j;
                    }
                }
            }
            //如果沒(méi)找到最小權(quán)值,該圖可能不是連通圖,或者已經(jīng)尋找完畢,直接返回
            if (min == NO_EDGE) {
                System.out.println(" sum:" + sum);
                return;
            }
            //已經(jīng)找到的邊對(duì)應(yīng)的兩個(gè)頂點(diǎn)都置為true
            connected[n1] = true;
            connected[n2] = true;
            //輸出找到的邊和最小權(quán)值
            System.out.println(vertexs[n1] + " ---> " + vertexs[n2] + " 權(quán)值:" + min);
            sum += min;
        }
    }


    public static void main(String[] args) {
        //頂點(diǎn)數(shù)組
        Character[] vexs = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};
        //邊數(shù)組,加權(quán)值
        Edge[] edges = {
                new Edge<>('A', 'C', 1),
                new Edge<>('D', 'A', 2),
                new Edge<>('A', 'F', 3),
                new Edge<>('B', 'C', 4),
                new Edge<>('C', 'D', 5),
                new Edge<>('E', 'G', 6),
                new Edge<>('E', 'B', 7),
                new Edge<>('D', 'B', 8),
                new Edge<>('F', 'G', 9)};

        //構(gòu)建圖
        MatrixPrimAndKruskal<Character> matrixPrimAndKruskal = new MatrixPrimAndKruskal<Character>(vexs, edges);
        //輸出圖
        System.out.println(matrixPrimAndKruskal);
        //深度優(yōu)先遍歷
        matrixPrimAndKruskal.DFS();
        //廣度優(yōu)先遍歷
        matrixPrimAndKruskal.BFS();
        //Prim算法輸出最小生成樹(shù)
        matrixPrimAndKruskal.prim();
        //Kruskal算法輸出最小生成樹(shù)
        matrixPrimAndKruskal.kruskal();
        //Kruskal算法結(jié)合Prim算法輸出最小生成樹(shù),可能會(huì)有Bug,目前未發(fā)現(xiàn)
        matrixPrimAndKruskal.kruskalAndPrim();
        //獲取邊集數(shù)組
        Edge[] edges1 = matrixPrimAndKruskal.getEdges();
        System.out.println(Arrays.toString(edges1));
    }
}

5 鄰接表加權(quán)圖實(shí)現(xiàn)

這里的實(shí)現(xiàn)能夠構(gòu)造一個(gè)基于鄰接表實(shí)現(xiàn)無(wú)向加權(quán)圖的類(lèi);并且提供深度優(yōu)先遍歷和廣度優(yōu)先遍歷的方法,提供獲取邊集數(shù)組的方法,提供Prim和Kruskal兩種求最小生成樹(shù)的方法。

/**
 * 無(wú)向加權(quán)圖鄰接表實(shí)現(xiàn)
 * {@link ListPrimAndKruskal#ListPrimAndKruskal(E[], Edge[])} 構(gòu)建無(wú)向加權(quán)圖
 * {@link ListPrimAndKruskal#DFS()}  深度優(yōu)先遍歷無(wú)向加權(quán)圖
 * {@link ListPrimAndKruskal#BFS()}  廣度優(yōu)先遍歷無(wú)向加權(quán)圖
 * {@link ListPrimAndKruskal#toString()}  輸出無(wú)向加權(quán)圖
 * {@link ListPrimAndKruskal#prim()}  Prim算法實(shí)現(xiàn)最小生成樹(shù)
 * {@link ListPrimAndKruskal#kruskal()}   Kruskal算法實(shí)現(xiàn)最小生成樹(shù)
 * {@link ListPrimAndKruskal#getEdges()}  獲取邊集數(shù)組
 *
 * @author lx
 * @date 2020/5/14 23:31
 */
public class ListPrimAndKruskal<E> {
    /**
     * 頂點(diǎn)類(lèi)
     *
     * @param <E>
     */
    private class Node<E> {
        /**
         * 頂點(diǎn)信息
         */
        E data;
        /**
         * 指向第一條依附該頂點(diǎn)的邊
         */
        LNode firstLNode;

        public Node(E data, LNode firstLNode) {
            this.data = data;
            this.firstLNode = firstLNode;
        }
    }

    /**
     * 邊表節(jié)點(diǎn)類(lèi)
     */
    private class LNode {
        /**
         * 該邊所指向的頂點(diǎn)的索引位置
         */
        int vertex;
        /**
         * 該邊的權(quán)值
         */
        int weight;
        /**
         * 指向下一條邊的指針
         */
        LNode nextLNode;
    }

    /**
     * 邊對(duì)象,具有權(quán)值,在構(gòu)建加權(quán)無(wú)向圖時(shí)使用
     */
    private static class Edge<E> {

        private E from;
        private E to;
        private int weight;

        public Edge(E from, E to, int weight) {
            this.from = from;
            this.to = to;
            this.weight = weight;
        }

        @Override
        public String toString() {
            return "Edge{" +
                    "from=" + from +
                    ", to=" + to +
                    ", weight=" + weight +
                    '}';
        }
    }

    /**
     * 頂點(diǎn)數(shù)組
     */
    private Node<E>[] vertexs;


    /**
     * 邊數(shù)組
     */
    private Edge<E>[] edges;

    /**
     * 由于是加權(quán)圖,這里設(shè)置一個(gè)邊的權(quán)值上限,任何邊的最大權(quán)值不能大于等于該值,在實(shí)際應(yīng)用中,該值應(yīng)該根據(jù)實(shí)際情況確定
     */
    private static final int NO_EDGE = 99;

    /**
     * 創(chuàng)建無(wú)向加權(quán)圖
     *
     * @param vexs  頂點(diǎn)數(shù)組
     * @param edges 邊二維數(shù)組
     */
    public ListPrimAndKruskal(E[] vexs, Edge<E>[] edges) {
        this.edges = edges;
        /*初始化頂點(diǎn)數(shù)組,并添加頂點(diǎn)*/
        vertexs = new Node[vexs.length];
        for (int i = 0; i < vertexs.length; i++) {
            vertexs[i] = new Node<>(vexs[i], null);
        }
        /*初始化邊表,并添加邊節(jié)點(diǎn)到邊表尾部,即采用尾插法*/
        for (Edge<E> edge : edges) {
            // 讀取一條邊的起始頂點(diǎn)和結(jié)束頂點(diǎn)索引值
            int p1 = getPosition(edge.from);
            int p2 = getPosition(edge.to);
            int weight = edge.weight;
            /*這里需要相互添加邊節(jié)點(diǎn),無(wú)向圖可以看作相互可達(dá)的有向圖*/
            // 初始化lnode1邊節(jié)點(diǎn)
            LNode lnode1 = new LNode();
            lnode1.vertex = p2;
            lnode1.weight = weight;
            // 將LNode鏈接到"p1所在鏈表的末尾"
            if (vertexs[p1].firstLNode == null) {
                vertexs[p1].firstLNode = lnode1;
            } else {
                linkLast(vertexs[p1].firstLNode, lnode1);
            }
            // 初始化lnode2邊節(jié)點(diǎn)
            LNode lnode2 = new LNode();
            lnode2.vertex = p1;
            lnode2.weight = weight;
            // 將lnode2鏈接到"p2所在鏈表的末尾"
            if (vertexs[p2].firstLNode == null) {
                vertexs[p2].firstLNode = lnode2;
            } else {
                linkLast(vertexs[p2].firstLNode, lnode2);
            }
        }
    }

    /**
     * 獲取某條邊的某個(gè)頂點(diǎn)所在頂點(diǎn)數(shù)組的索引位置
     *
     * @param e 頂點(diǎn)的值
     * @return 所在頂點(diǎn)數(shù)組的索引位置, 或者-1 - 表示不存在
     */
    private int getPosition(E e) {
        for (int i = 0; i < vertexs.length; i++) {
            if (vertexs[i].data == e) {
                return i;
            }
        }
        return -1;
    }


    /**
     * 將lnode節(jié)點(diǎn)鏈接到邊表的最后,采用尾插法
     *
     * @param first 邊表頭結(jié)點(diǎn)
     * @param node  將要添加的節(jié)點(diǎn)
     */
    private void linkLast(LNode first, LNode node) {
        while (true) {
            if (first.vertex == node.vertex) {
                return;
            }
            if (first.nextLNode == null) {
                break;
            }
            first = first.nextLNode;
        }
        first.nextLNode = node;
    }

    @Override
    public String toString() {
        StringBuilder stringBuilder = new StringBuilder();
        for (int i = 0; i < vertexs.length; i++) {
            stringBuilder.append(i).append("(").append(vertexs[i].data).append("): ");
            LNode node = vertexs[i].firstLNode;
            while (node != null) {
                stringBuilder.append(node.vertex).append("(").append(vertexs[node.vertex].data).append("-").append(node.weight).append(")");
                node = node.nextLNode;
                if (node != null) {
                    stringBuilder.append("->");
                } else {
                    break;
                }
            }
            stringBuilder.append("\n");
        }
        return stringBuilder.toString();
    }

    /**
     * 深度優(yōu)先搜索遍歷圖的遞歸實(shí)現(xiàn),類(lèi)似于樹(shù)的先序遍歷
     * 因此模仿樹(shù)的先序遍歷,同樣借用棧結(jié)構(gòu),這里使用的是方法的遞歸,隱式的借用棧
     *
     * @param i       頂點(diǎn)索引
     * @param visited 訪問(wèn)標(biāo)志數(shù)組
     */
    private void DFS(int i, boolean[] visited) {
        //索引索引標(biāo)記為true ,表示已經(jīng)訪問(wèn)了
        visited[i] = true;
        System.out.print(vertexs[i].data + " ");
        //獲取該頂點(diǎn)的邊表頭結(jié)點(diǎn)
        LNode node = vertexs[i].firstLNode;
        //循環(huán)遍歷該頂點(diǎn)的鄰接點(diǎn),采用同樣的方式遞歸搜索
        while (node != null) {
            if (!visited[node.vertex]) {
                DFS(node.vertex, visited);
            }
            node = node.nextLNode;
        }
    }

    /**
     * 深度優(yōu)先搜索遍歷圖,類(lèi)似于樹(shù)的前序遍歷,
     */
    public void DFS() {
        //新建頂點(diǎn)訪問(wèn)標(biāo)記數(shù)組,對(duì)應(yīng)每個(gè)索引對(duì)應(yīng)相同索引的頂點(diǎn)數(shù)組中的頂點(diǎn)
        boolean[] visited = new boolean[vertexs.length];
        //初始化所有頂點(diǎn)都沒(méi)有被訪問(wèn)
        for (int i = 0; i < vertexs.length; i++) {
            visited[i] = false;
        }
        System.out.println("DFS: ");
        /*循環(huán)搜索*/
        for (int i = 0; i < vertexs.length; i++) {
            //如果對(duì)應(yīng)索引的頂點(diǎn)的訪問(wèn)標(biāo)記為false,則搜索該頂點(diǎn)
            if (!visited[i]) {
                DFS(i, visited);
            }
        }
        /*走到這一步,說(shuō)明頂點(diǎn)訪問(wèn)標(biāo)記數(shù)組全部為true,說(shuō)明全部都訪問(wèn)到了,深度搜索結(jié)束*/
        System.out.println();
    }

    /**
     * 廣度優(yōu)先搜索圖,類(lèi)似于樹(shù)的層序遍歷
     * 因此模仿樹(shù)的層序遍歷,同樣借用隊(duì)列結(jié)構(gòu)
     */
    public void BFS() {
        // 輔組隊(duì)列
        Queue<Integer> indexLinkedList = new LinkedList<>();
        //新建頂點(diǎn)訪問(wèn)標(biāo)記數(shù)組,對(duì)應(yīng)每個(gè)索引對(duì)應(yīng)相同索引的頂點(diǎn)數(shù)組中的頂點(diǎn)
        boolean[] visited = new boolean[vertexs.length];
        //初始化所有頂點(diǎn)都沒(méi)有被訪問(wèn)
        for (int i = 0; i < vertexs.length; i++) {
            visited[i] = false;
        }
        System.out.println("BFS: ");
        for (int i = 0; i < vertexs.length; i++) {
            //如果訪問(wèn)方劑為false,則設(shè)置為true,表示已經(jīng)訪問(wèn),然后開(kāi)始訪問(wèn)
            if (!visited[i]) {
                visited[i] = true;
                System.out.print(vertexs[i].data + " ");
                indexLinkedList.add(i);
            }
            //判斷隊(duì)列是否有值,有就開(kāi)始遍歷
            if (!indexLinkedList.isEmpty()) {
                //出隊(duì)列
                Integer j = indexLinkedList.poll();
                LNode node = vertexs[j].firstLNode;
                while (node != null) {
                    int k = node.vertex;
                    if (!visited[k]) {
                        visited[k] = true;
                        System.out.print(vertexs[k].data + " ");
                        //繼續(xù)入隊(duì)列
                        indexLinkedList.add(k);
                    }
                    node = node.nextLNode;
                }
            }
        }
        System.out.println();
    }

    /**
     * Prim算法求最小生成樹(shù)
     */
    public void prim() {
        System.out.println("prim: ");
        //對(duì)應(yīng)節(jié)點(diǎn)應(yīng)該被連接的前驅(qū)節(jié)點(diǎn),用來(lái)輸出
        //默認(rèn)為0,即前驅(qū)結(jié)點(diǎn)為第一個(gè)節(jié)點(diǎn)
        int[] mid = new int[vertexs.length];
        int start = 0;
        int min, tmp, sum = 0;
        int num = vertexs.length;

        //頂點(diǎn)間邊的權(quán)值
        //存儲(chǔ)未連接頂點(diǎn)到已連接頂點(diǎn)的最短距離(最小權(quán))
        int[] dis = new int[num];


        // 初始化"頂點(diǎn)的權(quán)值數(shù)組",
        // 將每個(gè)頂點(diǎn)的權(quán)值初始化為"第start個(gè)頂點(diǎn)"到"該頂點(diǎn)"的權(quán)值。
        //首先將其他頂點(diǎn)到0索引頂點(diǎn)的權(quán)值存儲(chǔ)進(jìn)去
        for (int i = 0; i < num; i++) {
            dis[i] = getWeight(start, i);
        }
        //如果某頂點(diǎn)作為末端頂點(diǎn)被連接,對(duì)應(yīng)位置應(yīng)該為true
        //第一個(gè)頂點(diǎn)默認(rèn)被連接
        boolean[] connected = new boolean[vertexs.length];
        connected[0] = true;
        /*默認(rèn)第一個(gè)頂點(diǎn)已經(jīng)找到了,因此最多還要需要大循環(huán)n-1次*/
        for (int k = 1; k < num; k++) {
            min = NO_EDGE;
            //最小權(quán)值的頂點(diǎn)的索引
            int minIndex = 0;
            // 在未被加入到最小生成樹(shù)的頂點(diǎn)中,找出權(quán)值最小的頂點(diǎn)。
            for (int i = 1; i < vertexs.length; i++) {
                //排除已連接的頂點(diǎn),排除權(quán)值等于0的值,因?yàn)檫@里默認(rèn)頂點(diǎn)指向自己的權(quán)值為0
                if (!connected[i] && dis[i] != 0 && dis[i] < min) {
                    min = dis[i];
                    minIndex = i;
                }
            }
            //如果沒(méi)找到,那么該圖可能不是連通圖,直接返回了,此時(shí)最小生成樹(shù)沒(méi)啥意義
            if (minIndex == 0) {
                return;
            }
            //權(quán)值和增加
            sum += min;
            //該新連接頂點(diǎn)對(duì)應(yīng)的索引值變成true,表示已被連接,后續(xù)判斷時(shí)跳過(guò)該頂點(diǎn)
            connected[minIndex] = true;
            //輸出對(duì)應(yīng)的前驅(qū)頂點(diǎn)到該最小頂點(diǎn)的權(quán)值
            System.out.println(vertexs[mid[minIndex]].data + " ---> " + vertexs[minIndex].data + " 權(quán)值:" + min);
            /*在新頂點(diǎn)minIndex加入之前的其他所有頂點(diǎn)到連接頂點(diǎn)最小的權(quán)值已經(jīng)計(jì)算過(guò)了
            因此只需要更新其他頂點(diǎn)到新連接頂點(diǎn)minIndex是否還有更短的權(quán)值,有的話就更新找到距離已連接的頂點(diǎn)權(quán)最小的頂點(diǎn)*/
            for (int i = 1; i < num; i++) {
                //如果該頂點(diǎn)未連接
                if (!connected[i]) {
                    // 獲取minindex頂點(diǎn)到未連接頂點(diǎn)i的權(quán)值
                    tmp = getWeight(minIndex, i);
                    /*如果新頂點(diǎn)到未連接頂點(diǎn)i的權(quán)值不為0,并且比原始頂點(diǎn)到未連接頂點(diǎn)i的權(quán)值還要小,那么更新對(duì)應(yīng)位置的最小權(quán)值*/
                    if (tmp != 0 && dis[i] > tmp) {
                        dis[i] = tmp;
                        //更新前驅(qū)節(jié)點(diǎn)索引為新加入節(jié)點(diǎn)索引
                        mid[i] = minIndex;
                    }
                }
            }
        }
        System.out.println("sum: " + sum);
    }

    /**
     * 嘗試獲取邊起點(diǎn)start到邊終點(diǎn)end的邊的權(quán)值,當(dāng)然可能獲取不到
     *
     * @param start 邊起點(diǎn)
     * @param end   邊終點(diǎn)
     * @return 返回權(quán)值; 如果起點(diǎn)和終點(diǎn)相同則返回0;如果邊起點(diǎn)和邊終點(diǎn)之間并沒(méi)有邊, 則返回NO_EDGE
     */
    private int getWeight(int start, int end) {
        //如果start=end,則返回0
        if (start == end) {
            return 0;
        }
        //獲取該頂點(diǎn)的邊表的第一個(gè)值
        LNode node = vertexs[start].firstLNode;
        //循環(huán)查找邊表,看能否找到對(duì)應(yīng)的索引=end,找不到就返回NO_EDGE,表示兩個(gè)頂點(diǎn)未連接。
        while (node != null) {
            if (end == node.vertex) {
                return node.weight;
            }
            node = node.nextLNode;
        }
        return NO_EDGE;
    }

    /**
     * Kruskal算法求最小生成樹(shù),可以說(shuō)鄰接矩陣和鄰接鏈表的實(shí)現(xiàn)方式是完全一致的
     */
    public void kruskal() {
        //由于創(chuàng)建圖的時(shí)候保存了邊集數(shù)組,這里直接使用就行了
        //Edge[] edges = getEdges();
        //this.edges=edges;
        //對(duì)邊集數(shù)組進(jìn)行排序
        Arrays.sort(this.edges, Comparator.comparingInt(o -> o.weight));
        // 用于保存已有最小生成樹(shù)中每個(gè)頂點(diǎn)在該最小樹(shù)中的最終終點(diǎn)的索引
        int[] vends = new int[this.edges.length];
        //能夠知道終點(diǎn)索引范圍是[0,this.edges.length-1],因此填充edges.length表示沒(méi)有終點(diǎn)
        Arrays.fill(vends, this.edges.length);
        int sum = 0;
        for (Edge<E> edge : this.edges) {
            // 獲取第i條邊的起點(diǎn)索引from
            int from = getPosition(edge.from);
            // 獲取第i條邊的終點(diǎn)索引to
            int to = getPosition(edge.to);
            // 獲取頂點(diǎn)from在"已有的最小生成樹(shù)"中的終點(diǎn)
            int m = getEndIndex(vends, from);
            // 獲取頂點(diǎn)to在"已有的最小生成樹(shù)"中的終點(diǎn)
            int n = getEndIndex(vends, to);
            // 如果m!=n,意味著沒(méi)有形成環(huán)路,則可以添加,否則直接跳過(guò),進(jìn)行下一條邊的判斷
            if (m != n) {
                //添加設(shè)置原始終點(diǎn)索引m在已有的最小生成樹(shù)中的終點(diǎn)為n
                vends[m] = n;
                System.out.println(vertexs[from].data + " ---> " + vertexs[to].data + " 權(quán)值:" + edge.weight);
                sum += edge.weight;
            }
        }
        System.out.println("sum: " + sum);
        //System.out.println(Arrays.toString(this.edges));
    }

    /**
     * 獲取頂點(diǎn)索引i的終點(diǎn)如果沒(méi)有終點(diǎn)則返回頂點(diǎn)索引本身
     *
     * @param vends 頂點(diǎn)在最小生成樹(shù)中的終點(diǎn)
     * @param i     頂點(diǎn)索引
     * @return 頂點(diǎn)索引i的終點(diǎn)如果沒(méi)有終點(diǎn)則返回頂點(diǎn)索引本身
     */
    private int getEndIndex(int[] vends, int i) {
        //這里使用循環(huán)查找的邏輯,尋找的是最終的終點(diǎn)
        while (vends[i] != this.edges.length) {
            i = vends[i];
        }
        return i;
    }

    /**
     * 如果沒(méi)有現(xiàn)成的邊集數(shù)組,那么根據(jù)鄰接表結(jié)構(gòu)獲取圖中的邊集數(shù)組
     *
     * @return 圖的邊集數(shù)組
     */
    private Edge[] getEdges() {
        List<Edge> edges = new ArrayList<>();
        //遍歷頂點(diǎn)數(shù)組
        for (int i = 0; i < vertexs.length; i++) {
            LNode node = vertexs[i].firstLNode;
            while (node != null) {
                //只需添加起點(diǎn)索引小于終點(diǎn)索引的邊就行了
                if (node.vertex > i) {
                    edges.add(new Edge<>(vertexs[i].data, vertexs[node.vertex].data, node.weight));
                }
                node = node.nextLNode;
            }
        }
        return edges.toArray(new Edge[0]);
    }

    public static void main(String[] args) {
        //頂點(diǎn)數(shù)組
        Character[] vexs = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};
        //邊數(shù)組,加權(quán)值
        Edge[] edges = {
                new Edge('A', 'C', 1),
                new Edge('D', 'A', 2),
                new Edge('A', 'F', 3),
                new Edge('B', 'C', 4),
                new Edge('C', 'D', 5),
                new Edge('E', 'G', 6),
                new Edge('E', 'B', 7),
                new Edge('D', 'B', 8),
                new Edge('F', 'G', 9)};
        //構(gòu)建圖
        ListPrimAndKruskal<Character> listPrimAndKruskal = new ListPrimAndKruskal<Character>(vexs, edges);
        //輸出圖
        System.out.println(listPrimAndKruskal);
        //深度優(yōu)先遍歷
        //DFS:
        //A C B E G F D
        listPrimAndKruskal.DFS();
        //廣度優(yōu)先遍歷
        //BFS:
        //A C D F B G E
        listPrimAndKruskal.BFS();
        //Prim算法求最小生成樹(shù)
        listPrimAndKruskal.prim();
        //Kruskal算法求最小生成樹(shù)
        listPrimAndKruskal.kruskal();
        //獲取邊集數(shù)組
        Edge[] edges1 = listPrimAndKruskal.getEdges();
        System.out.println(Arrays.toString(edges1));
    }
}

6 總結(jié)

最小生成樹(shù)能夠有效的解決生活中的最小經(jīng)費(fèi)問(wèn)題,但是有一部分問(wèn)題卻不能解決,比如求兩個(gè)不直接相通的站點(diǎn)之間的最短通行時(shí)間問(wèn)題,這里求的就不是最小生成樹(shù)了,因?yàn)椴恍枰B通所有站點(diǎn),而是只需要最短通行時(shí)間路徑,即最短路徑。

以上就是Java求最小生成樹(shù)的兩種算法詳解的詳細(xì)內(nèi)容,更多關(guān)于Java最小生成樹(shù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 基于Java的正則表達(dá)式

    基于Java的正則表達(dá)式

    正則表達(dá)式,又稱(chēng)正規(guī)表示法、常規(guī)表示法(英語(yǔ):Regular Expression,在代碼中常簡(jiǎn)寫(xiě)為regex、regexp或RE),計(jì)算機(jī)科學(xué)的一個(gè)概念
    2017-05-05
  • Java?volatile關(guān)鍵字特性講解下篇

    Java?volatile關(guān)鍵字特性講解下篇

    JMM要求保證可見(jiàn)性、原子性、有序性,volatile可以保證其中的兩個(gè),本篇文章具體驗(yàn)證volatile的可見(jiàn)性,不原子性和禁重排,同時(shí)解決volatile的不保證原子性,讓代碼具有原子性
    2022-12-12
  • java數(shù)組基礎(chǔ)詳解

    java數(shù)組基礎(chǔ)詳解

    這篇文章主要介紹了Java數(shù)組基礎(chǔ)詳解,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • Java利用Optional解決空指針異常

    Java利用Optional解決空指針異常

    這篇文章主要介紹了Java利用Optional解決空指針異常,Optional?類(lèi)是一個(gè)包含有可選值的包裝類(lèi),這意味著?Optional?類(lèi)既可以含有對(duì)象也可以為空
    2022-09-09
  • idea中無(wú)法自動(dòng)裝配未找到 ‘XXXXXXX‘ 類(lèi)型的 Bean

    idea中無(wú)法自動(dòng)裝配未找到 ‘XXXXXXX‘ 類(lèi)型的 Bean

    本文主要介紹了idea中無(wú)法自動(dòng)裝配未找到 ‘XXXXXXX‘ 類(lèi)型的 Bean的原因及三種解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-03-03
  • 多模塊項(xiàng)目使用枚舉配置spring-cache緩存方案詳解

    多模塊項(xiàng)目使用枚舉配置spring-cache緩存方案詳解

    這篇文章主要為大家介紹了多模塊項(xiàng)目使用枚舉配置spring-cache緩存的方案詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • springboot文件虛擬路徑映射方式

    springboot文件虛擬路徑映射方式

    這篇文章主要介紹了springboot文件虛擬路徑映射方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java享元設(shè)計(jì)模式優(yōu)化對(duì)象創(chuàng)建提高性能和效率

    Java享元設(shè)計(jì)模式優(yōu)化對(duì)象創(chuàng)建提高性能和效率

    Java享元設(shè)計(jì)模式通過(guò)共享可重用的對(duì)象,減少了系統(tǒng)中對(duì)象的數(shù)量,優(yōu)化了對(duì)象的創(chuàng)建和管理,提高了性能和效率。它是一種經(jīng)典的設(shè)計(jì)模式,適用于需要處理大量相似對(duì)象的應(yīng)用程序
    2023-04-04
  • java生成餅圖svg及JFreeChart生成svg圖表

    java生成餅圖svg及JFreeChart生成svg圖表

    java生成餅圖svg,代碼實(shí)現(xiàn)感覺(jué)有點(diǎn)復(fù)雜,個(gè)人認(rèn)為不如用JFreeChart,這篇文章主要介紹java生成餅圖svg及JFreeChart生成svg圖表,有需要的小伙伴可以參考下
    2015-08-08
  • SpringBoot如何通過(guò)@Profile注解配置多環(huán)境

    SpringBoot如何通過(guò)@Profile注解配置多環(huán)境

    在Spring中,可以使用配置文件的方式來(lái)指定不同環(huán)境下所需要的配置信息,本文給大家介紹SpringBoot如何通過(guò)@Profile注解配置多環(huán)境,感興趣的朋友跟隨小編一起看看吧
    2023-06-06

最新評(píng)論

精产国品久久一二三产区区别| 激情国产小视频在线| 人人妻人人爽人人澡人人精品| 自拍偷拍日韩欧美一区二区| 夜色撩人久久7777| 老司机你懂得福利视频| 久久农村老妇乱69系列| 不卡精品视频在线观看| 天堂av中文在线最新版| 99re国产在线精品| 啊啊好慢点插舔我逼啊啊啊视频| 国产清纯美女al在线| 日韩欧美国产精品91| 亚洲av日韩av第一区二区三区| 亚洲美女美妇久久字幕组| av视屏免费在线播放| 一级黄片大鸡巴插入美女| 日曰摸日日碰夜夜爽歪歪| 9l人妻人人爽人人爽| 国产真实灌醉下药美女av福利| 在线免费视频 自拍| 99久久99一区二区三区| 人妻久久无码中文成人| 青娱乐蜜桃臀av色| 欧美成一区二区三区四区| 精品黑人巨大在线一区| 久久这里只有精品热视频 | 亚洲一区二区三区精品视频在线| 超碰中文字幕免费观看| 78色精品一区二区三区| 免费看高清av的网站| 国产妇女自拍区在线观看| 在线亚洲天堂色播av电影| 女生被男生插的视频网站| 深夜男人福利在线观看| 91超碰青青中文字幕| 一区二区在线观看少妇| 沈阳熟妇28厘米大战黑人| 插小穴高清无码中文字幕| 亚洲精品中文字幕下载| 高清一区二区欧美系列| 日本阿v视频在线免费观看| 91精品激情五月婷婷在线| 4个黑人操素人视频网站精品91 | 精品首页在线观看视频| 欧洲日韩亚洲一区二区三区| 青娱乐在线免费视频盛宴 | 亚洲va欧美va人人爽3p| 国产女人露脸高潮对白视频| 天天色天天舔天天射天天爽| 天天干狠狠干天天操| 国产91嫩草久久成人在线视频| 四川五十路熟女av| av视屏免费在线播放| 一区二区视频在线观看免费观看| 国产极品精品免费视频| 99精品国产免费久久| 在线观看欧美黄片一区二区三区| 中文字幕在线观看极品视频| 直接能看的国产av| 亚洲狠狠婷婷综合久久app| 欧美亚洲偷拍自拍色图| 天堂av在线官网中文| 韩国黄色一级二级三级| 天堂av在线最新版在线| 男人天堂av天天操| weyvv5国产成人精品的视频| 91色老99久久九九爱精品| av中文字幕电影在线看| 五月精品丁香久久久久福利社| 沈阳熟妇28厘米大战黑人| 亚洲成人三级在线播放| 欧美国产亚洲中英文字幕| 日本后入视频在线观看| 成人精品视频99第一页| 阿v天堂2014 一区亚洲| 亚洲美女自偷自拍11页| 日本丰满熟妇BBXBBXHD| 午夜福利人人妻人人澡人人爽| 国产高清在线观看1区2区| 99久久久无码国产精品性出奶水 | 天天日天天透天天操| 88成人免费av网站| 五十路av熟女松本翔子| 久久久精品精品视频视频| 亚洲黄色av网站免费播放| 亚洲 中文 自拍 无码| 5528327男人天堂| 搡老熟女一区二区在线观看| 青青草在观免费国产精品| 风流唐伯虎电视剧在线观看 | 精品亚洲在线免费观看| 狠狠操狠狠操免费视频| 久草电影免费在线观看| jiuse91九色视频| 同居了嫂子在线播高清中文| 亚洲日本一区二区久久久精品| 亚洲精品国产在线电影| av成人在线观看一区| 亚洲男人让女人爽的视频| 国产一区成人在线观看视频| 亚洲最大黄 嗯色 操 啊| 欧美va不卡视频在线观看| 免费岛国喷水视频在线观看 | 最新日韩av传媒在线| 插逼视频双插洞国产操逼插洞| 国内资源最丰富的网站| 最新日韩av传媒在线| 国产精品成人xxxx| 干逼又爽又黄又免费的视频| 国产精品国产三级麻豆| 国产高清97在线观看视频| 蜜桃视频在线欧美一区| 午夜精品一区二区三区更新| 精品黑人一区二区三区久久国产| 亚洲在线免费h观看网站| 国产精品污污污久久| 国产美女午夜福利久久| 欧美中国日韩久久精品| 亚洲国产免费av一区二区三区| av日韩在线免费播放| 适合午夜一个人看的视频| 热99re69精品8在线播放| 欧美综合婷婷欧美综合| 2020av天堂网在线观看| 亚洲在线一区二区欧美| 激情国产小视频在线| 国产欧美日韩在线观看不卡| 日本黄色特一级视频| 欧美另类一区二区视频| 欧美黑人与人妻精品| 久久人人做人人妻人人玩精品vr | 2021年国产精品自拍| 又粗又硬又猛又爽又黄的| 2018在线福利视频| 懂色av之国产精品| 亚洲 图片 欧美 图片| 蜜臀av久久久久久久| 天天插天天狠天天操| 色婷婷精品大在线观看| 亚洲成人av在线一区二区| 国产日韩欧美美利坚蜜臀懂色| 自拍偷拍亚洲精品第2页| av网站色偷偷婷婷网男人的天堂| 中文字幕熟女人妻久久久| 小穴多水久久精品免费看| 中文字幕AV在线免费看 | 久久久久久久久久久免费女人| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 国产欧美日韩在线观看不卡| 人妻3p真实偷拍一二区| 国产成人自拍视频在线免费观看| 天堂av在线官网中文| 欧美韩国日本国产亚洲| 成人免费毛片aaaa| 亚洲一级 片内射视正片| 成人18禁网站在线播放| 亚洲精品国偷自产在线观看蜜桃| 啪啪啪啪啪啪啪免费视频| 黄色片年轻人在线观看| 日本啪啪啪啪啪啪啪| 狠狠的往里顶撞h百合| 揄拍成人国产精品免费看视频| 欧美精产国品一二三产品区别大吗| 国产精品国产精品一区二区| 一级黄色片夫妻性生活| 鸡巴操逼一级黄色气| 亚洲欧美国产麻豆综合| 天天躁日日躁狠狠躁av麻豆| 欧美特色aaa大片| 国产黄色片蝌蚪九色91| 亚洲天天干 夜夜操| 色综合色综合色综合色| 欧美日韩高清午夜蜜桃大香蕉| nagger可以指黑人吗| 日韩加勒比东京热二区| 福利在线视频网址导航| 九九热99视频在线观看97| 天天操夜夜骑日日摸| 天堂av在线官网中文| 日韩人妻在线视频免费| 丰满少妇人妻xxxxx| 在线播放 日韩 av| 午夜dv内射一区区| 欧美国产亚洲中英文字幕| 国产精品自偷自拍啪啪啪| 天天日天天干天天插舔舔| 亚洲综合一区成人在线| 青娱乐蜜桃臀av色| 国产精品人妻66p| 青青青青草手机在线视频免费看| 动漫黑丝美女的鸡巴| 日本又色又爽又黄又粗| 日本女人一级免费片| 日本高清成人一区二区三区| 女同久久精品秋霞网| 欧洲日韩亚洲一区二区三区| 爆乳骚货内射骚货内射在线| 97香蕉碰碰人妻国产樱花| 亚洲精品乱码久久久本| 人妻激情图片视频小说| 91免费观看在线网站| 激情内射在线免费观看| 91极品新人『兔兔』精品新作| 亚洲欧美精品综合图片小说| 都市激情校园春色狠狠| 91色网站免费在线观看| 亚洲av无硬久久精品蜜桃| 亚洲卡1卡2卡三卡四老狼| 日韩午夜福利精品试看| 久久美欧人妻少妇一区二区三区| 嫩草aⅴ一区二区三区| 99亚洲美女一区二区三区| 玖玖一区二区在线观看| 三级av中文字幕在线观看| 天天日天天干天天要| www久久久久久久久久久| av中文字幕国产在线观看| jul—619中文字幕在线| 日本少妇在线视频大香蕉在线观看| 欧美爆乳肉感大码在线观看| 亚洲欧美国产麻豆综合| 后入美女人妻高清在线| 一区二区三区四区五区性感视频| 成熟丰满熟妇高潮xx×xx| 人人妻人人爱人人草| 亚洲乱码中文字幕在线| 日韩一个色综合导航| 亚洲男人的天堂a在线| sw137 中文字幕 在线| 内射久久久久综合网| 大鸡巴操b视频在线| 骚货自慰被发现爆操| 亚洲欧美成人综合视频| eeuss鲁片一区二区三区| 欧美一区二区三区激情啪啪啪| 国产大鸡巴大鸡巴操小骚逼小骚逼| 93精品视频在线观看| 日本后入视频在线观看| 亚洲图库另类图片区| jiujiure精品视频在线| 中国视频一区二区三区| 1024久久国产精品| 又色又爽又黄的美女裸体| 国产视频精品资源网站| 欧美成一区二区三区四区| 亚洲 图片 欧美 图片| 女生被男生插的视频网站| 被大鸡吧操的好舒服视频免费| 免费看美女脱光衣服的视频| 成人资源在线观看免费官网| 国产麻豆精品人妻av| 亚洲国产精品中文字幕网站| 欧美80老妇人性视频| 中文字幕第三十八页久久| 亚洲av日韩精品久久久| 男人天堂色男人av| 精品欧美一区二区vr在线观看| 天天日天天透天天操| 精品美女福利在线观看| 中文字幕一区二区亚洲一区| 亚洲国产成人在线一区| 馒头大胆亚洲一区二区| 少妇人妻久久久久视频黄片| 91综合久久亚洲综合| 91麻豆精品91久久久久同性| 久久精品国产999| 人妻无码色噜噜狠狠狠狠色| 在线视频精品你懂的| 成人在线欧美日韩国产| 香蕉av影视在线观看| 日本熟女精品一区二区三区| 国产精品自偷自拍啪啪啪| 久久精品国产999| 美女操逼免费短视频下载链接| 最近的中文字幕在线mv视频| 亚洲中文字幕国产日韩| 91破解版永久免费| 一区二区三区欧美日韩高清播放| 亚洲男人在线天堂网| 欧美精品欧美极品欧美视频 | 亚洲天堂精品久久久| 免费无码人妻日韩精品一区二区| 男女啪啪视频免费在线观看 | av在线免费观看亚洲天堂| 亚洲伊人久久精品影院一美女洗澡| 熟女国产一区亚洲中文字幕| 在线免费观看国产精品黄色| 亚洲人妻视频在线网| 激情图片日韩欧美人妻| 91综合久久亚洲综合| 熟女少妇激情五十路| 视频二区在线视频观看| 亚洲2021av天堂| 亚洲狠狠婷婷综合久久app| 91国产在线视频免费观看| 日本免费视频午夜福利视频| 天天爽夜夜爽人人爽QC| 天天干天天日天天干天天操| 91桃色成人网络在线观看| 2012中文字幕在线高清| 蜜桃视频在线欧美一区| 高清一区二区欧美系列| 亚洲成人精品女人久久久| 在线不卡成人黄色精品| 超碰在线中文字幕一区二区| 少妇高潮一区二区三区| 日本免费午夜视频网站| av乱码一区二区三区| 2022中文字幕在线| 97欧洲一区二区精品免费| 天天夜天天日天天日| 99热久久极品热亚洲| 免费在线观看视频啪啪| 97超碰国语国产97超碰| 亚洲欧美清纯唯美另类| 啪啪啪啪啪啪啪免费视频| 国产精品手机在线看片| 欧美一区二区中文字幕电影| 中文字幕熟女人妻久久久| 哥哥姐姐综合激情小说| 免费成人va在线观看| 99人妻视频免费在线| 521精品视频在线观看| 黑人解禁人妻叶爱071| 啊用力插好舒服视频| 扒开让我视频在线观看| 亚洲av男人天堂久久| 欧美熟妇一区二区三区仙踪林| 青青操免费日综合视频观看| 女同性ⅹxx女同hd| 亚洲天堂av最新网址| 人妻少妇一区二区三区蜜桃| 欧美日韩一级黄片免费观看| 午夜激情精品福利视频| 少妇一区二区三区久久久| 特级无码毛片免费视频播放| 操操网操操伊剧情片中文字幕网| 亚洲第一伊人天堂网| 特级无码毛片免费视频播放| 中文乱理伦片在线观看| 少妇系列一区二区三区视频| 亚洲第一黄色在线观看| 青青色国产视频在线| japanese日本熟妇另类| 特一级特级黄色网片| 一区二区三区综合视频| 亚洲欧美清纯唯美另类| 亚洲另类综合一区小说| 亚洲av午夜免费观看| 东京热男人的av天堂| 激情综合治理六月婷婷| 国产白袜脚足J棉袜在线观看| 东京热男人的av天堂| 国产janese在线播放| 女警官打开双腿沦为性奴| 日韩在线视频观看有码在线| 最新欧美一二三视频| 在线网站你懂得老司机| 最新日韩av传媒在线| 天堂va蜜桃一区入口| 大鸡吧插入女阴道黄色片| 亚洲精品国品乱码久久久久| 日韩欧美一级aa大片| 亚洲 中文字幕在线 日韩| 大鸡巴后入爆操大屁股美女| 国产福利小视频大全| 亚洲人妻av毛片在线| 中文字幕亚洲中文字幕| 国产黑丝高跟鞋视频在线播放| 国产精品女邻居小骚货| 91自产国产精品视频| xxx日本hd高清| 国产高清精品极品美女| 精品一区二区三四区| 久久一区二区三区人妻欧美| 小穴多水久久精品免费看| 国产日韩av一区二区在线| 欧美综合婷婷欧美综合| 亚洲在线一区二区欧美| 欧美成人综合色在线噜噜| 亚洲一区二区三区精品视频在线| av中文在线天堂精品| 中文字幕人妻一区二区视频| 色在线观看视频免费的| 久久永久免费精品人妻专区 | 黑人性生活视频免费看| 十八禁在线观看地址免费| 蜜桃色婷婷久久久福利在线| 欧美3p在线观看一区二区三区| 91福利在线视频免费观看| 国产变态另类在线观看| 亚洲专区激情在线观看视频| gogo国模私拍视频| 大香蕉玖玖一区2区| 青青社区2国产视频| 阴茎插到阴道里面的视频| 少妇高潮无套内谢麻豆| 国产高清精品一区二区三区| 成年人中文字幕在线观看| 成人亚洲精品国产精品| 可以免费看的www视频你懂的| 男人插女人视频网站| 国产亚洲欧美45p| 免费男阳茎伸入女阳道视频| 老师让我插进去69AV| 男人天堂av天天操| 五十路熟女人妻一区二区9933| 97年大学生大白天操逼| 在线免费观看av日韩| 18禁美女羞羞免费网站| 综合页自拍视频在线播放| 国产成人精品一区在线观看| 在线免费观看av日韩| 欧美精产国品一二三产品价格| 日韩熟女系列一区二区三区| 美女av色播在线播放| 婷婷色中文亚洲网68| 性欧美日本大妈母与子| 精品视频中文字幕在线播放| 国内资源最丰富的网站| 中文字幕日韩无敌亚洲精品| av中文字幕网址在线| 欧美80老妇人性视频| 自拍偷拍 国产资源| 亚洲精品一区二区三区老狼| 精品91高清在线观看| 久久午夜夜伦痒痒想咳嗽P| 91欧美在线免费观看| 超碰中文字幕免费观看| 黑人乱偷人妻中文字幕| 亚洲图片偷拍自拍区| 亚洲国产成人无码麻豆艾秋| 毛茸茸的大外阴中国视频| 97国产在线观看高清| 日本黄色特一级视频| 91av中文视频在线| 自拍偷拍 国产资源| 自拍偷拍日韩欧美一区二区| 80电影天堂网官网| 青草亚洲视频在线观看| 亚洲欧美国产麻豆综合| 国产精品国产三级国产午| 久草视频在线看免费| 2022天天干天天操| 四川乱子伦视频国产vip| 国产成人精品午夜福利训2021| 最近的中文字幕在线mv视频| 三级黄色亚洲成人av| 成人福利视频免费在线| 91国产资源在线视频| 青青青aaaa免费| 欧美女同性恋免费a| 欧美日韩高清午夜蜜桃大香蕉| 中文字幕熟女人妻久久久| 92福利视频午夜1000看| 国产日本欧美亚洲精品视| 久久久精品999精品日本| 丝袜国产专区在线观看| 成人区人妻精品一区二视频| 偷拍美女一区二区三区| 天天综合天天综合天天网| 青青热久免费精品视频在线观看| 亚欧在线视频你懂的| 99热这里只有精品中文| 欧美另类z0z变态| 99热99这里精品6国产| 日韩av熟妇在线观看| 毛茸茸的大外阴中国视频| 黄色录像鸡巴插进去| 超碰在线观看免费在线观看| 国产日韩精品一二三区久久久 | 免费在线黄色观看网站| 一色桃子人妻一区二区三区| 老司机欧美视频在线看| 免费在线观看视频啪啪| 日韩美av高清在线| 天天操天天污天天射| 白白操白白色在线免费视频 | 国产精品久久久久久久女人18| 日韩国产乱码中文字幕| 久久亚洲天堂中文对白| 日本18禁久久久久久| 超碰公开大香蕉97| 欧美偷拍亚洲一区二区| 日本一本午夜在线播放| 日本av高清免费网站| 在线免费视频 自拍| 欧美偷拍自拍色图片| 国产精品一区二区三区蜜臀av| 无码中文字幕波多野不卡| 伊人综合免费在线视频| 精彩视频99免费在线| 日韩一个色综合导航| 欧美日韩一级黄片免费观看| 护士特殊服务久久久久久久| 99re6热在线精品| 一区二区三区 自拍偷拍| gogo国模私拍视频| 国产一区av澳门在线观看| 欧美国产亚洲中英文字幕| 一级黄色片夫妻性生活| 中文字幕av一区在线观看| 91国产在线视频免费观看| 熟女人妻一区二区精品视频| jul—619中文字幕在线| 午夜国产福利在线观看| 中文字幕在线观看国产片| 日韩欧美国产一区不卡| 天天日天天爽天天干| 夜色撩人久久7777| 亚洲视频在线观看高清| 最新91精品视频在线| 国产精品精品精品999| 五十路熟女人妻一区二区9933| 99精品视频在线观看婷婷| 女生自摸在线观看一区二区三区| 亚洲自拍偷拍综合色| 午夜精品一区二区三区更新| 日韩一区二区三区三州| 最新91精品视频在线| 国产又粗又硬又猛的毛片视频| 国产精品精品精品999| 成人精品视频99第一页| 午夜dv内射一区区| 黄色的网站在线免费看| 经典国语激情内射视频| 精品黑人一区二区三区久久国产| 亚洲在线一区二区欧美| 97年大学生大白天操逼| 大屁股熟女一区二区三区| 做爰视频毛片下载蜜桃视频1| 欧美视频一区免费在线| 亚洲1069综合男同| 亚洲成人激情av在线| 亚洲精品中文字幕下载| 欧美老鸡巴日小嫩逼| 免费黄色成人午夜在线网站| 69精品视频一区二区在线观看| 国产黄色大片在线免费播放| 夜女神免费福利视频| 免费成人va在线观看| 欧美乱妇无乱码一区二区| 天天摸天天干天天操科普| 视频二区在线视频观看| 极品粉嫩小泬白浆20p主播| 激情人妻校园春色亚洲欧美| 2020久久躁狠狠躁夜夜躁| av手机在线观播放网站| 91九色porny国产蝌蚪视频| av一本二本在线观看| 国产亚洲天堂天天一区| av俺也去在线播放| 国产视频网站国产视频| 一区二区免费高清黄色视频| 美女av色播在线播放| 国产综合视频在线看片| 91精品啪在线免费| 91精品综合久久久久3d动漫 | 91国产在线视频免费观看| 免费黄色成人午夜在线网站| 色综合天天综合网国产成人| 3337p日本欧洲大胆色噜噜| 伊人综合免费在线视频| 老有所依在线观看完整版| 一色桃子人妻一区二区三区| 亚洲国产在线精品国偷产拍| 欧美久久久久久三级网| 在线观看欧美黄片一区二区三区| 亚洲欧美日韩视频免费观看| 久久三久久三久久三久久| 中文字幕—97超碰网| 亚洲高清国产自产av| 夜色撩人久久7777| 亚洲成人熟妇一区二区三区| 久久亚洲天堂中文对白| 国产精品女邻居小骚货| 亚洲免费成人a v| 天天射夜夜操综合网| 亚洲天堂第一页中文字幕| 视频一区 视频二区 视频| 欧美黄片精彩在线免费观看| 天天做天天爽夜夜做少妇| 日本精品视频不卡一二三| 亚洲国产香蕉视频在线播放| 日韩成人性色生活片| 人妻少妇av在线观看| mm131美女午夜爽爽爽| 五十路熟女人妻一区二区9933| 在线免费观看日本伦理| 人妻自拍视频中国大陆| 丝袜肉丝一区二区三区四区在线| 操操网操操伊剧情片中文字幕网| 欧洲精品第一页欧洲精品亚洲| 极品丝袜一区二区三区| 欧美地区一二三专区| 精品亚洲在线免费观看| 91chinese在线视频| 黄色三级网站免费下载| huangse网站在线观看| 青青青青视频在线播放| 天天操天天干天天插| 青青在线视频性感少妇和隔壁黑丝| 人妻久久久精品69系列| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | av亚洲中文天堂字幕网| gogo国模私拍视频| 国产高清女主播在线| 日韩精品啪啪视频一道免费| 中文字幕最新久久久| 欧美性感尤物人妻在线免费看| 国产精品久久综合久久| 91chinese在线视频| 特大黑人巨大xxxx| 99热久久这里只有精品8| 人妻久久无码中文成人| 亚洲一区二区久久久人妻| 欧美女同性恋免费a| 亚洲欧美一区二区三区电影| 午夜婷婷在线观看视频| 青青草亚洲国产精品视频| 午夜久久久久久久99| 日本脱亚入欧是指什么| 92福利视频午夜1000看| 亚洲一区二区人妻av| 亚洲成人免费看电影| 国产精品精品精品999| 一区二区三区在线视频福利| 最新激情中文字幕视频| 国产精品自拍偷拍a| 亚洲va国产va欧美va在线| 成人24小时免费视频| 一区二区三区麻豆福利视频| 日韩成人综艺在线播放| 91色秘乱一区二区三区| 日本av熟女在线视频| 日本啪啪啪啪啪啪啪| av中文字幕在线导航| 日韩美女搞黄视频免费| 中文字幕在线视频一区二区三区 | 在线观看一区二区三级| 老司机福利精品免费视频一区二区| 欧美aa一级一区三区四区| 五十路在线观看完整版| 粉嫩欧美美人妻小视频| 99re久久这里都是精品视频| 97黄网站在线观看| 亚洲视频乱码在线观看| 亚洲一区二区三区久久午夜| 国产不卡av在线免费| 激情啪啪啪啪一区二区三区| 人人妻人人澡人人爽人人dvl| lutube在线成人免费看| 久久这里有免费精品| 在线成人日韩av电影| 色综合久久无码中文字幕波多| 日本熟女精品一区二区三区| 久久精品国产999| 黄色无码鸡吧操逼视频| 欧亚日韩一区二区三区观看视频| 在线观看国产网站资源| 欧美日本在线观看一区二区| 中英文字幕av一区| 97超碰最新免费在线观看| 日本性感美女视频网站| 婷婷综合蜜桃av在线| 熟女人妻三十路四十路人妻斩| 熟女人妻三十路四十路人妻斩| 日本熟女精品一区二区三区| 2022天天干天天操| 熟女俱乐部一二三区| 国产污污污污网站在线| 人妻丝袜诱惑我操她视频| 不卡一区一区三区在线| 2017亚洲男人天堂| 欧美少妇性一区二区三区| 亚洲av自拍天堂网| 国产一区成人在线观看视频| 亚洲午夜电影之麻豆| 亚洲蜜臀av一区二区三区九色| 青青社区2国产视频| 爱有来生高清在线中文字幕| 亚洲熟妇x久久av久久| 中文字幕第1页av一天堂网| 91在线免费观看成人| 午夜大尺度无码福利视频| 天天通天天透天天插| 亚洲中文字字幕乱码| 国产伊人免费在线播放| 国产精品入口麻豆啊啊啊| 黄色大片男人操女人逼| 中文字幕网站你懂的| 日本xx片在线观看| 欧美一区二区三区四区性视频| 日韩欧美在线观看不卡一区二区 | 91精品国产麻豆国产| 在线不卡成人黄色精品| 超碰97人人做人人爱| 亚洲精品无码久久久久不卡| 天天插天天狠天天操| av中文字幕网址在线| 日本成人不卡一区二区| 2022精品久久久久久中文字幕| 91成人精品亚洲国产| 国产久久久精品毛片| 人人人妻人人澡人人| 一区二区三区四区中文| 亚洲综合在线观看免费| 中文字幕av男人天堂| 韩国黄色一级二级三级| 免费观看成年人视频在线观看| 精品国产在线手机在线| 一区二区三区激情在线| 特级欧美插插插插插bbbbb| jiujiure精品视频在线| 91破解版永久免费| 97超碰免费在线视频| 亚洲最大黄 嗯色 操 啊| 精品av久久久久久久| 熟女人妻一区二区精品视频| 中文字幕一区二区自拍| huangse网站在线观看| 久久久91蜜桃精品ad| 四虎永久在线精品免费区二区| 亚洲午夜在线视频福利| 青青青视频自偷自拍38碰| 亚洲激情偷拍一区二区| 精品国产高潮中文字幕| 中文字幕一区二 区二三区四区 | 日本韩国免费福利精品| 久久精品视频一区二区三区四区| 国产高清精品一区二区三区| 美味人妻2在线播放| 天天摸天天亲天天舔天天操天天爽| 亚洲熟妇无码一区二区三区| 欧美亚洲牲夜夜综合久久| 午夜国产免费福利av| asmr福利视频在线观看| 最新97国产在线视频| 欧美日本在线观看一区二区| www久久久久久久久久久| 一级a看免费观看网站| 2020中文字幕在线播放| 11久久久久久久久久久| 日韩美女福利视频网| 国产精品久久久久国产三级试频| 国产精品自偷自拍啪啪啪| 绝顶痉挛大潮喷高潮无码 | 人妻av无码专区久久绿巨人| 1区2区3区4区视频在线观看| 美女张开两腿让男人桶av| 中文字幕综合一区二区| 成人午夜电影在线观看 久久| 精彩视频99免费在线| 又色又爽又黄的美女裸体| 国产在线一区二区三区麻酥酥 | 国产成人精品福利短视频| 国产欧美精品一区二区高清 | www日韩毛片av| 淫秽激情视频免费观看| 91极品新人『兔兔』精品新作| 欧美一区二区三区高清不卡tv| 专门看国产熟妇的网站| 自拍偷拍vs一区二区三区| 91精品免费久久久久久| 岳太深了紧紧的中文字幕| japanese日本熟妇另类| 午夜dv内射一区区| 久久永久免费精品人妻专区 | 91九色porny国产在线| 中国把吊插入阴蒂的视频| 精品一区二区三区午夜| 亚洲另类图片蜜臀av| gav成人免费播放| 天天操天天弄天天射| 大鸡巴操b视频在线| 成人18禁网站在线播放| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 在线网站你懂得老司机| caoporn蜜桃视频| 日韩av熟妇在线观看| 干逼又爽又黄又免费的视频| 亚洲中文字幕校园春色| 在线 中文字幕 一区| 国产在线观看黄色视频| 黑人大几巴狂插日本少妇| 国产自拍黄片在线观看| 亚洲av色图18p| 亚洲 中文 自拍 另类 欧美| 成年午夜免费无码区| 538精品在线观看视频| 女同性ⅹxx女同hd| 色综合久久久久久久久中文| 99久久久无码国产精品性出奶水 | 中文字幕—97超碰网| 亚洲中文字幕综合小综合| 成人在线欧美日韩国产| 日韩欧美中文国产在线| 久久三久久三久久三久久| 亚洲av无码成人精品区辽| 日韩a级精品一区二区| 欧美性受xx黑人性猛交| 天天躁日日躁狠狠躁躁欧美av | 久久这里只有精品热视频| 57pao国产一区二区| 亚洲欧美激情国产综合久久久| 激情色图一区二区三区| 四虎永久在线精品免费区二区| 自拍偷拍日韩欧美亚洲| 免费在线播放a级片| av天堂资源最新版在线看| 岛国毛片视频免费在线观看| 91九色国产熟女一区二区| 99国产精品窥熟女精品| 日日夜夜大香蕉伊人| 99精品视频之69精品视频 | 美味人妻2在线播放| 国产91精品拍在线观看| 成人高潮aa毛片免费| 男人天堂色男人av| 大鸡吧插逼逼视频免费看 | 日本熟女精品一区二区三区| 91桃色成人网络在线观看| 在线观看亚洲人成免费网址| 人妻少妇性色欲欧美日韩| 嫩草aⅴ一区二区三区| 免费看国产又粗又猛又爽又黄视频| 欧美精品伦理三区四区| 亚洲最大黄了色网站| 中英文字幕av一区| 精品一区二区三区欧美| 亚洲另类伦春色综合小| 久久尻中国美女视频| 视频啪啪啪免费观看| 欧美韩国日本国产亚洲| av欧美网站在线观看| 人妻少妇av在线观看| 搡老妇人老女人老熟女| 亚洲精品久久视频婷婷| 国产高潮无码喷水AV片在线观看| 欧美精品免费aaaaaa| 久草视频在线看免费| 欧美少妇性一区二区三区| 阿v天堂2014 一区亚洲| 超碰97免费人妻麻豆| 中文字幕av熟女人妻| 久久久久久99国产精品| 9色在线视频免费观看| 精品首页在线观看视频| 福利视频一区二区三区筱慧 | 天天操天天干天天插| 人妻av无码专区久久绿巨人| 成人av天堂丝袜在线观看| 中国黄片视频一区91| 毛茸茸的大外阴中国视频| 9国产精品久久久久老师| 中文 成人 在线 视频| 日日夜夜大香蕉伊人| 三级黄色亚洲成人av| 午夜青青草原网在线观看| 亚洲成人激情av在线| 干逼又爽又黄又免费的视频| 国产精品人妻一区二区三区网站 | 最新国产亚洲精品中文在线| jul—619中文字幕在线| 超碰公开大香蕉97| 午夜91一区二区三区| 91久久精品色伊人6882| 久碰精品少妇中文字幕av| 国产日韩一区二区在线看| 国产精品久久综合久久| 亚洲特黄aaaa片| 青青青青青免费视频| 真实国产乱子伦一区二区| 大香蕉伊人国产在线| 国产1区,2区,3区| 国产成人自拍视频播放| okirakuhuhu在线观看| 3D动漫精品啪啪一区二区下载| 99re6热在线精品| 中文字幕人妻被公上司喝醉在线| 亚洲国产欧美一区二区丝袜黑人| 污污小视频91在线观看| 欧美久久久久久三级网| 北条麻妃av在线免费观看| 38av一区二区三区| 人妻久久无码中文成人| 九色porny九色9l自拍视频| 亚洲午夜伦理视频在线| 亚洲 欧美 精品 激情 偷拍| 日韩午夜福利精品试看| 中国产一级黄片免费视频播放| 国产成人综合一区2区| 亚洲另类综合一区小说| 国产精品3p和黑人大战| 91精品国产麻豆国产| 欧美80老妇人性视频| 亚洲 图片 欧美 图片| 欧美爆乳肉感大码在线观看| 久久永久免费精品人妻专区 | 日本啪啪啪啪啪啪啪| 少妇系列一区二区三区视频| 精品美女福利在线观看| 国产一区av澳门在线观看| h国产小视频福利在线观看| 午夜精品一区二区三区更新| 中文字幕人妻熟女在线电影| 亚洲成人黄色一区二区三区| 激情五月婷婷综合色啪| 亚洲 色图 偷拍 欧美| 日本福利午夜电影在线观看| 啊用力插好舒服视频| 亚洲一区二区三区uij| 蜜桃视频在线欧美一区| 亚洲国产精品久久久久久6| 亚洲国产成人无码麻豆艾秋| 国产极品精品免费视频| 热99re69精品8在线播放| 亚洲国产精品黑丝美女| 男人的天堂av日韩亚洲| 最近的中文字幕在线mv视频| 大白屁股精品视频国产| 五月色婷婷综合开心网4438| 沙月文乃人妻侵犯中文字幕在线 | 五月精品丁香久久久久福利社| 18禁精品网站久久| 日韩中文字幕在线播放第二页| 欧美香蕉人妻精品一区二区| 天天日天天日天天射天天干| 天天操天天爽天天干| 一级黄色片夫妻性生活| 中文字幕成人日韩欧美| 视频二区在线视频观看| 天天艹天天干天天操| 成人av电影免费版| 97资源人妻免费在线视频| 久久精品36亚洲精品束缚| 色噜噜噜噜18禁止观看| 午夜在线精品偷拍一区二| 天天射夜夜操综合网| 国产一区二区三免费视频| 中文字幕日韩91人妻在线| 超碰97免费人妻麻豆| 亚洲一区二区三区精品乱码| 黄色大片免费观看网站| brazzers欧熟精品系列| 亚洲中文精品字幕在线观看| 日韩av免费观看一区| 亚洲av午夜免费观看| 日韩一区二区电国产精品| 最后99天全集在线观看| 天天日天天透天天操| 国产又色又刺激在线视频| 一二三中文乱码亚洲乱码one| 97超碰人人搞人人| 中国把吊插入阴蒂的视频| 欧美特级特黄a大片免费| 国产精品人久久久久久| 福利午夜视频在线合集| 婷婷六月天中文字幕| 午夜极品美女福利视频| 中文字幕在线第一页成人| 91九色国产熟女一区二区| 精品美女福利在线观看| 狠狠地躁夜夜躁日日躁| 亚洲国产40页第21页| 啪啪啪操人视频在线播放| av资源中文字幕在线观看| 免费在线黄色观看网站| 在线网站你懂得老司机| 久久久精品精品视频视频| 国产一区成人在线观看视频| aiss午夜免费视频| 晚上一个人看操B片| 2021久久免费视频| 人妻丝袜精品中文字幕| 日韩欧美一级黄片亚洲| 久久精品国产999| 97精品综合久久在线| 亚洲va国产va欧美va在线| 五月婷婷在线观看视频免费| 中文字幕免费福利视频6| 亚洲青青操骚货在线视频| 亚洲人一区二区中文字幕| 中文字幕网站你懂的| 国产黄网站在线观看播放| 欧美国品一二三产区区别| 青青草成人福利电影| 黄色录像鸡巴插进去| 巨乳人妻日下部加奈被邻居中出 | 亚洲免费福利一区二区三区| 天天干天天日天天干天天操| 爱爱免费在线观看视频| 护士小嫩嫩又紧又爽20p| 午夜场射精嗯嗯啊啊视频| 欧美精品资源在线观看| 一区二区三区四区视频| 国产精选一区在线播放| 美女骚逼日出水来了| 国产精品视频欧美一区二区| 国产aⅴ一线在线观看| 中文乱理伦片在线观看| 欧美日本在线观看一区二区| 人妻丰满熟妇综合网| 3344免费偷拍视频| 黄色资源视频网站日韩| 日韩av中文在线免费观看| 在线观看国产免费麻豆| 国产91精品拍在线观看| 欧美成一区二区三区四区| 国产欧美精品一区二区高清| 91久久综合男人天堂| 在线国产日韩欧美视频| 天天操夜夜操天天操天天操 | 麻豆精品成人免费视频| 日韩熟女av天堂系列| 亚洲中文字幕国产日韩| av中文字幕网址在线| 欧美日韩激情啪啪啪| 国产内射中出在线观看| 日本特级片中文字幕| jiuse91九色视频| 骚逼被大屌狂草视频免费看| 五月精品丁香久久久久福利社| 国产精品午夜国产小视频| 在线观看日韩激情视频| 久久这里只有精品热视频 | 青青青青爽手机在线| 女人精品内射国产99| 岛国一区二区三区视频在线| 日韩近亲视频在线观看| 又大又湿又爽又紧A视频| 玖玖一区二区在线观看| 国产亚洲欧美45p| 女生自摸在线观看一区二区三区 | 自拍 日韩 欧美激情| 国产精品一区二区av国| 久碰精品少妇中文字幕av| 欧美日韩在线精品一区二区三| 天天躁夜夜躁日日躁a麻豆| 一色桃子人妻一区二区三区| 熟女视频一区,二区,三区| av在线播放国产不卡| 宅男噜噜噜666免费观看| 在线观看911精品国产| 日韩精品中文字幕福利| 69精品视频一区二区在线观看| 91国语爽死我了不卡| 天天日天天敢天天干| 91中文字幕最新合集| 国产精彩对白一区二区三区| 国产高潮无码喷水AV片在线观看 | 一区二区三区四区视频在线播放| 国产视频在线视频播放| 91精品一区二区三区站长推荐| 美女张开腿让男生操在线看| 天天日天天鲁天天操| 综合色区亚洲熟妇shxstz| 国产乱弄免费视频观看| 精品国产高潮中文字幕| 国产精品黄片免费在线观看| 国产一线二线三线的区别在哪| 欧美日韩精品永久免费网址| 最新97国产在线视频| 一区二区三区综合视频| 国产揄拍高清国内精品对白 | av无限看熟女人妻另类av| 最新国产精品拍在线观看| 国产欧美日韩在线观看不卡| 91国内精品自线在拍白富美| 一区二区三区四区视频在线播放| 可以免费看的www视频你懂的| 天堂av中文在线最新版| 久久久超爽一二三av| 中文字幕一区二 区二三区四区 | 亚洲伊人色一综合网| 偷拍自拍福利视频在线观看| 国产卡一卡二卡三乱码手机| 美女av色播在线播放| 社区自拍揄拍尻屁你懂的| av成人在线观看一区| 久草视频中文字幕在线观看| 久碰精品少妇中文字幕av | 日韩不卡中文在线视频网站| 亚洲综合图片20p| 99av国产精品欲麻豆| 亚洲精品乱码久久久久久密桃明| 国产av自拍偷拍盛宴| 国产成人精品福利短视频| 黄页网视频在线免费观看| 在线观看亚洲人成免费网址| 女蜜桃臀紧身瑜伽裤| 日韩黄色片在线观看网站| 偷青青国产精品青青在线观看| 欧美成人精品欧美一级黄色| 日本18禁久久久久久| 在线观看av2025| 天天操,天天干,天天射| 1769国产精品视频免费观看| 扒开腿挺进肉嫩小18禁视频| 久久久久只精品国产三级| 久久麻豆亚洲精品av| 99re6热在线精品| 粉嫩av蜜乳av蜜臀| okirakuhuhu在线观看| 蜜臀成人av在线播放| 国产刺激激情美女网站| 精产国品久久一二三产区区别| 久久综合老鸭窝色综合久久| 香蕉aⅴ一区二区三区| 亚洲在线观看中文字幕av| 亚洲人成精品久久久久久久| 天天干天天插天天谢| 337p日本大胆欧美人| 中文字幕日韩无敌亚洲精品| 国产精品中文av在线播放 | 中文字幕日韩无敌亚洲精品| 欧美精品欧美极品欧美视频 | 日本免费视频午夜福利视频| 欧洲欧美日韩国产在线| 午夜婷婷在线观看视频| 一区二区视频在线观看免费观看| 啊啊好慢点插舔我逼啊啊啊视频| 午夜免费体验区在线观看| 最近的中文字幕在线mv视频| 国产性色生活片毛片春晓精品| 欧美老鸡巴日小嫩逼| 非洲黑人一级特黄片| 国产在线观看黄色视频| 日视频免费在线观看| 欧美黑人巨大性xxxxx猛交| 成人sm视频在线观看| 国产精品久久久久久久久福交| 午夜久久久久久久99| 国产午夜激情福利小视频在线| 国产精品一二三不卡带免费视频| 午夜的视频在线观看| 亚洲成人国产av在线| 大香蕉福利在线观看| 国产伦精品一区二区三区竹菊| 欧美偷拍自拍色图片| 国产成人精品av网站| 又大又湿又爽又紧A视频| 啊啊好大好爽啊啊操我啊啊视频| 丰满的继坶3中文在线观看| 亚洲av香蕉一区区二区三区犇| 91老师蜜桃臀大屁股| 天天射夜夜操综合网| 欧美特色aaa大片| 中文字幕无码日韩专区免费| 国产精品污污污久久| 中文字幕av一区在线观看| 中文字幕日韩精品就在这里| 早川濑里奈av黑人番号| 一区二区三区国产精选在线播放| 又粗又长 明星操逼小视频| 韩国三级aaaaa高清视频| 中文字幕人妻av在线观看| 男人天堂av天天操| 国产一区av澳门在线观看| 五月激情婷婷久久综合网| 99热99这里精品6国产| 亚洲无码一区在线影院| 成人av免费不卡在线观看| 欧美专区日韩专区国产专区| 国产日韩av一区二区在线| 偷青青国产精品青青在线观看| 欧美精品一区二区三区xxxx| 黑人解禁人妻叶爱071| 亚洲偷自拍高清视频| 精品国产乱码一区二区三区乱| 自拍偷拍 国产资源| 男人和女人激情视频| 红桃av成人在线观看| 亚洲变态另类色图天堂网| 丝袜亚洲另类欧美变态| 一二三中文乱码亚洲乱码one| 在线观看操大逼视频| 国产精品sm调教视频| 熟女少妇激情五十路| 毛片一级完整版免费| 丝袜长腿第一页在线| 香港三日本三韩国三欧美三级| 欧美综合婷婷欧美综合| 日辽宁老肥女在线观看视频| 久久精品在线观看一区二区| 国产精品污污污久久| 国产精品人久久久久久| 少妇被强干到高潮视频在线观看| 亚洲欧洲av天堂综合| 久久精品在线观看一区二区| av森泽佳奈在线观看| 东游记中文字幕版哪里可以看到| 综合激情网激情五月天| 精品视频国产在线观看| 亚洲国产成人无码麻豆艾秋| 天天躁日日躁狠狠躁躁欧美av | 亚洲午夜精品小视频| 久久丁香花五月天色婷婷| 日本少妇的秘密免费视频| 亚洲一级特黄特黄黄色录像片| 国产成人无码精品久久久电影| 天天日天天干天天插舔舔| 欧美伊人久久大香线蕉综合| 人妻少妇亚洲精品中文字幕| 在线观看视频一区麻豆| 热99re69精品8在线播放| 亚洲中文精品字幕在线观看| 91国偷自产一区二区三区精品| 天天日天天操天天摸天天舔| 免费在线黄色观看网站| 久久久久久cao我的性感人妻 | 国产av欧美精品高潮网站| 婷婷色国产黑丝少妇勾搭AV| 亚洲一区二区三区久久午夜 | 国产麻豆剧果冻传媒app| 在线观看欧美黄片一区二区三区 | 亚洲码av无色中文| 午夜精品亚洲精品五月色| 777奇米久久精品一区| 国产福利小视频免费观看| 一区二区三区另类在线 | 国产精彩福利精品视频| 男生舔女生逼逼视频| 日本脱亚入欧是指什么| 久久尻中国美女视频| 91欧美在线免费观看| 亚洲中文字幕人妻一区| 天天射夜夜操综合网| 激情啪啪啪啪一区二区三区 | 很黄很污很色的午夜网站在线观看| 大陆精品一区二区三区久久| 大肉大捧一进一出好爽在线视频| 日本男女操逼视频免费看| 成人色综合中文字幕| 久草视频在线免播放| 亚洲国产精品中文字幕网站| 亚洲一级av大片免费观看| 9色精品视频在线观看| 国产精品大陆在线2019不卡| 大胆亚洲av日韩av| 久久这里有免费精品| 人人人妻人人澡人人| 51国产偷自视频在线播放| 午夜在线观看一区视频| 玖玖一区二区在线观看| 最新91精品视频在线| 久久这里有免费精品| 91九色国产熟女一区二区| 热思思国产99re| 小穴多水久久精品免费看| 中文字幕网站你懂的| 欲满人妻中文字幕在线| sejizz在线视频| 精品一区二区三四区| 亚洲变态另类色图天堂网| 天天日天天日天天擦| 国产精品黄片免费在线观看| 免费在线福利小视频| 午夜福利人人妻人人澡人人爽| avjpm亚洲伊人久久| av大全在线播放免费| 3337p日本欧洲大胆色噜噜| 521精品视频在线观看| 欧美日韩激情啪啪啪| 天天插天天色天天日| 久久久久久97三级| 日本一区精品视频在线观看| 久久久精品精品视频视频| 一区二区麻豆传媒黄片| 免费在线黄色观看网站| 中文字幕在线观看国产片| 国产丰满熟女成人视频| 99热这里只有精品中文| 在线播放一区二区三区Av无码| 大香蕉伊人国产在线| 亚洲av色香蕉一区二区三区 | 中文字幕视频一区二区在线观看| 国产刺激激情美女网站| 亚洲欧美自拍另类图片| 激情伦理欧美日韩中文字幕| 亚洲国产成人无码麻豆艾秋| 日本免费午夜视频网站| 人妻少妇精品久久久久久| weyvv5国产成人精品的视频| 五十路丰满人妻熟妇| 5528327男人天堂| 偷拍自拍亚洲视频在线观看| 精品日产卡一卡二卡国色天香| 亚洲卡1卡2卡三卡四老狼| 又粗又硬又猛又爽又黄的| 亚洲欧洲av天堂综合| 懂色av之国产精品| 欧美日韩激情啪啪啪| 日本一本午夜在线播放| 天天操天天干天天日狠狠插| 女同久久精品秋霞网| 成年人该看的视频黄免费| 天天干天天操天天玩天天射 | 精品久久久久久久久久久a√国产| 91极品大一女神正在播放| 午夜福利资源综合激情午夜福利资 | 国产成人一区二区三区电影网站 | 国产janese在线播放| 在线视频精品你懂的| 日本免费视频午夜福利视频| 人妻少妇一区二区三区蜜桃| 100%美女蜜桃视频| 91精品综合久久久久3d动漫| 爱爱免费在线观看视频| 天天色天天操天天舔| 视频一区 二区 三区 综合| 97小视频人妻一区二区| 午夜婷婷在线观看视频| 88成人免费av网站| 日韩美女综合中文字幕pp| 白白操白白色在线免费视频| 激情伦理欧美日韩中文字幕| 亚洲成人激情视频免费观看了| 非洲黑人一级特黄片| 一区二区在线视频中文字幕| 一区二区三区四区中文| 日本阿v视频在线免费观看| 97青青青手机在线视频| 亚洲激情,偷拍视频| 久久丁香花五月天色婷婷| 亚洲免费成人a v| 91av中文视频在线| 夏目彩春在线中文字幕| 99国内精品永久免费视频| 日本少妇人妻xxxxx18| 无码国产精品一区二区高潮久久4| 超碰97人人做人人爱| 99精品国产自在现线观看| 人妻少妇精品久久久久久| 久久三久久三久久三久久| 日韩欧美在线观看不卡一区二区 | 青青草亚洲国产精品视频| 日韩欧美国产精品91| 在线观看911精品国产| 好吊操视频这里只有精品| 天天干天天搞天天摸| 99精品免费久久久久久久久a| 日本午夜久久女同精女女| 日本一本午夜在线播放| 亚洲欧洲av天堂综合| 青青青国产免费视频| 黑人变态深video特大巨大| 蜜臀av久久久久久久| 精品suv一区二区69| 免费大片在线观看视频网站| 国产亚洲四十路五十路| 51国产成人精品视频| 午夜国产福利在线观看| 国产精品黄页网站视频| 成人在线欧美日韩国产| 中文乱理伦片在线观看| 福利视频一区二区三区筱慧 | 国产熟妇乱妇熟色T区| 日本少妇人妻xxxxxhd| 国产精品一二三不卡带免费视频| 999久久久久999| 久久综合老鸭窝色综合久久| 国产精品自拍在线视频| 人妻丰满熟妇综合网| 欧美亚洲国产成人免费在线 | 91在线视频在线精品3| 天天射夜夜操狠狠干| 午夜精品在线视频一区| 欧美激情精品在线观看| 青青青艹视频在线观看| 一区二区麻豆传媒黄片| 午夜毛片不卡免费观看视频| 国产一级精品综合av| 精品一区二区亚洲欧美| 在线观看亚洲人成免费网址| 黄色片一级美女黄色片| 亚洲国产精品免费在线观看| 欧美日韩v中文在线| 中文字幕av一区在线观看| 99婷婷在线观看视频| 国产精品久久久久久美女校花| 人妻丝袜精品中文字幕| 亚洲中文字幕人妻一区| 天码人妻一区二区三区在线看 | 亚洲激情,偷拍视频| 中文字日产幕乱六区蜜桃| 蜜桃视频在线欧美一区| 视频一区二区在线免费播放| 日韩北条麻妃一区在线| 亚洲精品av在线观看| 日本黄色特一级视频| 国产老熟女伦老熟妇ⅹ| 欧美日韩情色在线观看| 中文字幕亚洲久久久| 亚洲中文精品人人免费| 午夜在线观看一区视频| 成人久久精品一区二区三区| 偷拍美女一区二区三区| 91精品国产黑色丝袜| 一区二区三区综合视频| av男人天堂狠狠干| 日美女屁股黄邑视频| 成人18禁网站在线播放| 亚洲国产免费av一区二区三区 | 国产性色生活片毛片春晓精品 | 午夜蜜桃一区二区三区| 青草久久视频在线观看| 国产在线一区二区三区麻酥酥| 喷水视频在线观看这里只有精品 | 中文字幕乱码av资源| 亚洲码av无色中文| 亚洲欧美自拍另类图片| 天天操天天干天天艹| 亚洲女人的天堂av| 欧美精品欧美极品欧美视频| 色婷婷精品大在线观看| 美女 午夜 在线视频| weyvv5国产成人精品的视频| 天天日天天透天天操| 2017亚洲男人天堂| 欧美性感尤物人妻在线免费看| 亚洲熟妇无码一区二区三区| 69精品视频一区二区在线观看| 久久久久久久久久一区二区三区| 男人和女人激情视频| 男人的天堂av日韩亚洲| 大香蕉玖玖一区2区| 18禁污污污app下载| 二区中出在线观看老师| 老司机福利精品视频在线| 9l人妻人人爽人人爽| 亚洲另类在线免费观看| 欧美一区二区三区激情啪啪啪| 一区二区视频视频视频| 久碰精品少妇中文字幕av | 黄工厂精品视频在线观看| 伊人日日日草夜夜草| 熟女人妻在线中出观看完整版| 欧美亚洲免费视频观看| 国产丰满熟女成人视频| 欧美日韩在线精品一区二区三| 天天草天天色天天干| 欧美中文字幕一区最新网址| 99精品国产自在现线观看| 啪啪啪18禁一区二区三区| 天堂av在线官网中文| 在线免费91激情四射| 午夜国产免费福利av| 精品91自产拍在线观看一区| av亚洲中文天堂字幕网| 亚洲国产第一页在线观看| 最新日韩av传媒在线| 被大鸡吧操的好舒服视频免费| 2019av在线视频| 99久久成人日韩欧美精品| 91大神福利视频网| 日本最新一二三区不卡在线| 快点插进来操我逼啊视频| 免费看高清av的网站 | 视频在线免费观看你懂得| 午夜精品一区二区三区更新| 在线视频国产欧美日韩| 黄色片年轻人在线观看| 性感美女高潮视频久久久| 日韩精品一区二区三区在线播放| 亚洲av极品精品在线观看| 青青青青爽手机在线| 国产成人精品一区在线观看| 亚洲精品福利网站图片| 亚洲精品国偷自产在线观看蜜桃| 日本成人一区二区不卡免费在线| 亚洲成人黄色一区二区三区| 国产视频网站国产视频| 亚洲精品精品国产综合| 蜜桃视频在线欧美一区| 操的小逼流水的文章| 人人超碰国字幕观看97| 精品黑人一区二区三区久久国产| 日韩熟女av天堂系列| av中文字幕在线观看第三页| 日韩成人免费电影二区| 亚洲最大黄了色网站| www天堂在线久久| 国产福利在线视频一区| 91麻豆精品秘密入口在线观看| 精品一区二区三区在线观看| 亚洲精品久久综合久| 天天躁日日躁狠狠躁av麻豆| 亚洲欧美自拍另类图片| 75国产综合在线视频| 黄片大全在线观看观看| 国产视频在线视频播放| 国产+亚洲+欧美+另类| 经典国语激情内射视频| 亚洲一级美女啪啪啪| 97国产在线av精品| 五十路熟女av天堂| 亚洲成人av在线一区二区| 国产精品视频欧美一区二区| 大胆亚洲av日韩av| 国产麻豆乱子伦午夜视频观看| 精品视频中文字幕在线播放| www久久久久久久久久久| 少妇被强干到高潮视频在线观看| av新中文天堂在线网址| tube69日本少妇| 欧美日韩亚洲国产无线码| 91精品激情五月婷婷在线| 日本性感美女视频网站| 日本少妇在线视频大香蕉在线观看| 免费在线观看视频啪啪| 深田咏美亚洲一区二区| 国产午夜男女爽爽爽爽爽视频| 在线观看操大逼视频| 高潮视频在线快速观看国家快速| 天天干夜夜操啊啊啊| 日本精品一区二区三区在线视频。| 国产高潮无码喷水AV片在线观看 | 97精品人妻一区二区三区精品| 日韩美女福利视频网| 欧美精品一区二区三区xxxx| 亚洲2021av天堂| 日本熟妇色熟妇在线观看| 最新国产精品网址在线观看| 中文字幕日本人妻中出| 2o22av在线视频| 天天射,天天操,天天说| 免费观看理论片完整版| 欧美性受xx黑人性猛交| 18禁美女无遮挡免费| 欧美日本在线观看一区二区| 999九九久久久精品| 国产女人露脸高潮对白视频| 中文字幕—97超碰网| 天堂av在线最新版在线| 最新日韩av传媒在线| 11久久久久久久久久久| 成人18禁网站在线播放| 好了av中文字幕在线| 老鸭窝日韩精品视频观看| 中文字幕综合一区二区| 久久久噜噜噜久久熟女av| 亚洲欧美另类手机在线| 欧美日韩情色在线观看| 成人av久久精品一区二区| 中文字幕—97超碰网| 一区二区视频视频视频| 亚洲一级av大片免费观看| 1769国产精品视频免费观看| 国产使劲操在线播放| 在线观看黄色成年人网站| 天天操天天弄天天射| 日韩美女搞黄视频免费| 日韩欧美在线观看不卡一区二区| 涩涩的视频在线观看视频| 一区二区三区毛片国产一区| 成人免费公开视频无毒| 人妻少妇av在线观看| 涩涩的视频在线观看视频| 在线新三级黄伊人网| 午夜精品福利一区二区三区p| 91久久精品色伊人6882| 福利午夜视频在线观看| 韩国女主播精品视频网站| 青青草人人妻人人妻| 亚洲精品中文字幕下载| 快插进小逼里大鸡吧视频| 青青青视频手机在线观看| 91麻豆精品久久久久| 亚洲福利精品视频在线免费观看| 亚洲自拍偷拍综合色| 亚洲精品色在线观看视频| 97瑟瑟超碰在线香蕉| 91极品新人『兔兔』精品新作| 中文字幕免费在线免费| 老司机欧美视频在线看| 国产亚洲四十路五十路| 97小视频人妻一区二区| 国产一线二线三线的区别在哪| 色综合久久久久久久久中文| 大鸡巴后入爆操大屁股美女| 熟女俱乐部一二三区| 亚洲青青操骚货在线视频| 亚洲va国产va欧美精品88| 久久久91蜜桃精品ad| 国产aⅴ一线在线观看| 久久午夜夜伦痒痒想咳嗽P| 偷拍自拍亚洲美腿丝袜| 亚洲av琪琪男人的天堂| 午夜频道成人在线91| 老司机99精品视频在线观看| 又色又爽又黄又刺激av网站| 美日韩在线视频免费看| 中文乱理伦片在线观看| 亚洲伊人色一综合网| 一区二区视频视频视频| 青青青国产免费视频| 欧美视频一区免费在线| 日韩欧美亚洲熟女人妻| 欧美精品欧美极品欧美视频| 天天操天天操天天碰| 成人伊人精品色xxxx视频| 在线免费观看日本伦理| 春色激情网欧美成人| 精品视频一区二区三区四区五区| 内射久久久久综合网| av天堂中文免费在线| 高潮喷水在线视频观看| 自拍偷拍vs一区二区三区| 精品区一区二区三区四区人妻| 激情综合治理六月婷婷| 姐姐的朋友2在线观看中文字幕| 最新的中文字幕 亚洲| 狠狠地躁夜夜躁日日躁| 人妻3p真实偷拍一二区| aaa久久久久久久久| ka0ri在线视频| 特黄老太婆aa毛毛片| 亚洲av黄色在线网站| 97国产福利小视频合集| 超碰中文字幕免费观看| 中文字幕第1页av一天堂网| 91精品国产黑色丝袜| 一区二区三区视频,福利一区二区| 日本av高清免费网站| h国产小视频福利在线观看| 久精品人妻一区二区三区| 亚洲欧美激情中文字幕| 免费黄色成人午夜在线网站| 大鸡巴插入美女黑黑的阴毛| 日本一本午夜在线播放| 51精品视频免费在线观看| 人人爽亚洲av人人爽av| 国产九色91在线视频| 亚洲综合乱码一区二区| 黄色三级网站免费下载| 国产久久久精品毛片| 亚洲综合在线观看免费| 国产又粗又猛又爽又黄的视频美国| 天天插天天色天天日| 中文字幕日韩91人妻在线| 日视频免费在线观看| 人妻久久久精品69系列| 黄片三级三级三级在线观看| 成人综合亚洲欧美一区 | 日韩人妻xxxxx| 青草亚洲视频在线观看| 免费在线福利小视频| 91亚洲精品干熟女蜜桃频道 | 中文字幕1卡1区2区3区| 可以在线观看的av中文字幕| 蜜臀av久久久久蜜臀av麻豆| 国产熟妇一区二区三区av| 亚洲国产在线精品国偷产拍| 青青青青青青青青青国产精品视频| 久草视频福利在线首页| 亚洲中文字字幕乱码| heyzo蜜桃熟女人妻| 久久精品国产亚洲精品166m| 人人妻人人爽人人澡人人精品| av森泽佳奈在线观看| 51国产成人精品视频| 可以免费看的www视频你懂的| 成人亚洲精品国产精品| 国产视频精品资源网站| 国产chinesehd精品麻豆| 日本又色又爽又黄又粗| 日本在线不卡免费视频| 9国产精品久久久久老师| 成年人的在线免费视频| 国产精品人妻熟女毛片av久| 18禁免费av网站| 亚洲成人线上免费视频观看| huangse网站在线观看| 天天色天天舔天天射天天爽| 五十路熟女人妻一区二区9933| 青青伊人一精品视频| 青青青视频自偷自拍38碰| 国产变态另类在线观看| 黑人性生活视频免费看| 亚洲在线免费h观看网站| 成人午夜电影在线观看 久久| sspd152中文字幕在线| 久精品人妻一区二区三区| 91九色国产熟女一区二区| 大白屁股精品视频国产| 日韩精品激情在线观看| 天天日天天鲁天天操| 最新国产精品网址在线观看| 国产综合精品久久久久蜜臀| 91精品国产91久久自产久强| 2022精品久久久久久中文字幕| 五十路人妻熟女av一区二区| 日本精品美女在线观看| 国产夫妻视频在线观看免费| 又粗又长 明星操逼小视频| 中文字幕无码日韩专区免费| 韩国一级特黄大片做受| 国产夫妻视频在线观看免费| 精品日产卡一卡二卡国色天香| 欧美成人精品欧美一级黄色| 88成人免费av网站| 好太好爽好想要免费| 丝袜肉丝一区二区三区四区在线| 午夜的视频在线观看| 好吊视频—区二区三区| 动色av一区二区三区| 精品首页在线观看视频| 国产麻豆剧传媒精品国产av蜜桃| 午夜精品久久久久麻豆影视| 亚洲成人情色电影在线观看| 色呦呦视频在线观看视频| 成年人午夜黄片视频资源| 亚洲青青操骚货在线视频| 亚洲一级av大片免费观看| 亚洲另类图片蜜臀av| 日本黄在免费看视频| 国产亚洲四十路五十路| 黄片三级三级三级在线观看| 日韩在线中文字幕色| 老师让我插进去69AV| 亚洲精品国产综合久久久久久久久| 美女福利写真在线观看视频| 亚洲2021av天堂| 日本性感美女写真视频| 熟女妇女老妇一二三区| 国产综合精品久久久久蜜臀| 午夜精品九一唐人麻豆嫩草成人| 中文字幕在线一区精品| 亚洲2021av天堂| av俺也去在线播放| 欧美综合婷婷欧美综合| 亚洲自拍偷拍精品网| 2020韩国午夜女主播在线| 黄色中文字幕在线播放| 亚洲欧美一卡二卡三卡| 国产超码片内射在线| 国产精品黄色的av| 国产乱弄免费视频观看| 天天躁夜夜躁日日躁a麻豆| 亚洲精品高清自拍av| 色综合天天综合网国产成人| 日韩无码国产精品强奸乱伦| 亚洲久久午夜av一区二区| 亚洲成人线上免费视频观看| 蜜桃精品久久久一区二区| 任我爽精品视频在线播放| 亚洲久久午夜av一区二区| 美味人妻2在线播放| 国产妇女自拍区在线观看| 亚洲青青操骚货在线视频| 国产精品久久9999| 熟女人妻在线观看视频| 97国产在线av精品| 夜色福利视频在线观看| 快插进小逼里大鸡吧视频| 成年午夜免费无码区| 97成人免费在线观看网站| 国产福利在线视频一区| 操日韩美女视频在线免费看 | 三级av中文字幕在线观看| 日韩av有码一区二区三区4| 北条麻妃av在线免费观看| 欧美一区二区三区啪啪同性| 黄网十四区丁香社区激情五月天| 色综合久久五月色婷婷综合| 春色激情网欧美成人| 久久久极品久久蜜桃| 久久www免费人成一看片| 久久精品36亚洲精品束缚| 在线新三级黄伊人网| 55夜色66夜色国产精品站| 亚洲狠狠婷婷综合久久app| 天天摸天天日天天操| 日本少妇人妻xxxxxhd| 毛片av在线免费看| 男人的天堂在线黄色| 2021天天色天天干| 国产精品手机在线看片| 亚洲Av无码国产综合色区| 少妇ww搡性bbb91| 青草久久视频在线观看| 一区二区三区四区五区性感视频| 日韩人妻xxxxx| 亚洲高清国产拍青青草原| 国产精品久久久久久美女校花| 在线观看视频一区麻豆| 视频二区在线视频观看| 欧美日韩熟女一区二区三区| 一本久久精品一区二区| 中文字幕av男人天堂| 999热精品视频在线| 亚洲av一妻不如妾| 中文字幕午夜免费福利视频| 91人妻精品一区二区在线看| 大鸡巴操娇小玲珑的女孩逼| 青青青青在线视频免费观看| 日韩av有码一区二区三区4 | 伊人精品福利综合导航| 亚洲熟女女同志女同| 日韩成人免费电影二区| 在线观看911精品国产| 亚洲国产在线精品国偷产拍| 色吉吉影音天天干天天操| 91九色porny国产蝌蚪视频| 中文字幕网站你懂的| av中文字幕网址在线| 欧美爆乳肉感大码在线观看| 93精品视频在线观看| 国产成人精品久久二区91| 午夜在线观看岛国av,com| 精品91高清在线观看| 国产女孩喷水在线观看| 亚洲福利精品视频在线免费观看| 精品人妻一二三区久久| 2021天天色天天干| 日韩成人综艺在线播放| 亚洲成人激情视频免费观看了| 在线免费视频 自拍| 午夜青青草原网在线观看| 国产熟妇乱妇熟色T区| 99热这里只有精品中文| 久久久久久9999久久久久| 熟女少妇激情五十路| 精品日产卡一卡二卡国色天香| 天天干天天操天天扣| 欧美精品黑人性xxxx| 偷拍自拍福利视频在线观看| 国产精品伦理片一区二区| 制丝袜业一区二区三区| 欧美一级色视频美日韩| 夜女神免费福利视频| 黄色大片免费观看网站| 亚洲一区二区三区精品视频在线| 91片黄在线观看喷潮| 日韩三级电影华丽的外出| 人妻3p真实偷拍一二区| 亚洲综合自拍视频一区| 亚洲综合乱码一区二区| 日本18禁久久久久久| 福利视频网久久91| 四川乱子伦视频国产vip| 粉嫩小穴流水视频在线观看| 日本少妇高清视频xxxxx| 亚洲av男人天堂久久| 97瑟瑟超碰在线香蕉| 91成人在线观看免费视频| 亚洲 图片 欧美 图片| 黑人巨大精品欧美视频| 搞黄色在线免费观看| 大香蕉伊人中文字幕| 九色视频在线观看免费| 精品视频一区二区三区四区五区| 伊人综合aⅴ在线网| 日本高清成人一区二区三区| 日本三极片视频网站观看| 人妻少妇性色欲欧美日韩| 香蕉aⅴ一区二区三区| 国产97在线视频观看| 看一级特黄a大片日本片黑人| 女同性ⅹxx女同h偷拍| 操人妻嗷嗷叫视频一区二区| av无限看熟女人妻另类av| 亚洲国产在人线放午夜| 亚洲麻豆一区二区三区| 国产麻豆乱子伦午夜视频观看| 欧美交性又色又爽又黄麻豆| 美日韩在线视频免费看| 国产又大又黄免费观看| 2025年人妻中文字幕乱码在线| 二区中出在线观看老师| 日本一区美女福利视频| 大白屁股精品视频国产| 国产熟妇人妻ⅹxxxx麻豆| 二区中出在线观看老师| 亚洲av男人的天堂你懂的| 久碰精品少妇中文字幕av| av中文在线天堂精品| 国产剧情演绎系列丝袜高跟| 18禁网站一区二区三区四区| 18禁美女羞羞免费网站| 国产一区二区三免费视频| 91社福利《在线观看| 亚洲成人情色电影在线观看| 蜜桃视频17c在线一区二区| 少妇人妻久久久久视频黄片| heyzo蜜桃熟女人妻| 日本丰满熟妇大屁股久久| 亚洲国产成人无码麻豆艾秋| 国产高清精品极品美女| 我想看操逼黄色大片| 激情人妻校园春色亚洲欧美| 粉嫩av蜜乳av蜜臀| 日本人妻欲求不满中文字幕| 1024久久国产精品| 99av国产精品欲麻豆| 五十路av熟女松本翔子| 亚洲成a人片777777| 蜜臀av久久久久蜜臀av麻豆| av一区二区三区人妻| 最新91精品视频在线| 人妻3p真实偷拍一二区| 亚洲粉嫩av一区二区三区| 国产高清精品极品美女| 啊啊好大好爽啊啊操我啊啊视频 | www,久久久,com| 国产福利小视频免费观看| 午夜婷婷在线观看视频| jul—619中文字幕在线| 亚洲欧美成人综合在线观看| 亚洲人成精品久久久久久久| 亚洲男人的天堂a在线| 国产亚洲视频在线二区| 超pen在线观看视频公开97| 亚洲少妇高潮免费观看| 国产在线自在拍91国语自产精品| 日韩av熟妇在线观看| 97人人妻人人澡人人爽人人精品| 女同性ⅹxx女同hd| 亚洲卡1卡2卡三卡四老狼| 99精品免费观看视频| 免费一级特黄特色大片在线观看| 亚洲av第国产精品| 98精产国品一二三产区区别| 91色老99久久九九爱精品| 成人sm视频在线观看| 国产精品视频资源在线播放| 99久久99久国产黄毛片| 国产精品视频欧美一区二区| 色偷偷伊人大杳蕉综合网| 亚洲精品午夜久久久久| 97人妻无码AV碰碰视频| 成人激情文学网人妻| 自拍 日韩 欧美激情| 亚洲综合乱码一区二区| 亚洲午夜福利中文乱码字幕| 国产黄色a级三级三级三级| 亚洲av无乱一区二区三区性色| 男女啪啪视频免费在线观看 | 亚洲熟色妇av日韩熟色妇在线| 在线国产精品一区二区三区| 成年人免费看在线视频| 中文字幕av第1页中文字幕| 摧残蹂躏av一二三区| 亚洲va国产va欧美va在线| 青青草精品在线视频观看| 精品黑人巨大在线一区| 久久麻豆亚洲精品av| 中国把吊插入阴蒂的视频| 亚洲熟色妇av日韩熟色妇在线| 久久久久久久亚洲午夜综合福利 | 全国亚洲男人的天堂| 99av国产精品欲麻豆| 免费黄页网站4188| 自拍偷拍亚洲欧美在线视频| 亚洲无线观看国产高清在线| 欧美80老妇人性视频| 国产熟妇乱妇熟色T区| 中国黄色av一级片| 直接能看的国产av| 动漫美女的小穴视频| 国产午夜福利av导航| 天天操天天爽天天干| 日本最新一二三区不卡在线| 亚洲国产美女一区二区三区软件| 蜜桃精品久久久一区二区| 伊人网中文字幕在线视频| 91麻豆精品久久久久| 91天堂精品一区二区| 亚洲国产免费av一区二区三区| 77久久久久国产精产品| 精品国产在线手机在线| 午夜久久久久久久精品熟女| 午夜dv内射一区区| 自拍 日韩 欧美激情| av亚洲中文天堂字幕网| 五十路丰满人妻熟妇| 亚洲 清纯 国产com| 99re6热在线精品| 91人妻精品久久久久久久网站| 国产无遮挡裸体免费直播视频| 亚洲高清国产自产av| 精品国产高潮中文字幕| 人人爽亚洲av人人爽av| 操操网操操伊剧情片中文字幕网| aⅴ五十路av熟女中出| 国产欧美日韩第三页| 亚洲成高清a人片在线观看| 91人妻人人做人人爽在线| 国产福利在线视频一区| 免费在线看的黄片视频| 香蕉91一区二区三区| 国产一区二区三免费视频| 黄色无码鸡吧操逼视频| 麻豆精品成人免费视频| 狠狠躁狠狠爱网站视频| 婷婷综合蜜桃av在线| 一区二区三区在线视频福利| 真实国模和老外性视频| 黄色的网站在线免费看| 少妇系列一区二区三区视频| chinese国产盗摄一区二区| 福利视频广场一区二区| 午夜精品一区二区三区更新| 婷婷综合亚洲爱久久| 韩国一级特黄大片做受| 大鸡吧插逼逼视频免费看| 狠狠的往里顶撞h百合| 果冻传媒av一区二区三区| 在线视频国产欧美日韩| 日韩av有码一区二区三区4| 91国产资源在线视频| 老熟妇xxxhd老熟女| av中文字幕电影在线看| 男人天堂最新地址av| 青青草在观免费国产精品| 欧美日本在线视频一区| 亚洲欧美激情国产综合久久久| yy96视频在线观看| 美女骚逼日出水来了| 丝袜国产专区在线观看| 中国视频一区二区三区| 偷拍自拍福利视频在线观看| 欧洲亚洲欧美日韩综合| 国产成人精品亚洲男人的天堂| 中国产一级黄片免费视频播放| 中文字幕成人日韩欧美| 天堂va蜜桃一区入口| 色综合久久久久久久久中文| 一区二区免费高清黄色视频| 天天干天天爱天天色| 成人影片高清在线观看| 80电影天堂网官网| 人妻3p真实偷拍一二区| 91精品激情五月婷婷在线| 成年人免费看在线视频| 91精品视频在线观看免费| 久久午夜夜伦痒痒想咳嗽P| 中文字幕在线乱码一区二区 | 天天干天天操天天扣| 99热国产精品666| tube69日本少妇| 一个色综合男人天堂| 黄色无码鸡吧操逼视频| aⅴ精产国品一二三产品| 日韩视频一区二区免费观看| 欧美区一区二区三视频| 天天日天天鲁天天操| 激情小视频国产在线| 免费黄高清无码国产| 国产精品黄页网站视频| 日本特级片中文字幕| 国产亚洲精品欧洲在线观看| 久久久久久久精品成人热| www天堂在线久久| 亚洲av成人网在线观看| tube69日本少妇| 国产视频网站国产视频| 美女小视频网站在线| 97国产精品97久久| 国产大学生援交正在播放| 日本午夜爽爽爽爽爽视频在线观看 | 免费av岛国天堂网站| v888av在线观看视频| 在线视频免费观看网| 国产+亚洲+欧美+另类| 少妇高潮无套内谢麻豆| 精产国品久久一二三产区区别| 日本黄色三级高清视频| 2022精品久久久久久中文字幕| 午夜精品一区二区三区更新| 亚洲欧美国产麻豆综合| 最后99天全集在线观看| 2020久久躁狠狠躁夜夜躁| 国产在线一区二区三区麻酥酥| 国产成人无码精品久久久电影| 激情五月婷婷综合色啪| 欧洲精品第一页欧洲精品亚洲 | 孕妇奶水仑乱A级毛片免费看| 丝袜美腿欧美另类 中文字幕| 国产精彩对白一区二区三区| 综合国产成人在线观看| 自拍偷拍日韩欧美一区二区| 天天日天天干天天舔天天射| 亚洲av午夜免费观看| 国产日韩av一区二区在线| yellow在线播放av啊啊啊| 40道精品招牌菜特色| 亚洲人一区二区中文字幕| 91在线免费观看成人| 国产一区自拍黄视频免费观看| 97人妻总资源视频| 亚洲欧美精品综合图片小说| 一个人免费在线观看ww视频| 99热国产精品666| av久久精品北条麻妃av观看| 女蜜桃臀紧身瑜伽裤| 日本阿v视频在线免费观看| 青青青艹视频在线观看| 日韩欧美一级aa大片| 免费在线黄色观看网站| 久草视频在线看免费| 国产免费高清视频视频| av天堂加勒比在线| 青青草人人妻人人妻| jul—619中文字幕在线| 人妻自拍视频中国大陆| 亚洲另类综合一区小说| 国语对白xxxx乱大交| 丰满熟女午夜福利视频| 国产午夜激情福利小视频在线| 亚洲麻豆一区二区三区| 久草视频在线看免费| 最新黄色av网站在线观看| 亚洲av黄色在线网站| 婷婷久久久久深爱网| 国产精品久久久久久久精品视频| 亚洲激情,偷拍视频| 少妇与子乱在线观看| 又大又湿又爽又紧A视频| 97人妻人人澡爽人人精品| 亚洲va欧美va人人爽3p| 91精品国产91久久自产久强| 视频一区 二区 三区 综合| 9色精品视频在线观看| 欧美精品资源在线观看| 欧美一级视频一区二区| 黄色三级网站免费下载| 成年人该看的视频黄免费| 91精品国产综合久久久蜜 | 特级欧美插插插插插bbbbb| 免费观看理论片完整版| 欧美特级特黄a大片免费| 经典亚洲伊人第一页| 青青草亚洲国产精品视频| 粉嫩欧美美人妻小视频| 日韩在线视频观看有码在线| 成熟丰满熟妇高潮xx×xx| 瑟瑟视频在线观看免费视频| 老司机午夜精品视频资源| huangse网站在线观看| 大鸡巴操娇小玲珑的女孩逼| 欧美一级视频一区二区| 久久久精品欧洲亚洲av| 国产麻豆国语对白露脸剧情 | 边摸边做超爽毛片18禁色戒| 大白屁股精品视频国产| 天天色天天操天天舔| 欧美亚洲中文字幕一区二区三区 | 中文字幕无码日韩专区免费| 97精品综合久久在线| 国产视频一区在线观看| 精品视频国产在线观看| 天天干天天搞天天摸| 93人妻人人揉人人澡人人| 男人天堂av天天操| 日本成人不卡一区二区| 免费福利av在线一区二区三区| 日本韩国亚洲综合日韩欧美国产 | 在线免费观看日本片| 在线国产中文字幕视频| av天堂中文字幕最新| 欲满人妻中文字幕在线| 欧美一区二区三区久久久aaa| 2021天天色天天干| 老司机深夜免费福利视频在线观看| 欧美男同性恋69视频| 亚洲在线观看中文字幕av| 一区二区视频在线观看免费观看 | free性日本少妇| 天天躁日日躁狠狠躁躁欧美av| 久久99久久99精品影院| 女同久久精品秋霞网| 东京干手机福利视频| 午夜精品九一唐人麻豆嫩草成人 | 大陆av手机在线观看| 国产精品手机在线看片| 亚洲伊人久久精品影院一美女洗澡| 特级无码毛片免费视频播放| 精品一区二区三区午夜| 欧美韩国日本国产亚洲| av森泽佳奈在线观看| 国产美女一区在线观看| 大屁股熟女一区二区三区| 国产使劲操在线播放| 久久精品美女免费视频| 欧美黑人与人妻精品| 欧美少妇性一区二区三区| 午夜久久久久久久精品熟女| 亚洲国产40页第21页| 2o22av在线视频| 97年大学生大白天操逼| 91一区精品在线观看| 青青青视频自偷自拍38碰| 搡老熟女一区二区在线观看| 日本美女性生活一级片| 91国产在线视频免费观看| yellow在线播放av啊啊啊| 人人妻人人爽人人澡人人精品| 狠狠躁狠狠爱网站视频| 国产精品视频一区在线播放| 成人午夜电影在线观看 久久| 国产97在线视频观看| 91精品视频在线观看免费| 懂色av之国产精品| 98精产国品一二三产区区别| 国产成人午夜精品福利| 中文字幕一区二 区二三区四区 | 一区国内二区日韩三区欧美| 制丝袜业一区二区三区| 欧美精品国产综合久久| 欧美成人黄片一区二区三区 | 老司机福利精品免费视频一区二区 | 亚洲综合图片20p| 中文字幕熟女人妻久久久| 超pen在线观看视频公开97| 成人福利视频免费在线| 亚洲一区av中文字幕在线观看| 岛国黄色大片在线观看| 亚洲图片欧美校园春色| 东京热男人的av天堂| 日本18禁久久久久久| 亚洲午夜高清在线观看| 国产精品一二三不卡带免费视频| 欧美在线一二三视频| 国产福利小视频大全| 日韩欧美一级黄片亚洲| 亚洲av无码成人精品区辽| 18禁美女羞羞免费网站| 国产又粗又猛又爽又黄的视频美国| 久草视频中文字幕在线观看| 日韩精品中文字幕在线| 欧美中文字幕一区最新网址| 亚洲欧美激情国产综合久久久 | 干逼又爽又黄又免费的视频| 伊人开心婷婷国产av| 精品国产成人亚洲午夜| 韩国一级特黄大片做受| 日韩视频一区二区免费观看| 日韩特级黄片高清在线看| 国产高清在线观看1区2区| 亚洲视频在线视频看视频在线| 91麻豆精品久久久久| 97人人模人人爽人人喊| 亚欧在线视频你懂的| 男生用鸡操女生视频动漫| 国产精品成久久久久三级蜜臀av | 天堂v男人视频在线观看| 91亚洲手机在线视频播放| 超碰97免费人妻麻豆| 天天日天天操天天摸天天舔| 天天通天天透天天插| 亚洲一区二区三区精品视频在线| 久久精品久久精品亚洲人| 国产视频在线视频播放| 国产视频一区二区午夜| 顶级尤物粉嫩小尤物网站| lutube在线成人免费看 | 在线亚洲天堂色播av电影| 亚洲国产成人av在线一区| 中文字幕av熟女人妻| 午夜精品久久久久久99热| 人人妻人人爽人人添夜| 日本韩国免费一区二区三区视频 | 久久久久久cao我的性感人妻 | 日韩成人免费电影二区| 人人超碰国字幕观看97| 中文字幕在线欧美精品| 92福利视频午夜1000看| 精品一区二区三四区| 在线免费观看黄页视频| 欧美日韩中文字幕欧美| 91香蕉成人app下载| 久久久久久久久久久久久97| 色伦色伦777国产精品| 很黄很污很色的午夜网站在线观看| 中文字幕在线永久免费播放| 女蜜桃臀紧身瑜伽裤| 在线可以看的视频你懂的| 日本又色又爽又黄又粗| 美女福利视频网址导航| 狍和女人的王色毛片| 蜜桃视频17c在线一区二区| 中文字幕1卡1区2区3区| 综合一区二区三区蜜臀| 91啪国自产中文字幕在线| 精品首页在线观看视频| 大黑人性xxxxbbbb| 亚洲成人午夜电影在线观看| 久久精品国产999| 日本最新一二三区不卡在线| 最新中文字幕乱码在线| 激情小视频国产在线| 福利午夜视频在线观看| 国产视频网站国产视频| 欧美成人小视频在线免费看| 大陆av手机在线观看| 国产真实灌醉下药美女av福利| 天天干天天啪天天舔| 极品性荡少妇一区二区色欲| 含骚鸡巴玩逼逼视频| 日本脱亚入欧是指什么| 99热碰碰热精品a中文| 一二三中文乱码亚洲乱码one| 欧美第一页在线免费观看视频| 欧美成人黄片一区二区三区| 免费高清自慰一区二区三区网站| 888亚洲欧美国产va在线播放| 97资源人妻免费在线视频| 男人的天堂在线黄色| 亚洲熟色妇av日韩熟色妇在线| 97精品视频在线观看| 极品性荡少妇一区二区色欲| 日本人妻少妇18—xx| 亚洲av日韩精品久久久久久hd| 丰满少妇翘臀后进式| 女生自摸在线观看一区二区三区| 一区二区三区 自拍偷拍| 中文字幕AV在线免费看 | 亚洲av男人天堂久久| 在线免费观看靠比视频的网站| 青青青视频自偷自拍38碰| 粗大的内捧猛烈进出爽大牛汉子| 啊啊好大好爽啊啊操我啊啊视频| 日日夜夜精品一二三| 少妇与子乱在线观看| 40道精品招牌菜特色| 天天色天天操天天舔| 国际av大片在线免费观看| 好吊视频—区二区三区| av大全在线播放免费| 十八禁在线观看地址免费| 日日夜夜精品一二三| av日韩在线观看大全| 成人24小时免费视频| 丝袜国产专区在线观看| 熟女国产一区亚洲中文字幕| 亚洲欧美一区二区三区电影| 天天做天天干天天舔| 丝袜美腿欧美另类 中文字幕| 午夜频道成人在线91| 涩涩的视频在线观看视频| 熟女俱乐部一二三区| 国产 在线 免费 精品| 香蕉aⅴ一区二区三区| 大香蕉伊人中文字幕| 美女小视频网站在线| 国产精品熟女久久久久浪潮| 人人妻人人澡欧美91精品| 大鸡巴操b视频在线| 国产一区av澳门在线观看| 视频一区 二区 三区 综合| 欧美亚洲少妇福利视频| 自拍偷拍日韩欧美亚洲| 日韩av免费观看一区| 久久久久久99国产精品| 久久农村老妇乱69系列| 成人性黑人一级av| 动漫美女的小穴视频| 综合激情网激情五月五月婷婷| www天堂在线久久| 馒头大胆亚洲一区二区| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 国产精品一区二区三区蜜臀av| 无忧传媒在线观看视频| 欧美日韩国产一区二区三区三州| 视频一区 二区 三区 综合| 欧美老鸡巴日小嫩逼| 岛国免费大片在线观看| 狠狠的往里顶撞h百合| 亚洲国产精品中文字幕网站| 天天干天天操天天插天天日| 久久久精品精品视频视频| 揄拍成人国产精品免费看视频| 亚洲福利天堂久久久久久 | 久久这里只有精品热视频 | 亚洲欧美激情中文字幕| 一区二区三区蜜臀在线| 日日爽天天干夜夜操| 人人人妻人人澡人人| 美女被肏内射视频网站| 亚洲欧美综合在线探花| 国产janese在线播放| free性日本少妇| 中国产一级黄片免费视频播放| 欧美日韩一级黄片免费观看| 夜鲁夜鲁狠鲁天天在线| 中文字幕一区二区三区蜜月| 美女在线观看日本亚洲一区| 天堂av狠狠操蜜桃| 521精品视频在线观看| 中文字幕高清在线免费播放| 国产性色生活片毛片春晓精品| 91九色porny国产蝌蚪视频| 青青青爽视频在线播放| 免费黄页网站4188| 521精品视频在线观看| 久草福利电影在线观看| 国产1区,2区,3区| 性欧美日本大妈母与子| 青青草在观免费国产精品| 国产无遮挡裸体免费直播视频| sspd152中文字幕在线| 综合精品久久久久97| 亚洲天堂精品福利成人av| 93人妻人人揉人人澡人人| 中文字幕综合一区二区| 不卡一区一区三区在线| 北条麻妃av在线免费观看| 国产超码片内射在线| 欧美黑人与人妻精品| 综合一区二区三区蜜臀| av亚洲中文天堂字幕网| 午夜精品久久久久久99热 | 在线视频精品你懂的| 久久精品美女免费视频| 人人妻人人爽人人添夜| 日本最新一二三区不卡在线 | 97人人妻人人澡人人爽人人精品| 亚洲国产成人无码麻豆艾秋| 色爱av一区二区三区| 一区二区三区的久久的蜜桃的视频 | 香港一级特黄大片在线播放| 成熟丰满熟妇高潮xx×xx| 亚洲av色图18p| 日本免费午夜视频网站| 丝袜肉丝一区二区三区四区在线看| 婷婷色国产黑丝少妇勾搭AV|