两顶点之前有路径吗? (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;
} 
全部评论

相关推荐

不愿透露姓名的神秘牛友
今天 11:00
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 11:16
点赞 评论 收藏
分享
小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
06-25 09:33
厦门大学 Java
程序员饺子:现在日常估计没啥hc了,等到八月多估计就慢慢有了。双九✌🏻不用焦虑的
投递快手等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务