婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 算法系列15天速成 第十四天 圖【上】

算法系列15天速成 第十四天 圖【上】

熱門標簽:語音平臺系統 醫院地圖標注 洛陽便宜外呼系統廠家 地圖標注和圖片標注 電銷機器人怎么收費 湖北穩定外呼系統 忻州外呼系統接口對接 滄州智能外呼系統收費 嘟聲的電銷機器人

今天來分享一下圖,這是一種比較復雜的非線性數據結構,之所以復雜是因為他們的數據元素之間的關系是任意的,而不像樹那樣 被幾個性質定理框住了,元素之間的關系還是比較明顯的,圖的使用范圍很廣的,比如網絡爬蟲,求最短路徑等等,不過大家也不要膽怯,

越是復雜的東西越能體現我們碼農的核心競爭力。       

      既然要學習圖,得要遵守一下圖的游戲規則。

一: 概念

       圖是由“頂點”的集合和“邊”的集合組成。記作:G=(V,E);

1> 無向圖

       就是“圖”中的邊沒有方向,那么(V1,V2)這條邊自然跟(V2,V1)是等價的,無向圖的表示一般用”圓括號“。

        

2> 有向圖

       “圖“中的邊有方向,自然V1,V2>這條邊跟V2,V1>不是等價的,有向圖的表示一般用"尖括號"表示。

             

3> 鄰接點

             一條邊上的兩個頂點叫做鄰接點,比如(V1,V2),(V1,V3),(V1,V5),只是在有向圖中有一個“入邊,出邊“的

       概念,比如V3的入邊為V5,V3的出邊為V2,V1,V4。

 

4> 頂點的度

          這個跟“樹”中的度的意思一樣。不過有向圖中也分為“入度”和“出度”兩種,這個相信大家懂的。

 

5> 完全圖

         每兩個頂點都存在一條邊,這是一種完美的表現,自然可以求出邊的數量。

        無向圖:edges=n(n-1)/2;

        有向圖:edges=n(n-1);           //因為有向圖是有邊的,所以必須在原來的基礎上"X2"。

       

6> 子圖

        如果G1的所有頂點和邊都在G2中,則G1是G2的子圖,具體不說了。

 

7> 路徑,路徑長度和回路(這些概念還是比較重要的)

       路徑:        如果Vm到Vn之間存在一個頂點序列。則表示Vm到Vn是一條路徑。

       路徑長度:  一條路徑中“邊的數量”。

       簡單路徑:  若一條路徑上頂點不重復出現,則是簡單路徑。

       回路:       若路徑的第一個頂點和最后一個頂點相同,則是回路。

       簡單回路:  第一個頂點和最后一個頂點相同,其它各頂點都不重復的回路則是簡單回路。

 

8> 連通圖和連通分量(針對無向圖而言的)

       連通圖:     無向圖中,任意兩個頂點都是連通的則是連通圖,比如V1,V2,V4之間。

       連通分量:  無向圖的極大連通子圖就是連通分量,一般”連通分量“就是”圖“本身,除非是“非連通圖”,

                       如下圖就是兩個連通分量。

           

9> 強連通圖和強連通分量(針對有向圖而言)

        這里主要注意的是“方向性“,V4可以到V3,但是V3無法到V4,所以不能稱為強連通圖。

       

10> 網

        邊上帶有”權值“的圖被稱為網。很有意思啊,呵呵。

 

二:存儲

     圖的存儲常用的是”鄰接矩陣”和“鄰接表”。

     鄰接矩陣: 手法是采用兩個數組,一個一維數組用來保存頂點信息,一個二維數組來用保存邊的信息,

                    缺點就是比較耗費空間。

     鄰接表:   改進后的“鄰接矩陣”,缺點是不方便判斷兩個頂點之間是否有邊,但是相比節省空間。

 

三: 創建圖

     這里我們就用鄰接矩陣來保存圖,一般的操作也就是:①創建,②遍歷

復制代碼 代碼如下:

#region 鄰接矩陣的結構圖
    /// summary>
/// 鄰接矩陣的結構圖
/// /summary>
    public class MatrixGraph
    {
        //保存頂點信息
        public string[] vertex;

        //保存邊信息
        public int[,] edges;

        //深搜和廣搜的遍歷標志
        public bool[] isTrav;

        //頂點數量
        public int vertexNum;

        //邊數量
        public int edgeNum;

        //圖類型
        public int graphType;

        /// summary>
/// 存儲容量的初始化
/// /summary>
/// param name="vertexNum">/param>
/// param name="edgeNum">/param>
/// param name="graphType">/param>
        public MatrixGraph(int vertexNum, int edgeNum, int graphType)
        {
            this.vertexNum = vertexNum;
            this.edgeNum = edgeNum;
            this.graphType = graphType;

            vertex = new string[vertexNum];
            edges = new int[vertexNum, vertexNum];
            isTrav = new bool[vertexNum];
        }

    }
    #endregion

1> 創建圖很簡單,讓用戶輸入一些“邊,點,權值"來構建一下圖

復制代碼 代碼如下:

#region 圖的創建
        /// summary>
/// 圖的創建
/// /summary>
/// param name="g">/param>
        public MatrixGraph CreateMatrixGraph()
        {
            Console.WriteLine("請輸入創建圖的頂點個數,邊個數,是否為無向圖(0,1來表示),已逗號隔開。");

            var initData = Console.ReadLine().Split(',').Select(i => int.Parse(i)).ToList();

            MatrixGraph graph = new MatrixGraph(initData[0], initData[1], initData[2]);

            Console.WriteLine("請輸入各頂點信息:");

            for (int i = 0; i graph.vertexNum; i++)
            {
                Console.Write("\n第" + (i + 1) + "個頂點為:");

                var single = Console.ReadLine();

                //頂點信息加入集合中
                graph.vertex[i] = single;
            }

            Console.WriteLine("\n請輸入構成兩個頂點的邊和權值,以逗號隔開。\n");

            for (int i = 0; i graph.edgeNum; i++)
            {
                Console.Write("第" + (i + 1) + "條邊:\t");

                initData = Console.ReadLine().Split(',').Select(j => int.Parse(j)).ToList();

                int start = initData[0];
                int end = initData[1];
                int weight = initData[2];

                //給矩陣指定坐標位置賦值
                graph.edges[start - 1, end - 1] = weight;

                //如果是無向圖,則數據呈“二,四”象限對稱
                if (graph.graphType == 1)
                {
                    graph.edges[end - 1, start - 1] = weight;
                }
            }

            return graph;
        }
        #endregion

2>廣度優先

      針對下面的“圖型結構”,我們如何廣度優先呢?其實我們只要深刻理解"廣搜“給我們定義的條條框框就行了。 為了避免同一個頂點在遍歷時被多

次訪問,可以將”頂點的下標”存放在sTrav[]的bool數組,用來標識是否已經訪問過該節點。 

    第一步:首先我們從isTrav數組中選出一個未被訪問的節點,如V1。

    第二步:訪問V1的鄰接點V2,V3,V5,并將這三個節點標記為true。

    第三步:第二步結束后,我們開始訪問V2的鄰接點V1,V3,但是他們都是被訪問過的。

    第四步:我們從第二步結束的V3出發訪問他的鄰接點V2,V1,V5,V4,還好V4是未被訪問的,此時標記一下。

    第五步:我們訪問V5的鄰接點V1,V3,V4,不過都是已經訪問過的。

    第六步:有的圖中通過一個頂點的“廣度優先”不能遍歷所有的頂點,此時我們重復(1-5)的步驟就可以最終完成廣度優先遍歷。



復制代碼 代碼如下:

#region 廣度優先
        /// summary>
/// 廣度優先
/// /summary>
/// param name="graph">/param>
        public void BFSTraverse(MatrixGraph graph)
        {
            //訪問標記默認初始化
            for (int i = 0; i graph.vertexNum; i++)
            {
                graph.isTrav[i] = false;
            }

            //遍歷每個頂點
            for (int i = 0; i graph.vertexNum; i++)
            {
                //廣度遍歷未訪問過的頂點
                if (!graph.isTrav[i])
                {
                    BFSM(ref graph, i);
                }
            }
        }

        /// summary>
/// 廣度遍歷具體算法
/// /summary>
/// param name="graph">/param>
        public void BFSM(ref MatrixGraph graph, int vertex)
        {
            //這里就用系統的隊列
            Queueint> queue = new Queueint>();

            //先把頂點入隊
            queue.Enqueue(vertex);

            //標記此頂點已經被訪問
            graph.isTrav[vertex] = true;

            //輸出頂點
            Console.Write(" ->" + graph.vertex[vertex]);

            //廣度遍歷頂點的鄰接點
            while (queue.Count != 0)
            {
                var temp = queue.Dequeue();

                //遍歷矩陣的橫坐標
                for (int i = 0; i graph.vertexNum; i++)
                {
                    if (!graph.isTrav[i] graph.edges[temp, i] != 0)
                    {
                        graph.isTrav[i] = true;

                        queue.Enqueue(i);

                        //輸出未被訪問的頂點
                        Console.Write(" ->" + graph.vertex[i]);
                    }
                }
            }
        }
        #endregion

3> 深度優先

        同樣是這個圖,大家看看如何實現深度優先,深度優先就像鐵骨錚錚的好漢,遵循“能進則進,不進則退”的原則。

        第一步:同樣也是從isTrav數組中選出一個未被訪問的節點,如V1。

        第二步:然后一直訪問V1的鄰接點,一直到走頭無路的時候“回溯”,路線為V1,V2,V3,V4,V5,到V5的時候訪問鄰接點V1,發現V1是訪問過的,

                   此時一直回溯的訪問直到V1。

        第三步: 同樣有的圖中通過一個頂點的“深度優先”不能遍歷所有的頂點,此時我們重復(1-2)的步驟就可以最終完成深度優先遍歷。

              

復制代碼 代碼如下:

#region 深度優先
        /// summary>
/// 深度優先
/// /summary>
/// param name="graph">/param>
        public void DFSTraverse(MatrixGraph graph)
        {
            //訪問標記默認初始化
            for (int i = 0; i graph.vertexNum; i++)
            {
                graph.isTrav[i] = false;
            }

            //遍歷每個頂點
            for (int i = 0; i graph.vertexNum; i++)
            {
                //廣度遍歷未訪問過的頂點
                if (!graph.isTrav[i])
                {
                    DFSM(ref graph, i);
                }
            }
        }

        #region 深度遞歸的具體算法
        /// summary>
/// 深度遞歸的具體算法
/// /summary>
/// param name="graph">/param>
/// param name="vertex">/param>
        public void DFSM(ref MatrixGraph graph, int vertex)
        {
            Console.Write("->" + graph.vertex[vertex]);

            //標記為已訪問
            graph.isTrav[vertex] = true;

            //要遍歷的六個點
            for (int i = 0; i graph.vertexNum; i++)
            {
                if (graph.isTrav[i] == false graph.edges[vertex, i] != 0)
                {
                    //深度遞歸
                    DFSM(ref graph, i);
                }
            }
        }
        #endregion
        #endregion

最后上一下總的代碼

復制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MatrixGraph
{
    public class Program
    {
        static void Main(string[] args)
        {
            MatrixGraphManager manager = new MatrixGraphManager();

            //創建圖
            MatrixGraph graph = manager.CreateMatrixGraph();

            manager.OutMatrix(graph);

            Console.Write("廣度遞歸:\t");

            manager.BFSTraverse(graph);

            Console.Write("\n深度遞歸:\t");

            manager.DFSTraverse(graph);

            Console.ReadLine();

        }
    }

    #region 鄰接矩陣的結構圖
    /// summary>
/// 鄰接矩陣的結構圖
/// /summary>
    public class MatrixGraph
    {
        //保存頂點信息
        public string[] vertex;

        //保存邊信息
        public int[,] edges;

        //深搜和廣搜的遍歷標志
        public bool[] isTrav;

        //頂點數量
        public int vertexNum;

        //邊數量
        public int edgeNum;

        //圖類型
        public int graphType;

        /// summary>
/// 存儲容量的初始化
/// /summary>
/// param name="vertexNum">/param>
/// param name="edgeNum">/param>
/// param name="graphType">/param>
        public MatrixGraph(int vertexNum, int edgeNum, int graphType)
        {
            this.vertexNum = vertexNum;
            this.edgeNum = edgeNum;
            this.graphType = graphType;

            vertex = new string[vertexNum];
            edges = new int[vertexNum, vertexNum];
            isTrav = new bool[vertexNum];
        }

    }
    #endregion

    /// summary>
/// 圖的操作類
/// /summary>
    public class MatrixGraphManager
    {
        #region 圖的創建
        /// summary>
/// 圖的創建
/// /summary>
/// param name="g">/param>
        public MatrixGraph CreateMatrixGraph()
        {
            Console.WriteLine("請輸入創建圖的頂點個數,邊個數,是否為無向圖(0,1來表示),已逗號隔開。");

            var initData = Console.ReadLine().Split(',').Select(i => int.Parse(i)).ToList();

            MatrixGraph graph = new MatrixGraph(initData[0], initData[1], initData[2]);

            Console.WriteLine("請輸入各頂點信息:");

            for (int i = 0; i graph.vertexNum; i++)
            {
                Console.Write("\n第" + (i + 1) + "個頂點為:");

                var single = Console.ReadLine();

                //頂點信息加入集合中
                graph.vertex[i] = single;
            }

            Console.WriteLine("\n請輸入構成兩個頂點的邊和權值,以逗號隔開。\n");

            for (int i = 0; i graph.edgeNum; i++)
            {
                Console.Write("第" + (i + 1) + "條邊:\t");

                initData = Console.ReadLine().Split(',').Select(j => int.Parse(j)).ToList();

                int start = initData[0];
                int end = initData[1];
                int weight = initData[2];

                //給矩陣指定坐標位置賦值
                graph.edges[start - 1, end - 1] = weight;

                //如果是無向圖,則數據呈“二,四”象限對稱
                if (graph.graphType == 1)
                {
                    graph.edges[end - 1, start - 1] = weight;
                }
            }

            return graph;
        }
        #endregion

        #region 輸出矩陣數據
        /// summary>
/// 輸出矩陣數據
/// /summary>
/// param name="graph">/param>
        public void OutMatrix(MatrixGraph graph)
        {
            for (int i = 0; i graph.vertexNum; i++)
            {
                for (int j = 0; j graph.vertexNum; j++)
                {
                    Console.Write(graph.edges[i, j] + "\t");
                }
                //換行
                Console.WriteLine();
            }
        }
        #endregion

        #region 廣度優先
        /// summary>
/// 廣度優先
/// /summary>
/// param name="graph">/param>
        public void BFSTraverse(MatrixGraph graph)
        {
            //訪問標記默認初始化
            for (int i = 0; i graph.vertexNum; i++)
            {
                graph.isTrav[i] = false;
            }

            //遍歷每個頂點
            for (int i = 0; i graph.vertexNum; i++)
            {
                //廣度遍歷未訪問過的頂點
                if (!graph.isTrav[i])
                {
                    BFSM(ref graph, i);
                }
            }
        }

        /// summary>
/// 廣度遍歷具體算法
/// /summary>
/// param name="graph">/param>
        public void BFSM(ref MatrixGraph graph, int vertex)
        {
            //這里就用系統的隊列
            Queueint> queue = new Queueint>();

            //先把頂點入隊
            queue.Enqueue(vertex);

            //標記此頂點已經被訪問
            graph.isTrav[vertex] = true;

            //輸出頂點
            Console.Write(" ->" + graph.vertex[vertex]);

            //廣度遍歷頂點的鄰接點
            while (queue.Count != 0)
            {
                var temp = queue.Dequeue();

                //遍歷矩陣的橫坐標
                for (int i = 0; i graph.vertexNum; i++)
                {
                    if (!graph.isTrav[i] graph.edges[temp, i] != 0)
                    {
                        graph.isTrav[i] = true;

                        queue.Enqueue(i);

                        //輸出未被訪問的頂點
                        Console.Write(" ->" + graph.vertex[i]);
                    }
                }
            }
        }
        #endregion

        #region 深度優先
        /// summary>
/// 深度優先
/// /summary>
/// param name="graph">/param>
        public void DFSTraverse(MatrixGraph graph)
        {
            //訪問標記默認初始化
            for (int i = 0; i graph.vertexNum; i++)
            {
                graph.isTrav[i] = false;
            }

            //遍歷每個頂點
            for (int i = 0; i graph.vertexNum; i++)
            {
                //廣度遍歷未訪問過的頂點
                if (!graph.isTrav[i])
                {
                    DFSM(ref graph, i);
                }
            }
        }

        #region 深度遞歸的具體算法
        /// summary>
/// 深度遞歸的具體算法
/// /summary>
/// param name="graph">/param>
/// param name="vertex">/param>
        public void DFSM(ref MatrixGraph graph, int vertex)
        {
            Console.Write("->" + graph.vertex[vertex]);

            //標記為已訪問
            graph.isTrav[vertex] = true;

            //要遍歷的六個點
            for (int i = 0; i graph.vertexNum; i++)
            {
                if (graph.isTrav[i] == false graph.edges[vertex, i] != 0)
                {
                    //深度遞歸
                    DFSM(ref graph, i);
                }
            }
        }
        #endregion
        #endregion

    }
}

代碼中我們構建了如下的“圖”。

您可能感興趣的文章:
  • 算法系列15天速成——第十三天 樹操作【下】
  • 算法系列15天速成 第十二天 樹操作【中】
  • 算法系列15天速成 第十一天 樹操作(上)
  • 算法系列15天速成 第十天 棧
  • 算法系列15天速成 第八天 線性表【下】
  • 算法系列15天速成 第九天 隊列
  • 算法系列15天速成 第七天 線性表【上】
  • 算法系列15天速成 第六天 五大經典查找【下】
  • 算法系列15天速成 第五天 五大經典查找【中】
  • 算法系列15天速成 第四天 五大經典查找【上】
  • 算法系列15天速成 第三天 七大經典排序【下】
  • 算法系列15天速成 第二天 七大經典排序【中】
  • 算法系列15天速成 第一天 七大經典排序【上】
  • 算法系列15天速成——第十五天 圖【下】(大結局)

標簽:定州 宜賓 日照 96 巴彥淖爾 山南 內蒙古 防城港

巨人網絡通訊聲明:本文標題《算法系列15天速成 第十四天 圖【上】》,本文關鍵詞  算法,系列,15天,速成,第十,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《算法系列15天速成 第十四天 圖【上】》相關的同類信息!
  • 本頁收集關于算法系列15天速成 第十四天 圖【上】的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品白丝av| 欧美大片免费久久精品三p| 风间由美一区二区三区在线观看 | 欧美mv和日韩mv的网站| 国产精品久久久一区麻豆最新章节| 日本不卡不码高清免费观看| 日韩欧美第一区| 精品一区二区免费| 国产午夜精品一区二区| 国产一区视频在线看| 中文字幕国产精品一区二区| 国产精品影音先锋| 精品成人一区二区三区四区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美日韩视频不卡| 日韩国产欧美在线视频| 精品日韩在线观看| 国产一区在线看| 1区2区3区欧美| 高清不卡一二三区| 国产女人aaa级久久久级| 97se亚洲国产综合自在线观| 最好看的中文字幕久久| 欧美专区日韩专区| 麻豆一区二区在线| 中文字幕中文字幕在线一区 | 色视频欧美一区二区三区| 日本乱人伦aⅴ精品| 亚洲精品一卡二卡| 欧美一区二区免费观在线| 蜜臀av在线播放一区二区三区| 欧美日本一道本| 国产一区二区日韩精品| 国产精品网站一区| 欧美四级电影在线观看| 蜜臀av性久久久久蜜臀av麻豆 | 精品区一区二区| gogogo免费视频观看亚洲一| 一区二区三区中文字幕电影 | 欧美区一区二区三区| 国产成人免费高清| 亚洲国产裸拍裸体视频在线观看乱了 | 69堂国产成人免费视频| 国产精品主播直播| 亚洲成人av一区二区| 欧美激情在线免费观看| 欧美日韩不卡一区二区| 在线免费观看日韩欧美| 国产91精品一区二区| 青青草国产精品97视觉盛宴| 亚洲美女偷拍久久| 久久精品人人做人人爽人人 | 色综合久久中文字幕综合网 | 日韩av中文字幕一区二区三区| 中文字幕不卡在线| 久久久精品欧美丰满| 成人国产电影网| 久久不见久久见免费视频1| 欧美激情资源网| 日韩欧美一区二区不卡| 日韩一级片在线播放| 91电影在线观看| 91丨porny丨首页| 热久久久久久久| 婷婷国产在线综合| 国产精品网站一区| 国产一区二区主播在线| 欧美不卡视频一区| 日韩免费性生活视频播放| 91福利视频网站| 夜夜嗨av一区二区三区| 一本一道波多野结衣一区二区| 中文字幕欧美激情| 99国产精品久久久| 亚洲v中文字幕| 综合激情网...| 国产精品久久久久久久久动漫 | 久久精子c满五个校花| 国产丝袜欧美中文另类| 成人免费视频国产在线观看| 国产精品久久影院| 亚洲成人综合网站| 丰满放荡岳乱妇91ww| 久久99精品国产.久久久久| 国产高清在线观看免费不卡| 欧美日韩亚洲国产综合| 中文字幕国产一区二区| 首页国产丝袜综合| 国产麻豆成人精品| 欧美影院午夜播放| 久久综合九色综合欧美就去吻 | 国产成人在线视频免费播放| 亚洲成av人片| 精品一区二区三区免费视频| 5858s免费视频成人| 国产精品久久午夜夜伦鲁鲁| 精品一区二区三区视频| 午夜a成v人精品| 91免费视频大全| 综合久久久久久久| 欧美一区二区视频免费观看| 亚洲资源中文字幕| 欧美四级电影在线观看| 亚洲一区二三区| 7777精品伊人久久久大香线蕉完整版 | 成人在线视频首页| 久久先锋影音av鲁色资源网| 精品中文av资源站在线观看| 555夜色666亚洲国产免| 久久成人综合网| 亚洲乱码国产乱码精品精小说 | 91毛片在线观看| 欧美一区二区三区在线视频| 136国产福利精品导航| 欧美日韩亚洲综合一区二区三区| 日本不卡一区二区三区 | 色中色一区二区| 91精品婷婷国产综合久久竹菊| 日韩电影免费一区| 国产精品丝袜一区| 91精品国产入口| 色综合一个色综合| 色综合久久久久| 五月婷婷激情综合网| 自拍偷自拍亚洲精品播放| 久久先锋资源网| 精品剧情在线观看| 欧美成人一区二区三区| 欧洲av在线精品| 精品久久久久一区二区国产| 一本久久综合亚洲鲁鲁五月天| 国产在线一区二区综合免费视频| 欧美日韩高清不卡| 欧美日韩一区成人| 3d成人动漫网站| 精品国产凹凸成av人网站| 欧美大度的电影原声| 欧美精品高清视频| 国产精品丝袜久久久久久app| 亚洲精品一区二区三区四区高清 | 精品国产免费一区二区三区香蕉| 欧美色视频在线| 欧美不卡一区二区三区四区| 久久伊人蜜桃av一区二区| 午夜精品免费在线| 国产美女在线观看一区| 91精品国产入口| 亚洲男同1069视频| 综合自拍亚洲综合图不卡区| 美日韩一区二区三区| 国产成人激情av| 欧美日韩免费一区二区三区视频| 国产精品成人免费在线| 蜜桃一区二区三区在线观看| 99在线精品视频| 日韩欧美亚洲一区二区| 一区二区三区在线播放| 成人福利视频在线看| 777xxx欧美| 在线亚洲一区二区| 日韩亚洲欧美中文三级| 亚洲午夜国产一区99re久久| av电影在线观看不卡| 国产欧美日韩另类视频免费观看| 国产99久久久国产精品免费看| 日产国产欧美视频一区精品| 在线观看av不卡| 欧美日韩三级在线| 日韩专区欧美专区| 久久精品亚洲麻豆av一区二区 | 亚洲老司机在线| 99久久伊人精品| 香蕉久久一区二区不卡无毒影院| 555www色欧美视频| 麻豆精品视频在线观看免费| 亚洲日韩欧美一区二区在线| 亚洲精品视频观看| 91麻豆精品国产91久久久久久| 美女视频一区在线观看| 中文字幕免费观看一区| 不卡区在线中文字幕| 日韩和欧美一区二区三区| 亚洲精品一区在线观看| 久久av中文字幕片| 国产高清在线精品| 亚洲成人第一页| 日韩区在线观看| 久久久99久久| 日韩一区国产二区欧美三区| 国产一区在线视频| 麻豆久久一区二区| 婷婷开心久久网| 日韩经典一区二区| 欧美成人a视频| 欧美军同video69gay| 国产乱人伦偷精品视频不卡| 日本不卡在线视频| 久久成人免费日本黄色| 日韩va亚洲va欧美va久久| 亚洲午夜成aⅴ人片|