日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

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

编程问答

图的单源最短路径算法

發布時間:2024/3/13 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 图的单源最短路径算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

第1關:求圖(鄰接矩陣存儲)最短路徑的狄克斯特拉算法

任務描述

本關任務:圖的存儲結構為鄰接矩陣,要求編寫函數實現狄克斯特拉算法。

測試說明

平臺會對你編寫的代碼進行測試:

測試輸入:
1
lt4.txt

輸入說明:
第一行輸入1,表示輸入圖的類型為有向網。
第二行輸入文件名,該文件里保存了圖的數據信息,內容如下:
7
12
0
1
2
3
4
5
6
0 1 4
0 2 6
0 3 6
1 2 1
1 4 6
2 4 6
2 5 4
3 2 2
3 5 5
4 6 6
5 4 1
5 6 8
第1行為圖的頂點的個數n;
第2行為圖的邊的條數m;
第3行至第n+2行是n個頂點的數據;
第n+3行至第n+m+2行是m條邊的數據;

預期輸出:
有向網
7個頂點12條邊。頂點依次是: 0 1 2 3 4 5 6
圖的鄰接矩陣:
∞ 4 6 6 ∞ ∞ ∞
∞ ∞ 1 ∞ 6 ∞ ∞
∞ ∞ ∞ ∞ 6 4 ∞
∞ ∞ 2 ∞ ∞ 5 ∞
∞ ∞ ∞ ∞ ∞ ∞ 6
∞ ∞ ∞ ∞ 1 ∞ 8
∞ ∞ ∞ ∞ ∞ ∞ ∞
dist: ∞ 4 6 6 ∞ ∞ ∞
path: -1 0 0 0 -1 -1 -1
dist: ∞ 4 5 6 10 ∞ ∞
path: -1 0 1 0 1 -1 -1
dist: ∞ 4 5 6 10 9 ∞
path: -1 0 1 0 1 2 -1
dist: ∞ 4 5 6 10 9 ∞
path: -1 0 1 0 1 2 -1
dist: ∞ 4 5 6 10 9 17
path: -1 0 1 0 1 2 5
dist: ∞ 4 5 6 10 9 16
path: -1 0 1 0 1 2 4
dist: ∞ 4 5 6 10 9 16
path: -1 0 1 0 1 2 4
從0到1最短路徑長度為:4 0→1
從0到2最短路徑長度為:5 0→1→2
從0到3最短路徑長度為:6 0→3
從0到4最短路徑長度為:10 0→1→4
從0到5最短路徑長度為:9 0→1→2→5
從0到6最短路徑長度為:16 0→1→4→6

輸出說明:
第一行輸出圖的類型。
第二部分起輸出圖的頂點和邊的數據信息。
第三部分輸出輔助數組的變化過程。
第四部分輸出從起點到其余各頂點的最短路徑。

代碼如下

#include<stdio.h> #include<stdlib.h> #include<string.h> #include<limits.h> #include<iostream> using namespace std; #include"MGraph.h"void Dijkstra(MGraph g,int v); //求從v到其他頂點的最短路徑 void DispAllPath(MGraph &g,int dist[],int path[],int S[],int v) ;//輸出從頂點v出發的所有最短路徑 void Dispdistpath(int dist[],int path[],int n); //輸出dist數組和path數組int main() {MGraph g;int i,j,n;CreateGraphF(g); /* 利用數據文件創建有向圖*/Display(g); /* 輸出有向圖*/ Dijkstra(g,0); return 0; }void Dijkstra(MGraph g,int v) { //求從v到其他頂點的最短路徑/********** Begin **********/int min,num,dist[MAX_VERTEX_NUM],path[MAX_VERTEX_NUM],s[MAX_VERTEX_NUM];for(int i = 0; i < g.vexnum; i++){dist[i] = g.arcs[v][i].adj;if(dist[i]!=INFINITY){path[i] = v;}else{path[i] = -1;}}for(int i = 0; i < g.vexnum; i++) s[i] = 0;s[v] = 1;num = 1;while(num<g.vexnum){int mini = INFINITY,m;for(int i = 0; i < g.vexnum; i++){if(s[i]==0&&dist[i]<mini){mini = dist[i];m = i ;}}s[m] = 1;Dispdistpath(dist,path,g.vexnum);for(int i = 0; i < g.vexnum; i++){if(s[i] == 0 && (dist[i] > dist[m] + g.arcs[m][i].adj)){dist[i] = dist[m] + g.arcs[m][i].adj;path[i] = m;}}num++;}Dispdistpath(dist,path,g.vexnum);DispAllPath(g,dist,path,s,v);/********** End **********/ }void DispAllPath(MGraph &g,int dist[],int path[],int S[],int v) //輸出從頂點v出發的所有最短路徑 {int i,j,k,count=0;int apath[MAX_VERTEX_NUM],d; //存放一條最短路徑(逆向)及其頂點個數for (i=0;i<g.vexnum;i++)if (path[i]!=-1)count++;if (count==1) //path中只有一個不為-1時表示沒有路徑{ printf("從指定的頂點到其他頂點都沒有路徑!!!\n");return;}for (i=0;i<g.vexnum;i++) //循環輸出從頂點v到i的路徑if (S[i]==1 && i!=v){//printf("從%s到%s最短路徑長度為:%s\t路徑:",g.vexs [v],g.vexs[i],dist[i]);cout<<"從"<<g.vexs [v]<<"到"<<g.vexs[i]<<"最短路徑長度為:"<<dist[i]<<"\t";d=0; apath[d]=i; //添加路徑上的終點k=path[i];if (k==-1) //沒有路徑的情況printf("無路徑\n");else //存在路徑時輸出該路徑{ while (k!=v){ d++; apath[d]=k;k=path[k];}d++; apath[d]=v; //添加路徑上的起點//printf("%d",apath[d]); //先輸出起點cout<<g.vexs [ apath[d] ];for (j=d-1;j>=0;j--) //再輸出其他頂點//printf("→%d",apath[j]);cout<<"→"<<g.vexs [ apath[j] ];printf("\n");}} }void Dispdistpath(int dist[],int path[],int n) //輸出dist數組和path數組 {int i;printf("dist:\t");for (i=0;i<n;i++)if (dist[i]==INFINITY)printf("%s\t","∞");elseprintf("%d\t",dist[i]);printf("\n");printf("path:\t");for (i=0;i<n;i++)printf("%d\t",path[i]);printf("\n"); }

第2關:求圖(鄰接表存儲)最短路徑的狄克斯特拉算法

任務描述

本關任務:圖的存儲結構為鄰接表,要求編寫函數實現狄克斯特拉算法。

測試說明

平臺會對你編寫的代碼進行測試:

測試輸入:
1
lt4.txt

輸入說明:
第一行輸入1,表示輸入圖的類型為有向網。
第二行輸入文件名,該文件里保存了圖的數據信息,內容如下:
7
12
0
1
2
3
4
5
6
0 1 4
0 2 6
0 3 6
1 2 1
1 4 6
2 4 6
2 5 4
3 2 2
3 5 5
4 6 6
5 4 1
5 6 8
第1行為圖的頂點的個數n;
第2行為圖的邊的條數m;
第3行至第n+2行是n個頂點的數據;
第n+3行至第n+m+2行是m條邊的數據;

預期輸出:
有向網
7個頂點:
0 1 2 3 4 5 6
12條弧(邊):
0→3 :6 0→2 :6 0→1 :4
1→4 :6 1→2 :1
2→5 :4 2→4 :6
3→5 :5 3→2 :2
4→6 :6
5→6 :8 5→4 :1
dist: ∞ 4 6 6 ∞ ∞ ∞
path: -1 0 0 0 -1 -1 -1
dist: ∞ 4 5 6 10 ∞ ∞
path: -1 0 1 0 1 -1 -1
dist: ∞ 4 5 6 10 9 ∞
path: -1 0 1 0 1 2 -1
dist: ∞ 4 5 6 10 9 ∞
path: -1 0 1 0 1 2 -1
dist: ∞ 4 5 6 10 9 17
path: -1 0 1 0 1 2 5
dist: ∞ 4 5 6 10 9 16
path: -1 0 1 0 1 2 4
dist: ∞ 4 5 6 10 9 16
path: -1 0 1 0 1 2 4
從0到1最短路徑長度為:4 0→1
從0到2最短路徑長度為:5 0→1→2
從0到3最短路徑長度為:6 0→3
從0到4最短路徑長度為:10 0→1→4
從0到5最短路徑長度為:9 0→1→2→5
從0到6最短路徑長度為:16 0→1→4→6

輸出說明:
第一行輸出圖的類型。
第二部分起輸出圖的頂點和邊的數據信息。
第三部分輸出輔助數組的變化過程。
第四部分輸出從起點到其余各頂點的最短路徑。

代碼如下

#include<stdio.h> #include<stdlib.h> #include<string.h> #include<limits.h> #include<iostream> using namespace std;#define INFINITY 4270000 // 用整型最大值代替∞ #include"ALGraph.h"int GetWeight(ALGraph G,VertexType a,VertexType b );//獲取權值void Dijkstra(ALGraph g,int v); //求從v到其他頂點的最短路徑 void DispAllPath(ALGraph &g,int dist[],int path[],int S[],int v) ;//輸出從頂點v出發的所有最短路徑 void Dispdistpath(int dist[],int path[],int n); //輸出dist數組和path數組int main() {ALGraph g;int i,j,n;CreateGraphF(g); /* 利用數據文件創建有向圖*/Display(g); /* 輸出有向圖*/ Dijkstra(g,0); return 0; }void Dijkstra(ALGraph g,int v) {//求從v到其他頂點的最短路徑/********** Begin **********/int min,num,dist[MAX_VERTEX_NUM],path[MAX_VERTEX_NUM],s[MAX_VERTEX_NUM];for(int i = 0; i < g.vexnum; i++){dist[i] = GetWeight(g,g.vertices[v].data,g.vertices[i].data);if(dist[i]!=INFINITY){path[i] = v;}else{path[i] = -1;}}for(int i = 0; i < g.vexnum; i++) s[i] = 0;s[v] = 1;num = 1;while(num<g.vexnum){int mini = INFINITY,m;for(int i = 0; i < g.vexnum; i++){if(s[i]==0&&dist[i]<mini){mini = dist[i];m = i ;}}s[m] = 1;Dispdistpath(dist,path,g.vexnum);for(int i = 0; i < g.vexnum; i++){if(s[i] == 0 && (dist[i] > dist[m] + GetWeight(g,g.vertices[m].data,g.vertices[i].data))){dist[i] = dist[m] + GetWeight(g,g.vertices[m].data,g.vertices[i].data);path[i] = m;}}num++;}Dispdistpath(dist,path,g.vexnum);DispAllPath(g,dist,path,s,v);/********** End **********/ }void DispAllPath(ALGraph &g,int dist[],int path[],int S[],int v) //輸出從頂點v出發的所有最短路徑 {int i,j,k,count=0;int apath[MAX_VERTEX_NUM],d; //存放一條最短路徑(逆向)及其頂點個數for (i=0;i<g.vexnum;i++)if (path[i]!=-1)count++;if (count==1) //path中只有一個不為-1時表示沒有路徑{ printf("從指定的頂點到其他頂點都沒有路徑!!!\n");return;}for (i=0;i<g.vexnum;i++) //循環輸出從頂點v到i的路徑if (S[i]==1 && i!=v){//printf("從%s到%s最短路徑長度為:%s\t路徑:",g.vexs [v],g.vexs[i],dist[i]);cout<<"從"<<g.vertices [v].data <<"到"<<g.vertices [i].data <<"最短路徑長度為:"<<dist[i]<<"\t";d=0; apath[d]=i; //添加路徑上的終點k=path[i];if (k==-1) //沒有路徑的情況printf("無路徑\n");else //存在路徑時輸出該路徑{ while (k!=v){ d++; apath[d]=k;k=path[k];}d++; apath[d]=v; //添加路徑上的起點//printf("%d",apath[d]); //先輸出起點cout<<g.vertices [ apath[d] ].data ;for (j=d-1;j>=0;j--) //再輸出其他頂點//printf("→%d",apath[j]);cout<<"→"<<g.vertices [ apath[j] ].data ;printf("\n");}} }void Dispdistpath(int dist[],int path[],int n) //輸出dist數組和path數組 {int i;printf("dist:\t");for (i=0;i<n;i++)if (dist[i]==INFINITY)printf("%s\t","∞");elseprintf("%d\t",dist[i]);printf("\n");printf("path:\t");for (i=0;i<n;i++)printf("%d\t",path[i]);printf("\n"); }int GetWeight(ALGraph G,VertexType a,VertexType b )//獲取權值 { int pa,pb;pa=LocateVex(G,a);pb=LocateVex(G,b);ArcNode* p;p=G.vertices[pa].firstarc;if(pa == pb)return 0;while(p!=NULL){ if( p->data.adjvex == pb)return p->data.info;elsep=p->nextarc;}return INFINITY; }

輔助文件

lt.txt

6 9 武漢 上海 長沙 南京 成都 廣州 武漢 長沙 9 武漢 成都 2 長沙 上海 2 長沙 南京 2 上海 南京 5 上海 廣州 4 上海 成都 3 南京 廣州 8 成都 廣州 6

lt2.txt

7 9 高等數學 程序設計基礎 C語言 離散數學 數據結構 編譯原理 操作系統 高等數學 C語言 高等數學 離散數學 程序設計基礎 數據結構 程序設計基礎 C語言 C語言 數據結構 離散數學 數據結構 離散數學 編譯原理 數據結構 編譯原理 數據結構 操作系統

lt3.txt

5 8 0 1 2 3 4 0 1 1 0 2 3 0 3 4 0 4 7 1 2 2 2 3 5 2 4 8 3 4 6

lt4.txt

7 12 0 1 2 3 4 5 6 0 1 4 0 2 6 0 3 6 1 2 1 1 4 6 2 4 6 2 5 4 3 2 2 3 5 5 4 6 6 5 4 1 5 6 8

lt5.txt

6 11 武漢 杭州 長沙 廈門 南京 上海 武漢 長沙 35 武漢 杭州 40 武漢 廈門 70 長沙 上海 50 長沙 南京 10 長沙 廈門 25 杭州 廈門 20 杭州 長沙 30 廈門 南京 15 廈門 上海 30 南京 上海 20

MGraph.h

#ifndef __MGraph_H__ #define __MGraph_H__ typedef int VRType; // 頂點關系類型 typedef char VertexType[20]; // 頂點類型 // 圖的數組(鄰接矩陣)存儲表示 #define INFINITY 4270000 // 用整型最大值代替∞ #define MAX_VERTEX_NUM 20 // 最大頂點個數 typedef enum{DG,DN,UDG,UDN}GraphKind; // {有向圖,有向網,無向圖,無向網} typedef struct {VRType adj; // 頂點關系類型。對無權圖,用1(是)或0(否)表示相鄰否;對帶權圖,則為權值 }ArcCell,AdjMatrix[MAX_VERTEX_NUM][MAX_VERTEX_NUM]; // 二維數組 typedef struct // 圖的數組(鄰接矩陣)存儲 {VertexType vexs[MAX_VERTEX_NUM]; // 頂點向量 AdjMatrix arcs; // 鄰接矩陣 int vexnum,arcnum; // 圖的當前頂點數和弧數 GraphKind kind; // 圖的種類標志 }MGraph; /*鄰接矩陣的8個基本操作函數聲明*/ int LocateVex(MGraph G,VertexType u);//若圖G中存在頂點u,則返回該頂點在圖中位置;否則返回-1 VertexType* GetVex(MGraph G,int v);// 根據圖G中某個頂點的序號v,返回該頂點的值 void visit(VertexType i);// 訪問輸出頂點的值 int FirstAdjVex(MGraph G,VertexType v);// v是圖G中某個頂點,返回v的第一個鄰接頂點的序號。若頂點v在G中沒有鄰接頂點,則返回-1 int NextAdjVex(MGraph G,VertexType v,VertexType w);//v是圖G中某個頂點,w是v的鄰接頂點,返回v的(相對于w的)下一個鄰接頂點的序號,若w是v的最后一個鄰接頂點,則返回-1 void CreateGraphF(MGraph &G);//采用數組(鄰接矩陣)表示法,由文件構造無向網G void DestroyGraph(MGraph &G);//銷毀圖G void Display(MGraph G);//輸出鄰接矩陣存儲表示的圖G #endif

MGraph.cpp

#include<stdio.h> #include<stdlib.h> #include<string.h> #include"MGraph.h" /*鄰接矩陣的8個基本操作函數定義*/ int LocateVex(MGraph G,VertexType u) {//初始條件:圖G存在,u和G中頂點有相同特征// 操作結果:若G中存在頂點u,則返回該頂點在圖中位置;否則返回-1 int i;for(i=0;i<G.vexnum;++i)if(strcmp(u,G.vexs[i]) == 0) return i; // VertexType是char [16]類型return -1; }VertexType* GetVex(MGraph G,int v) { // 初始條件:圖G存在,v是G中某個頂點的序號。操作結果:返回v的值if( v>=G.vexnum || v<0 )exit(0);return &(G.vexs[v]); }void visit(VertexType i) {printf("%s ",i); }int FirstAdjVex(MGraph G,VertexType v) {// 初始條件:圖G存在,v是G中某個頂點 // 操作結果:返回v的第一個鄰接頂點的序號。若頂點在G中沒有鄰接頂點,則返回-1 int i,j=0,k;k=LocateVex(G,v); // k為頂點v在圖G中的序號 if(G.kind%2) // 網 j=INFINITY;for(i=0;i<G.vexnum;i++)if(G.arcs[k][i].adj!=j)return i;return -1; }int NextAdjVex(MGraph G,VertexType v,VertexType w) {// 初始條件:圖G存在,v是G中某個頂點,w是v的鄰接頂點 // 操作結果:返回v的(相對于w的)下一個鄰接頂點的序號,若w是v的最后一個鄰接頂點,則返回-1 int i,j=0,k1,k2;k1=LocateVex(G,v); // k1為頂點v在圖G中的序號 k2=LocateVex(G,w); // k2為頂點w在圖G中的序號 if(G.kind%2) // 網 j=INFINITY;for(i=k2+1;i<G.vexnum;i++)if(G.arcs[k1][i].adj!=j)return i;return -1; }void CreateGraphF(MGraph &G) {// 采用數組(鄰接矩陣)表示法,由文件構造無向網Gint i,j,k,w;char filename[13];VertexType va,vb;FILE *graphlist;//printf("請輸入圖的類型(有向圖:0,有向網:1,無向圖:2,無向網:3): ");scanf("%d",&G.kind);//printf("請輸入數據文件名:");scanf("%s",filename); graphlist=fopen(filename,"r"); // 以graphlist指針 打開數據文件fscanf(graphlist,"%d",&G.vexnum);fscanf(graphlist,"%d",&G.arcnum);for(i=0;i<G.vexnum;++i) // 構造頂點向量fscanf(graphlist,"%s",G.vexs[i]);for(i=0;i<G.vexnum;++i) // 初始化鄰接矩陣for(j=0;j<G.vexnum;++j){if(G.kind%2) // 網G.arcs[i][j].adj=INFINITY; else // 圖G.arcs[i][j].adj=0; }for(k=0;k<G.arcnum;++k){if(G.kind%2) // 網fscanf(graphlist,"%s%s%d",va,vb,&w);else // 圖fscanf(graphlist,"%s%s",va,vb);i=LocateVex(G,va);j=LocateVex(G,vb);if(G.kind == 0) // 有向圖G.arcs[i][j].adj =1;else if(G.kind == 1)G.arcs[i][j].adj=w; // 有向網else if(G.kind == 2) // 無向圖G.arcs[i][j].adj = G.arcs[j][i].adj=1;elseG.arcs[i][j].adj = G.arcs[j][i].adj = w;}fclose(graphlist); // 關閉數據文件 }void DestroyGraph(MGraph &G) { // 初始條件:圖G存在。操作結果:銷毀圖G int i,j,k=0;if(G.kind%2) // 網 k=INFINITY; // k為兩頂點之間無邊或弧時鄰接矩陣元素的值 G.vexnum=0; // 頂點數為0 G.arcnum=0; // 邊數為0 }void Display(MGraph G) { // 輸出鄰接矩陣存儲表示的圖G int i,j;switch(G.kind){case DG: printf("有向圖\n"); break;case DN: printf("有向網\n"); break;case UDG:printf("無向圖\n"); break;case UDN:printf("無向網\n");}printf("%d個頂點%d條邊。頂點依次是: ",G.vexnum,G.arcnum);for(i=0;i<G.vexnum;++i) // 輸出G.vexs printf("%s ",G.vexs[i]);printf("\n圖的鄰接矩陣:\n"); // 輸出G.arcs.adj for(i=0;i<G.vexnum;i++){for(j=0;j<G.vexnum;j++)if(G.kind%2) {if(G.arcs[i][j].adj==INFINITY)printf("%s\t","∞");elseprintf("%d\t",G.arcs[i][j].adj);}elseprintf("%d\t",G.arcs[i][j].adj);printf("\n");} }

ALGraph.h

#ifndef __ALGraph_H__ #define __ALGraph_H__typedef char VertexType[20]; // 頂點類型為字符串 #define MAX_VERTEX_NUM 20 typedef enum{DG,DN,UDG,UDN}GraphKind; // {有向圖,有向網,無向圖,無向網} typedef struct {int adjvex; // 該弧所指向的頂點的位置 int info; // 網的權值指針 }ElemType;typedef struct ArcNode {ElemType data; // 除指針以外的部分都屬于ElemType struct ArcNode *nextarc; // 指向下一條弧的指針 }ArcNode; // 表結點 typedef struct {VertexType data; // 頂點信息 ArcNode *firstarc; // 第一個表結點的地址,指向第一條依附該頂點的弧的指針 }VNode,AdjList[MAX_VERTEX_NUM]; // 頭結點 typedef struct {AdjList vertices;int vexnum,arcnum; // 圖的當前頂點數和弧數 GraphKind kind; // 圖的種類標志 }ALGraph;#define LNode ArcNode // 定義單鏈表的結點類型是圖的表結點的類型 #define next nextarc // 定義單鏈表結點的指針域是表結點指向下一條弧的指針域 typedef ArcNode *LinkList; // 定義指向單鏈表結點的指針是指向圖的表結點的指針 int equal(ElemType a,ElemType b); void visit(VertexType i); int LocateVex(ALGraph G,VertexType u);//若G中存在頂點u,則返回該頂點在圖中位置;否則返回-1 int FirstAdjVex(ALGraph G,VertexType v); // 返回v的第一個鄰接頂點的序號;否則返回-1 int NextAdjVex(ALGraph G,VertexType v,VertexType w);//v是圖G中某個頂點,w是v的鄰接頂點,返回v的(相對于w的)下一個鄰接頂點的序號 void CreateGraphF(ALGraph &G);// 采用鄰接表存儲結構,由文件構造沒有相關信息圖或網G void Display(ALGraph G); // 輸出圖的鄰接表G #endif

ALGraph.cpp

#include<stdio.h> #include<string.h> #include"ALGraph.h" #include"LinkList.h" int LocateVex(ALGraph G,VertexType u) { // 初始條件:圖G存在,u和G中頂點有相同特征 // 操作結果:若G中存在頂點u,則返回該頂點在圖中位置;否則返回-1 int i;for(i=0;i<G.vexnum;++i)if(strcmp(u,G.vertices[i].data)==0)return i;return -1; }int FirstAdjVex(ALGraph G,VertexType v) { // 初始條件:圖G存在,v是G中某個頂點 // 操作結果:返回v的第一個鄰接頂點的序號。若頂點在G中沒有鄰接頂點,則返回-1 LinkList p;int v1;v1=LocateVex(G,v); // v1為頂點v在圖G中的序號 p=G.vertices[v1].firstarc;if(p)return p->data.adjvex;elsereturn -1; }int NextAdjVex(ALGraph G,VertexType v,VertexType w) { // 初始條件:圖G存在,v是G中某個頂點,w是v的鄰接頂點 // 操作結果:返回v的(相對于w的)下一個鄰接頂點的序號。若w是v的最后一個鄰接點,則返回-1 LinkList p,p1; // p1在Point()中用作輔助指針ElemType e;int v1;v1=LocateVex(G,v); // v1為頂點v在圖G中的序號 e.adjvex=LocateVex(G,w); // e.adjvex為頂點w在圖G中的序號 p=Point(G.vertices[v1].firstarc,e,equal,p1); // p指向頂點v的鏈表中鄰接頂點為w的結點 if(!p||!p->next) // 沒找到w或w是最后一個鄰接點 return -1;else // p->data.adjvex==w return p->next->data.adjvex; // 返回v的(相對于w的)下一個鄰接頂點的序號 }void CreateGraphF(ALGraph &G) { // 采用鄰接表 存儲結構,由文件構造沒有相關信息圖或網G(用一個函數構造4種圖) int i,j,k,w; // w是權值 VertexType va,vb; // 連接邊或弧的2頂點 ElemType e;char filename[13];FILE *graphlist;//printf("請輸入圖的類型(有向圖:0,有向網:1,無向圖:2,無向網:3): ");scanf("%d",&G.kind);//printf("請輸入數據文件名:");scanf("%s",filename); graphlist=fopen(filename,"r"); // 以讀的方式打開數據文件,并以graphlist表示 fscanf(graphlist,"%d",&G.vexnum);fscanf(graphlist,"%d",&G.arcnum);for(i=0;i<G.vexnum;++i) // 構造頂點向量 {fscanf(graphlist,"%s",G.vertices[i].data);G.vertices[i].firstarc=NULL; // 初始化與該頂點有關的出弧鏈表 }for(k=0;k<G.arcnum;++k) // 構造相關弧鏈表 {if(G.kind%2) // 網 fscanf(graphlist,"%s%s%d",va,vb,&w);else // 圖 fscanf(graphlist,"%s%s",va,vb);i=LocateVex(G,va); // 弧尾 j=LocateVex(G,vb); // 弧頭 e.info=0; // 給待插表結點e賦值,圖無權 e.adjvex=j; // 弧頭 if(G.kind%2) // 網 {e.info = w;}ListInsert(G.vertices[i].firstarc,1,e); // 插在第i個元素(出弧)的表頭if(G.kind>=2) // 無向圖或網,產生第2個表結點,并插在第j個元素(入弧)的表頭 {e.adjvex=i; // e.info不變,不必再賦值 ListInsert(G.vertices[j].firstarc,1,e); // 插在第j個元素的表頭}}fclose(graphlist); // 關閉數據文件 } void Display(ALGraph G) { // 輸出圖的鄰接表G int i;LinkList p;switch(G.kind){case DG: printf("有向圖\n"); break;case DN: printf("有向網\n"); break;case UDG:printf("無向圖\n"); break;case UDN:printf("無向網\n");}printf("%d個頂點:\n",G.vexnum);for(i=0;i<G.vexnum;++i)printf("%s ",G.vertices[i].data);printf("\n%d條弧(邊):\n",G.arcnum);for(i=0;i<G.vexnum;i++){p=G.vertices[i].firstarc;while(p){printf("%s→%s ",G.vertices[i].data,G.vertices[p->data.adjvex].data);if(G.kind%2) // 網 printf(":%d\t",p->data.info ); p=p->nextarc;}printf("\n");} } int equal(ElemType a,ElemType b) { if(a.adjvex==b.adjvex)return 1;elsereturn 0; }void visit(VertexType i) {printf("%s ",i); }

LinkList.h

#ifndef __LinkList_H__ #define __LinkList_H__ // 函數結果狀態代碼#define TRUE 1#define FALSE 0#define OK 1#define ERROR 0#include"ALGraph.h" typedef LNode * LinkList; // 另一種定義LinkList的方法// 不帶頭結點的單鏈表的部分基本操作(9個)#define DestroyList ClearList // DestroyList()和ClearList()的操作是一樣的void InitList(LinkList &L); void ClearList(LinkList &L);int ListEmpty(LinkList L);int ListLength(LinkList L);int GetElem(LinkList L,int i,ElemType &e);int LocateElem(LinkList L,ElemType e,int(*compare)(ElemType,ElemType));int ListInsert(LinkList &L,int i,ElemType e);int ListDelete(LinkList &L,int i,ElemType &e);void ListTraverse(LinkList L,void(*vi)(ElemType));LinkList Point(LinkList L,ElemType e,int(*equal)(ElemType,ElemType),LinkList &p);//查找表L中滿足條件的結點。如找到#endif

LinkList.cpp

#include<stdio.h> #include<stdlib.h> #include"LinkList.h" // 不帶頭結點的單鏈表的部分基本操作(9個) void InitList(LinkList &L) { // 操作結果:構造一個空的線性表LL=NULL; // 指針為空 }#define DestroyList ClearList // DestroyList()和ClearList()的操作是一樣的 void ClearList(LinkList &L) { // 初始條件:線性表L已存在。操作結果:將L重置為空表LinkList p;while(L) // L不空{p=L; // p指向首元結點L=L->next; // L指向第2個結點(新首元結點)free(p); // 釋放首元結點} }int ListEmpty(LinkList L) { // 初始條件:單鏈表L已存在。操作結果:若L為空表,則返回TRUE,否則返回FALSEif(L)return FALSE;elsereturn TRUE; }int ListLength(LinkList L) { // 初始條件:線性表L已存在。操作結果:返回L中數據元素個數int i=0;LinkList p=L;while(p) // p指向結點(沒到表尾){p=p->next; // p指向下一個結點i++;}return i; }int GetElem(LinkList L,int i,ElemType &e) { // L為不帶頭結點的單鏈表的頭指針。當第i個元素存在時,其值賦給e并返回OK,否則返回ERRORint j=1;LinkList p=L;if(i<1) // i值不合法return ERROR;while(j<i&&p) // 沒到第i個元素,也沒到表尾{j++;p=p->next;}if(j==i) // 存在第i個元素{e=p->data;return OK;}elsereturn ERROR; }int LocateElem(LinkList L,ElemType e,int(*compare)(ElemType,ElemType)) { // 初始條件:線性表L已存在,compare()是數據元素判定函數(滿足為1,否則為0)// 操作結果:返回L中第1個與e滿足關系compare()的數據元素的位序。// 若這樣的數據元素不存在,則返回值為0int i=0;LinkList p=L;while(p){i++;if(compare(p->data,e)) // 找到這樣的數據元素return i;p=p->next;}return 0; }int ListInsert(LinkList &L,int i,ElemType e) { // 在不帶頭結點的單鏈線性表L中第i個位置之前插入元素eint j=1;LinkList p=L,s;if(i<1) // i值不合法return ERROR;s=(LinkList)malloc(sizeof(LNode)); // 生成新結點s->data=e; // 給s的data域賦值if(i==1) // 插在表頭{s->next=L;L=s; // 改變L}else{ // 插在表的其余處while(p&&j<i-1) // 尋找第i-1個結點{p=p->next;j++;}if(!p) // i大于表長+1return ERROR;s->next=p->next;p->next=s;}return OK; }int ListDelete(LinkList &L,int i,ElemType &e){ // 在不帶頭結點的單鏈線性表L中,刪除第i個元素,并由e返回其值int j=1;LinkList p=L,q;if(i==1) // 刪除第1個結點{L=p->next; // L由第2個結點開始e=p->data;free(p); // 刪除并釋放第1個結點}else{while(p->next&&j<i-1) // 尋找第i個結點,并令p指向其前趨{p=p->next;j++;}if(!p->next||j>i-1) // 刪除位置不合理return ERROR;q=p->next; // 刪除并釋放結點p->next=q->next;e=q->data;free(q);}return OK; }void ListTraverse(LinkList L,void(*vi)(ElemType)){ // 初始條件:線性表L已存在。操作結果:依次對L的每個數據元素調用函數vi()LinkList p=L;while(p){vi(p->data);p=p->next;}printf("\n");} LinkList Point(LinkList L,ElemType e,int(*equal)(ElemType,ElemType),LinkList &p) { //查找表L中滿足條件的結點。如找到,返回指向該結點的指針,p指向該結點的前驅(若該結點是首元結點,則p=NULL)。//如表L中無滿足條件的結點,則返回NULL,p無定義。函數equal()的兩形參的關鍵字相等,返回OK;否則返回ERRORint i,j;i=LocateElem(L,e,equal);if(i) // 找到 {if(i==1) // 是首元結點 {p=NULL;return L;}p=L;for(j=2;j<i;j++)p=p->next;return p->next;}return NULL; // 沒找到 }

總結

以上是生活随笔為你收集整理的图的单源最短路径算法的全部內容,希望文章能夠幫你解決所遇到的問題。

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

亚洲精品乱码久久 | 久久精品老司机 | 麻豆一精品传二传媒短视频 | 午夜体验区 | 免费欧美高清视频 | 日韩欧美国产免费播放 | 国产精品久久久久久妇 | 99r精品视频在线观看 | 中文字幕在线观看完整 | 欧美性黄网官网 | 欧美网址在线观看 | 一本一本久久a久久精品牛牛影视 | 国产亚洲精品久 | 人人射| 欧美国产在线看 | 免费在线观看视频一区 | av超碰在线观看 | 婷婷日| 日本婷婷色 | 91丨九色丨国产女 | 国产精品麻豆99久久久久久 | 日日日天天天 | 国产手机精品视频 | 天天干夜夜操视频 | 天天综合久久综合 | 亚a在线 | 日本超碰在线 | 最新av电影网址 | 九色琪琪久久综合网天天 | 日韩性网站| 国产资源网 | 日本久久片 | 亚洲在线日韩 | 尤物九九久久国产精品的分类 | 男女日麻批| 999亚洲国产996395 | 久久精品免视看 | 天天综合婷婷 | 黄色国产区| 久久99视频精品 | 亚洲精品视频免费在线观看 | av网站在线免费观看 | 99久久99久久精品国产片 | 精品久久久久久久久久国产 | 99热精品国产 | 国产亚洲va综合人人澡精品 | 色综合天天在线 | 久久久久国产精品免费 | 毛片1000部免费看 | www.色午夜.com | 黄色免费电影网站 | 亚洲一区二区三区四区在线视频 | 96久久| 久久久久久久福利 | 国产视频一区二区在线 | 美女在线观看av | 深夜国产福利 | 午夜性福利 | 亚洲视频在线视频 | 婷婷久久网站 | 在线观看国产一区二区 | 91在线视频播放 | 高清av免费看 | 国产一区二区三区在线 | 日韩欧美在线综合网 | 天天操综合 | 日韩精品一区二区三区第95 | 亚洲在线视频免费观看 | av天天澡天天爽天天av | 婷婷伊人五月 | 国产精品久久久久9999吃药 | 天天操夜夜操 | 久久精品1区2区 | 999超碰| 国产成人一级 | 黄色小说免费观看 | 正在播放五月婷婷狠狠干 | 爱情影院aqdy鲁丝片二区 | 黄色av一区二区三区 | 国产小视频国产精品 | 99久在线精品99re8热视频 | 免费一级日韩欧美性大片 | 亚洲午夜精 | 超碰免费公开 | 国产精品久久久久一区二区国产 | 日韩视频在线观看视频 | 中文字幕在线观看不卡 | 国产视频黄 | 人人爽人人爽人人片av免 | 色爱成人网 | 999ZYZ玖玖资源站永久 | 91精品爽啪蜜夜国产在线播放 | 亚洲一二区精品 | 中文字幕视频播放 | 在线91av | 一区二区三区日韩在线 | 国产精品久久久久久久久久久久久 | 日韩免费高清在线观看 | 久草在线视频看看 | 久久精品资源 | 亚洲精品91天天久久人人 | 日韩精品免费一区二区三区 | 国产精品久久久久久久久久妇女 | 久久尤物电影视频在线观看 | 国产资源精品在线观看 | 日韩videos | 日本黄色免费电影网站 | 免费亚洲精品视频 | 久久精品99久久久久久 | 亚洲国产剧情 | 亚洲午夜久久久久久久久电影网 | 天天做日日爱夜夜爽 | 日韩av手机在线观看 | 欧美激情视频三区 | 国产亚洲成av片在线观看 | 男女日麻批| 久久久久女教师免费一区 | 成人黄色大片 | 日韩高清一二区 | 国产成人精品一区二区三区网站观看 | av中文资源在线 | 成年人视频在线免费播放 | 日本黄色大片儿 | 五月天久久精品 | 一级免费观看 | 91免费高清 | 久久99热这里只有精品 | 91女人18片女毛片60分钟 | 久久国产精品99久久久久久丝袜 | 亚洲一级久久 | 国产亚洲精品xxoo | 在线免费中文字幕 | 四虎在线永久免费观看 | 日日日天天天 | 五月婷婷视频在线 | 99re亚洲国产精品 | 日韩在线观看一区 | 成人免费电影 | 久久精品影片 | 91精品国产99久久久久 | 韩国一区二区在线观看 | 2000xxx影视 | 色婷婷av在线 | 综合视频在线 | 中文字幕第一页在线 | 激情视频国产 | 亚洲一区欧美激情 | 国产精品免费观看久久 | 超碰999| 婷婷六月中文字幕 | 欧美永久视频 | 国产精品乱码久久久久久1区2区 | 久久男人视频 | 欧美另类高潮 | 国产精品久久嫩一区二区免费 | 日韩精品一区二区免费视频 | 成人在线观看网址 | 九九视频精品免费 | 狠狠干.com| 精品自拍网 | 天天做综合网 | 99视屏 | 国产视频不卡一区 | 在线高清一区 | 久久99偷拍视频 | 在线色资源 | 国内丰满少妇猛烈精品播放 | 亚洲精品国产精品久久99热 | 国产一区二区在线精品 | 黄色一级网| 激情中文在线 | 久久久久成人免费 | 国产精品久久99综合免费观看尤物 | 欧美十八 | av在线在线 | 亚洲精品久久在线 | 欧洲黄色片 | 国产精品一二三 | 日韩精品免费一线在线观看 | 国产日产精品一区二区三区四区 | 成人小视频在线观看免费 | 日韩av网站在线播放 | 中文av资源站 | 99热这里是精品 | 久久视频在线视频 | 激情五月开心 | 亚洲天堂精品视频在线观看 | 九九九热精品免费视频观看 | 免费看一级黄色大全 | 欧美 亚洲 另类 激情 另类 | 亚洲精品网站在线 | 国产一级片播放 | 天天插日日射 | 在线观看国产成人av片 | 国产高清专区 | 四虎最新域名 | 欧洲成人av | 久久精品亚洲一区二区三区观看模式 | 在线中文字幕观看 | av解说在线| 国产精品久久久久久久久久新婚 | 久久免费黄色大片 | 免费看的视频 | 69中文字幕 | 乱男乱女www7788 | 日韩欧美精品在线观看视频 | 色婷婷激情 | 国产视频亚洲精品 | 波多野结衣在线视频一区 | 亚洲三级在线免费观看 | 99电影456麻豆 | 亚洲国产日韩精品 | 91免费高清在线观看 | 欧美日在线 | 91av在线精品 | 国产91精品久久久久久 | 99精品亚洲 | 9999亚洲| 久久久久久看片 | 国产精品久久久视频 | 91精选 | 最近免费中文视频 | 69国产盗摄一区二区三区五区 | 国产精品欧美精品 | 欧美日韩一区二区免费在线观看 | 黄色小说在线免费观看 | 四虎影视国产精品免费久久 | 国产裸体永久免费视频网站 | 国产一级特黄毛片在线毛片 | 欧美吞精| 久久九九精品久久 | 国产精品地址 | 久久一区二区三区国产精品 | 开心丁香婷婷深爱五月 | 人人爽人人爽人人 | 精品国产黄色片 | 特级西西444www大胆高清无视频 | 99久久影院 | 中文字幕黄色网址 | 久久高清片 | 国产在线91在线电影 | av在线免费在线观看 | 欧美日韩aa | 国产精品免费一区二区 | 国产 一区二区三区 在线 | 欧美日韩精品在线播放 | 日韩精品国产一区 | 91麻豆视频网站 | 日日干综合 | 免费观看成人av | 国产成人三级在线观看 | 欧美一区二区伦理片 | 成人国产一区二区 | 国内小视频 | 麻豆av电影 | 日韩性片 | 亚洲做受高潮欧美裸体 | 在线观看成人av | 91看片淫黄大片在线播放 | 久久只精品99品免费久23小说 | 色视频成人在线观看免 | 国产精品毛片一区视频播不卡 | 亚洲成人av电影 | 国产一级二级av | a级一a一级在线观看 | aaa亚洲精品一二三区 | 国产视频欧美视频 | 91成年人视频 | 国内99视频 | adn—256中文在线观看 | 97av在线视频免费播放 | 国产成人综合精品 | 天天操狠狠操夜夜操 | 久影院 | 91私密保健 | 国产中文字幕第一页 | 欧美aa级 | 91av在线免费视频 | 97免费在线观看视频 | 91精品999| 天天干天天操天天做 | 五月色综合 | 色就色,综合激情 | 一区二区三区日韩视频在线观看 | 日批视频在线观看免费 | 中文字幕亚洲精品在线观看 | 日韩精品你懂的 | 91丨九色丨蝌蚪丨对白 | 亚洲精品一区二区久 | 免费福利片2019潦草影视午夜 | 国产精品久久久久久久午夜片 | 色网站在线观看 | 久操97| 成人一级视频在线观看 | av在线a | 成人av在线一区二区 | 亚洲天堂精品视频在线观看 | 久久狠狠亚洲综合 | 91亚洲精品久久久中文字幕 | av不卡中文 | 日韩电影一区二区在线 | 成人资源在线 | 国产精品第二页 | 2019精品手机国产品在线 | 天天天干 | 婷色在线| 97电院网手机版 | 日本高清久久久 | 欧美日韩中文在线视频 | 麻豆视频国产 | 国产精品午夜久久久久久99热 | 最近免费中文字幕mv在线视频3 | 国产黄大片 | 久久免费毛片 | 国产一级免费观看 | 国产亚洲精品久久久久久网站 | 久久超级碰视频 | 久久欧洲视频 | 国产91在线免费视频 | 九九九热精品免费视频观看 | 激情伊人 | 欧美成人播放 | 国产一区二区三区视频在线 | 日日干天天操 | 免费黄色在线网址 | 最近更新的中文字幕 | 四虎影视精品成人 | 五月综合网 | 欧美国产日韩一区二区三区 | 免费h视频 | 91麻豆国产福利在线观看 | 久久国产麻豆 | 国产精品福利在线 | 青青河边草免费观看完整版高清 | 日日操日日操 | 草久久影院 | 国产精品黑丝在线观看 | 日韩最新av在线 | 97精品国产97久久久久久久久久久久 | 国产精品免费久久久久 | 国产麻豆果冻传媒在线观看 | 91麻豆精品91久久久久同性 | www色片| 国产一区在线视频播放 | 久久这里有 | 天天草综合 | 国产在线免费观看 | 婷久久 | 久久午夜电影院 | 在线欧美最极品的av | 欧美日产在线观看 | 在线 国产 亚洲 欧美 | 欧美孕妇与黑人孕交 | 日本三级久久 | 久久久久久久久久久影视 | 国产精品久久久久久一区二区 | 欧美日韩高清在线 | 97涩涩视频 | 国产喷水在线 | 91av在线视频免费观看 | 色五月成人 | 亚洲精品国产精品国产 | 亚洲一区黄色 | 99在线高清视频在线播放 | 福利一区在线视频 | 欧美日韩亚洲在线观看 | 亚洲国产成人在线观看 | 337p欧美| 国产精品一区二区在线观看免费 | 懂色av一区二区三区蜜臀 | 色婷婷国产在线 | 人人超碰免费 | 激情影院在线观看 | 激情婷婷 | 黄色大片免费网站 | av亚洲产国偷v产偷v自拍小说 | 免费成人av | 玖玖在线看 | 久视频在线 | 国产成人精品一区二区三区在线观看 | 韩国av一区 | 亚州中文av | 欧美一区二区三区免费观看 | 国产视频一区精品 | 操高跟美女 | 欧美精品久 | 久久久久久久毛片 | 亚洲人人网| 国内免费久久久久久久久久久 | 免费欧美高清视频 | 亚洲人成在线电影 | 久久精品首页 | 狠狠干,狠狠操 | 中文字幕 国产 一区 | 欧美亚洲三级 | 91在线操 | 国产一区在线不卡 | 久久久国产日韩 | 日韩欧美视频在线 | 色婷婷激情 | 狠狠干2018 | 成人a在线观看高清电影 | 精品在线一区二区 | 国产精品久久久久久久免费大片 | 欧美老女人xx| 中文字幕电影高清在线观看 | 日本爽妇网| 成年性视频 | 国产一级h| 中文字幕乱在线伦视频中文字幕乱码在线 | 天天干天天操天天拍 | 99久热在线精品视频成人一区 | 天天综合视频在线观看 | 四虎永久免费网站 | 久久久久国产成人免费精品免费 | 日韩欧美区 | 成年人av在线播放 | 在线观看亚洲a | 国产又粗又猛又黄视频 | 成人一区二区在线 | 免费a级大片 | 中文字幕免费观看 | 丁香久久婷婷 | 中国黄色一级大片 | 欧美少妇xxxxxx | 国产视频一区二区在线观看 | 精品国产视频在线观看 | 黄色中文字幕 | 亚洲老妇xxxxxx | 日韩av不卡在线观看 | 波多野结衣小视频 | 国内成人精品视频 | 亚洲一区二区三区精品在线观看 | 麻豆传媒在线免费看 | 成人av网站在线 | 亚洲激情小视频 | 999成人免费视频 | 日韩欧美视频在线 | 中文字幕免费国产精品 | 国产不卡精品视频 | 亚洲国产手机在线 | 88av网站| 国产剧情在线一区 | 久久在线一区 | 国产精品 久久 | 久久综合狠狠综合久久狠狠色综合 | 免费高清影视 | 三级av网 | 中文字幕网站视频在线 | 激情久久综合 | 在线观看爱爱视频 | 中文字幕第一页在线 | 国产99久久久欧美黑人 | 欧美福利片在线观看 | 亚洲不卡123| 五月天,com | 亚洲v欧美v国产v在线观看 | 国产精品99久久免费观看 | 一区二区三区高清不卡 | 午夜色场 | 亚洲精品在线播放视频 | 国产亚洲欧美一区 | 久草干 | 超碰伊人网 | 日韩视频免费在线观看 | 精品在线小视频 | 顶级欧美色妇4khd | 国产亚洲字幕 | 99热在线免费观看 | 欧美人人 | 天天爽网站 | 久久精品人 | 国产亚洲精品久久久久久网站 | 色综合久久久久久久久五月 | 国产精品麻豆99久久久久久 | 超碰资源在线 | 久热av在线 | 人人射人人| 激情久久久 | 国产精品成人自拍 | 91大神精品视频在线观看 | 国产精品视频永久免费播放 | 日韩动漫免费观看高清完整版在线观看 | 午夜久久影视 | 丁香色天天 | 久草手机视频 | 国产探花视频在线播放 | 五月天亚洲精品 | 日韩在线观看视频一区二区三区 | 亚洲国产精品视频 | 在线影院中文字幕 | 波多野结衣理论片 | 亚洲精品久久久久999中文字幕 | 美女视频a美女大全免费下载蜜臀 | av在线免费观看不卡 | 亚洲伊人网在线观看 | www.亚洲视频 | 国产成人精品不卡 | 午夜av一区二区三区 | 九九久久久久久久久激情 | 亚洲精品国产精品国 | 狠狠艹夜夜干 | 97在线免费观看 | 国产99久久久国产 | 免费在线观看av的网站 | 精品久久美女 | 久久不卡视频 | 免费日韩一区二区 | 成人av av在线 | 在线观看黄av | 岛国av在线 | 成人免费在线电影 | 亚洲综合色网站 | 国产成人精品午夜在线播放 | 911国产 | 国产精品av免费观看 | 免费视频资源 | 国产精品免费麻豆入口 | 亚洲精品自拍 | 亚洲五月花 | 91在线蜜桃臀 | 天天天天综合 | 中文字幕乱在线伦视频中文字幕乱码在线 | 国产黄色免费观看 | 成年人免费看片网站 | 六月丁香婷婷网 | 美女黄视频免费看 | 美腿丝袜av| 日本深夜福利视频 | av中文字幕日韩 | 日韩一级网站 | 成人网色| 99国产精品视频免费观看一公开 | 亚洲精品视频在线免费 | 久久久午夜影院 | 天堂网av在线 | 国产精品热视频 | 成年人国产视频 | 日韩精品视频网站 | a在线播放 | 国产成人综 | 人人干免费 | 国产麻豆精品免费视频 | 日日爱网址| 一区二区欧美激情 | 久久中文字幕导航 | 337p日本大胆噜噜噜噜 | 天天天天天天操 | 久久久久久高潮国产精品视 | 天天爱综合 | 欧美淫视频 | 天天射天天操天天干 | 人人玩人人添人人澡97 | 久久天天躁狠狠躁夜夜不卡公司 | 国产精品com | 黄色的网站在线 | 九九综合久久 | 国产精品成人久久 | 国产精品入口a级 | 国产一级片在线播放 | 免费视频你懂得 | 免费黄色看片 | 97在线视频观看 | 精品福利视频在线 | 久久久香蕉视频 | 91伊人久久大香线蕉蜜芽人口 | 精品美女在线视频 | 国产精品视频线看 | 激情综合中文娱乐网 | 免费国产一区二区视频 | 日日干av | 免费在线中文字幕 | 亚洲精品在线免费观看视频 | 免费在线观看污 | 国产精品一区二区三区免费视频 | 亚洲一区精品人人爽人人躁 | 中文字幕 国产精品 | 日韩字幕在线观看 | 91成人久久| 精品中文字幕在线观看 | 99精品欧美一区二区 | 久久久久久美女 | av在线8| 中文字幕一区二区在线播放 | 国产精品久久久区三区天天噜 | 日韩精品免费一线在线观看 | www.av免费观看| 久久国产电影院 | 黄色天堂在线观看 | 久久免费视频5 | 在线观看视频黄色 | 99久久精品国产一区二区三区 | 日韩精品首页 | 国外调教视频网站 | 91九色国产蝌蚪 | 精品视频123区在线观看 | 日韩有码在线播放 | 91亚色在线观看 | 色97在线 | 玖玖在线看 | 中文字幕高清免费日韩视频在线 | 国产免费三级在线观看 | 天天操夜夜操天天射 | 免费av观看网站 | 日韩精品一区二区三区免费观看视频 | 波多野结衣视频网址 | 黄色软件在线观看免费 | 不卡电影免费在线播放一区 | 久久久久中文 | av中文字幕在线电影 | av+在线播放在线播放 | 在线观看国产中文字幕 | 精品久久久久久久久久久久久 | 九九热免费在线视频 | 精品av网站| av黄色大片| 日日麻批40分钟视频免费观看 | 91在线观看高清 | 91av九色| 91在线成人| 日韩成人在线一区二区 | 黄色一级片视频 | 亚洲视频www | 中文亚洲欧美日韩 | 激情婷婷丁香 | 中文字幕在线观看的网站 | 日韩欧美在线一区二区 | 亚洲综合精品视频 | 黄色网在线播放 | 免费久久网站 | 日韩视频在线观看视频 | 天天爽天天爽天天爽 | 中文字幕黄色网址 | 久久久精品网站 | 色国产视频 | 伊人色播 | 成人免费观看av | 国产在线国偷精品产拍免费yy | 国产精品成人免费一区久久羞羞 | 激情五月六月婷婷 | 最新日韩在线 | 精品国产一区二区三区日日嗨 | 日本护士撒尿xxxx18 | 免费观看午夜视频 | 99免费在线播放99久久免费 | 久久 亚洲视频 | 精品久久美女 | 成人av影视 | 视频一区在线播放 | 91插插插免费视频 | 午夜精品三区 | 四虎成人精品永久免费av | 国产精品18久久久久久久久 | 亚洲精品视频 | 免费看片网址 | 久久九九网站 | 国产精品一码二码三码在线 | 青春草视频在线播放 | 久久综合9988久久爱 | 色夜影院 | 操操操夜夜操 | 韩国av免费在线 | 九九久久国产 | 在线观看视频在线观看 | 激情开心色 | 国产精品毛片一区视频播不卡 | 天天干天天射天天插 | 欧美做受69 | 伊人春色电影网 | 亚洲天堂网视频在线观看 | 最近中文字幕免费观看 | 免费又黄又爽 | 久久草草影视免费网 | 久久怡红院 | 国产精品视频最多的网站 | www.97视频 | 久草视频免费 | 日韩久久片 | 中文字幕av网站 | 中文区中文字幕免费看 | 国产精品久久久久久一区二区 | 九草视频在线 | 日韩欧美在线综合网 | 久久国产高清 | 亚洲五月婷婷 | 免费午夜网站 | 精品久久久久久亚洲综合网站 | 久久毛片视频 | ,午夜性刺激免费看视频 | 91最新视频| 亚洲一区日韩精品 | 欧美大片大全 | 免费高清在线视频一区· | 最新国产精品视频 | 在线观看日韩av | 久久高清av | 亚洲欧美日韩在线一区二区 | 欧美日韩不卡在线观看 | 91在线视频精品 | 国产日韩欧美自拍 | 国产精品自产拍在线观看 | 精品毛片久久久久久 | 99中文在线 | 青青草国产成人99久久 | av理论电影 | 国产精品亚洲人在线观看 | 久久国产精品免费看 | 有码中文字幕 | 91传媒在线播放 | 久久久久久久久久久网站 | 天天干天天操av | 美女视频免费一区二区 | 国产精品一区免费在线观看 | 午夜精品久久久久久久久久久久 | 人人草网站 | 成人中心免费视频 | 激情五月在线 | 91欧美精品 | 国产一区二区免费 | 97人人添人澡人人爽超碰动图 | 丁香六月天 | 在线成人高清电影 | 91在线免费观看网站 | 91精品入口 | 国产成人免费高清 | 久久精品网站视频 | 天天操天天操天天操 | 欧美男同视频网站 | 激情久久综合 | 狠狠色综合网站久久久久久久 | 国产精品综合久久久 | 亚洲免费小视频 | 久久一本综合 | 久章操 | 精品久久久久久国产偷窥 | 国产国产人免费人成免费视频 | 免费看片网址 | 最近免费中文视频 | 99成人免费视频 | 国产精品 视频 | 成人一级视频在线观看 | 一区二区三区视频网站 | 成人中文字幕在线 | 日韩av不卡在线 | 夜色资源网 | 国产成人精品综合久久久久99 | 91看片成人 | 五月天com | 蜜臀av夜夜澡人人爽人人桃色 | 天天操比 | 日韩欧美国产精品 | 久久久网站 | 香蕉网在线播放 | 2019天天干夜夜操 | 性色av免费观看 | www.国产毛片| 国模一区二区三区四区 | 日韩成人精品一区二区三区 | aaa亚洲精品一二三区 | 日本黄色免费大片 | 亚洲色视频 | 久草在线免费播放 | 久久久夜色| 天天做天天射 | 国产午夜精品一区二区三区在线观看 | 日本黄色黄网站 | 精品久久久久一区二区国产 | 综合国产在线 | 精品国产精品久久 | 日韩久久久久久久久久 | 久久人人爽视频 | 欧美日韩国产精品一区二区三区 | 久久婷婷精品视频 | 俺要去色综合狠狠 | 日韩最新中文字幕 | 天堂av免费看 | 国产午夜一区二区 | 亚洲国产精品电影在线观看 | 久久在线 | 日韩一级网站 | 爱色婷婷 | 久久一久久 | 亚洲不卡在线 | 欧美精品久久久久久久亚洲调教 | 97视频资源| 97自拍超碰 | 精品亚洲va在线va天堂资源站 | 狠日日| 91日韩在线视频 | 国产精品白丝jk白祙 | 99精品欧美一区二区三区黑人哦 | 欧美日韩午夜在线 | 一级特黄aaa大片在线观看 | 婷婷精品视频 | 韩国av永久免费 | 欧美另类性 | 午夜视频在线瓜伦 | 午夜精品一区二区三区在线视频 | 国产做aⅴ在线视频播放 | 四虎免费在线观看视频 | 日韩精品一区电影 | 99久久精品免费看国产四区 | 亚洲精品456在线播放第一页 | 9999毛片 | 久久久久久片 | 在线网站黄 | 日韩欧美高清不卡 | 综合色亚洲 | 999久久久免费精品国产 | 亚洲狠狠丁香婷婷综合久久久 | 在线国产能看的 | 久久久久久久久久久久电影 | 国产精品午夜在线 | 在线观看亚洲成人 | 91网址在线 | 亚洲爱视频 | 91免费日韩 | 黄色成人影视 | 免费黄色av电影 | 91在线视频 | 婷婷激情五月 | 成人毛片在线观看视频 | 欧美日韩一区久久 | 国产一区在线看 | 国产精品久久久久高潮 | 久久精品久久精品久久39 | 又黄又爽又无遮挡免费的网站 | 亚洲日本精品视频 | 9999免费视频 | 免费无遮挡动漫网站 | 尤物一区二区三区 | 国产高清成人 | 四虎国产精品免费观看视频优播 | 久久久国产精品网站 | 久久免费视频这里只有精品 | av成年人电影 | 一级一片免费视频 | 丁香 婷婷 激情 | 久久免费视频这里只有精品 | 18pao国产成视频永久免费 | 五月开心激情 | 丁香资源影视免费观看 | 草久在线视频 | 中文字幕av播放 | 亚洲综合欧美日韩狠狠色 | 四虎www| 亚洲成人资源在线 | 亚洲 欧美日韩 国产 中文 | av888av.com | 2000xxx影视| 国产精品成人久久久久久久 | 午夜精品一区二区三区免费视频 | 黄色片亚洲 | 国产精品久久久久久久久久尿 | 97超碰中文字幕 | 国产精品久久久久久一二三四五 | a在线免费观看视频 | 国产一区二区在线精品 | 深夜福利视频在线观看 | 黄色小说视频网站 | 久久97视频 | 久草在线高清 | 99热99re6国产在线播放 | 久久久久久久久艹 | 亚洲日b视频 | 久久久久久久国产精品视频 | 97精品久久 | 911免费视频 | 91禁在线观看 | 日韩欧美综合在线视频 | 亚洲综合激情五月 | 久久av高清 | 久久精品国产免费 | 精品久久久久一区二区国产 | 美女视频黄色免费 | 国产中文字幕国产 | 国产精品com | 国产视频精品网 | www.五月婷 | 国产精品久久久久一区二区 | 五月综合网 | 国产精品v欧美精品v日韩 | 久久精美视频 | 国产日韩精品在线 | 国产亚洲人 | 久久精品久久精品久久 | 91av视频网站 | 国产精品99久久99久久久二8 | 日韩av免费大片 | 日韩视频a | 五月天丁香视频 | 在线观看精品视频 | 免费在线激情电影 | 日韩精品欧美专区 | 久久伊人操 | 国产h片在线观看 | 日日夜夜精品视频 | 97精品国产91久久久久久久 | 一区二区欧美在线观看 | 日日夜夜爱 | 国产精品久久久久久久毛片 | 最近中文字幕免费观看 | 色视频网站在线观看一=区 a视频免费在线观看 | 国产亚洲精品久久19p | 久久视频在线看 | 国产区在线看 | 亚洲电影一区二区 | 国产综合福利在线 | 99视频这里有精品 | 国产精品一区二区在线播放 | 国产精品一区二区在线播放 | 色网站中文字幕 | 久久久免费电影 | 成 人 黄 色 片 在线播放 | 国产日本高清 | av在线一二三区 | 在线观看 亚洲 | 国产午夜精品久久 | 91少妇精拍在线播放 | 精品主播网红福利资源观看 | 91福利在线导航 | 日韩三级不卡 | 在线精品国产 | 成人宗合网| 日韩视频一区二区三区 | 欧美日韩在线精品一区二区 | 一区二区视频免费在线观看 | 精品国产精品久久 | 亚洲无吗视频在线 | 韩日色视频 | 日韩性网站| 中文字幕av免费在线观看 | 久久亚洲电影 | 久久精品一区二区三区中文字幕 | 久久精品国产亚洲精品2020 | 看国产黄色大片 | 久久精品79国产精品 | 九九热1| 婷婷六月网 | 日韩av成人在线观看 | 黄色在线观看www | 中文字幕在线观看视频网站 | www.久久久久 | 亚洲高清久久久 | 狠色在线| 国产麻豆电影在线观看 | www.五月激情.com | 亚洲精品777 | 欧美日韩中文国产一区发布 | 六月激情丁香 | 永久免费毛片在线观看 | 久久精品国产免费看久久精品 | 精品一区电影国产 | 成人午夜av电影 | 精品国内| 国产视频 亚洲视频 | 免费视频97 | 日日夜夜天天久久 | 黄色小说免费在线观看 | 国语精品免费视频 | 国产免费高清 | 91高清视频 | 久草精品网 | 国产大尺度视频 | 久久婷婷国产色一区二区三区 | 六月丁香综合网 | 最近日本mv字幕免费观看 | 日韩三级av | 香蕉久久久久久av成人 | 91一区啪爱嗯打偷拍欧美 | 国产品久精国精产拍 | 天天插一插 | 中文字幕在线久一本久 | 91综合久久一区二区 | 天天躁天天狠天天透 | 天天操天操 | 亚洲成人av一区 | 国产一级视频免费看 | 午夜久草 | 欧美二区三区91 | 中文字幕乱码日本亚洲一区二区 | 四虎影视国产精品免费久久 | 亚洲国产片| 韩国三级av在线 | 久久99精品国产99久久6尤 | 激情av资源网 | 国产手机在线 | 菠萝菠萝在线精品视频 | 欧美亚洲专区 | 亚洲婷久久 | 一区二区不卡视频在线观看 | 亚洲理论电影网 | 免费黄色特级片 | 国产麻豆视频在线观看 | 久久99最新地址 | 免费福利视频网站 | 色播五月激情综合网 | 大型av综合网站 |