两顶点之前有路径吗? (20 分)


这道题有一个坑点在于自身是有路径的

int hasPath(struct Graph *g, int v, int w){
	for(int i=0;i<g->v;i++)g->Adj[i][i]=1;
	for (int i = 0; i < g->v; i++)
            {
                for (int j =0; j <g->v; j++)
                {
                	for(int l = 0;l<g->v;l++){
                		if (g->Adj[i][j] ==1&& g->Adj[l][j]==1)
                        g->Adj[i][l] =1;
					}
                    
                }
            }
    int sum=1;
    //ghy(g,0,v);
	for(int i=0;i<g->v;i++){
		if(g->Adj[v][i]==1){
			for(int j=0;j<g->v;j++){
				if(g->Adj[i][j]==1){
					g->Adj[v][j]=1;
				}
			}
		} 
	}
	for(int i=0;i<g->v;i++){
		if(g->Adj[v][i]==1&&v!=i){
			sum++;
		}
	} 
	printf("%d\n",sum);
	sum=1;
	for(int i=0;i<g->v;i++){
		if(g->Adj[w][i]==1){
			for(int j=0;j<g->v;j++){
				if(g->Adj[i][j]==1){
					g->Adj[w][j]=1;
				}
			}
		} 
	}
	for(int i=0;i<g->v;i++){
		if(g->Adj[w][i]==1&&w!=i)sum++;
	} 
	printf("%d\n",sum);
    if(g->Adj[v][w]==1)return 1;
    else return 0;
} 
全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务