关键词不能为空

当前您在: 主页 > 英语 >

数据结构专题--图的路径

作者:高考题库网
来源:https://www.bjmy2z.cn/gaokao
2021-02-01 21:40
tags:

-

2021年2月1日发(作者:moisture是什么意思)


7.22


判断是否存在从


u

< br>到


v


的路径


< br>基本思想:从


u


出发深度或广度搜索,找到


v


就有,找不到就没有



int visited[MAXSIZE];


int exist_path_DFS(ALGraph G,int i,int j)


{



if(i==j) return 1;



else



{




visited[i]=1;




for(p=es[i].firstarc;p;p=p->nextarc)




{





k=p->adjvex;





if(!visited[k]&&exit_path_DFS(G,k,j)) return 1;




}



}


}



7.23


int exist_path_BFS(ALGraph G,int i,int j)


{ //


三件事情,定访问数组,初始化队列,起点进队




int visited[MAXSIZE];



InitQueue(Q);



EnQueue(Q,i);



while(!QueueEmpty(Q))



{




De Queue(Q,u);//


出队并访问





visited[u]=1;




for(p=es[u].firstarc;p;p=p->nextarc)




{





k=p->adjvex;





if(k==j) return 1;





if(!visited[k]) EnQueue(Q,k);




}



}


}



7.27


判断


u


v


是否存在长度


k


的简单路径



int visited[MAXSIZE];


int exist_path_len(ALGraph G,int i,int j,int k)


{



if(i==j&&k==0) return 1;



else if(k>0)



{




visited[i]=1;




for(p=es[i].firstarc;p;p=p->nextarc)




{





l=p->adjvex;





if(!visited[l])






if(exit_path_len(G,l,j,k-1)) return 1;




}




visited[i]=0;//


如 果该点的邻接点中没找到,将该点退出




}






//


以便在别的路径中访问




return 0;


}



7.28



u



v


所有简单路径



int path[MAXSIZE],visited[MAXSIZE];


int Find_All_Path(ALGraph G,int u,int v,int k)


{



path[k]=u;



visited[u]=1;



if(u==v)



{




printf(




for(i=0;path[i];i++) printf(



}



else




for(p=es.[u].firstarc;p;p=p->nextarc)




{





l=p->adjvex;





if(!visited[l]) Find_All_Path(G,l,v,k+1);




}



visited[i]=0;



path[k]=0;


}



7.29



i



j


的不含回路的,长度为


k


的路径条数



int GetPathNum_Len(ALGraph G,int i,int j,int len)


{



if(i==j&&len==0) return 1;



else if(len>0)



{




sum=0;//


表示通过本结点的路径数





visited[i]=1;




for(p=es[i].firstarc;p;p=p->nextarc)




{





l=p->adjvex;





if(!visited[l])






sum+=GetPathNum_Len(G,l,j,len-1);




}



visited[i]=0;



}



return sum;


}



7.30


求有向图中所有简单回路



int visited[MAXSIZE];


int path[MAXSIZE];


int cycles[MAXSIZE][MAXSIZE];


int thiscycle[MAXSIZE];


int cyount=0;//


以发现的回路个数



void GetAllCycle(ALGraph G)


{



for(v=0;v<;v++) visited[v]=0;



for(v=0;v<;v++)




if(!visited[i]) DFS(G,v,0);


}



void DFS(ALGraph G,int v,int k)


{



visited[v]=1;



path[k]=v;



for(p=es[v].firstarc;p;p=p->next)



{




w=p->adjvex;




if(!visited[w]) DFS(G,w,k+1);




else //


出现已经访问过的结点,发现回路





{





for(i=0;path[i] !=w;i++);//


找回路起点






for(j=0;path[i+j];i++) thiscycle[j]=path[i+j];





if(!exist_cycle()) cycles[cycount++]=thiscycle;





for(i=0;i<;i++) thiscycle[i]=0;




}



}



path[k]=0;



visit ed[k]=0;//


注意只有当前路经结点上的


visite d


为真。因此一旦发现当前结点


visited


为真







//


即发现了一条回路



}



int exsit_cycle()


{



int temp[MAXSIZE];



for(i=0;i




temp[m]=cycles[i][k+m];



for()



}



7.36

每个顶点增加一个


MPL


域存放由他出发的最长路径的长度



void Fill_MPL(ALGraph &G)


{



FindIndegree(G,indegree);



for(i=0;i<;i++)



{




if(!indegree[i]) Get_MPL(G,i);//


从零入度顶点出发构建


MPL





}


}



int Get_MPL(ALGraph &G,int i)


{



if(!es[i].firstarc)



{




es[i].MPL=0;




return 0;



}



else



{




max=0;




for(p=es[i].firstarc;p;p=p->nextarc)




{





j=p->adjvex;





if(es[j].MPL==0) k=Get_MPL(G,j);





if(k>max) max=k;




}




es[i]=max+1;




return max+1;



}


}


-


-


-


-


-


-


-


-



本文更新与2021-02-01 21:40,由作者提供,不代表本网站立场,转载请注明出处:https://www.bjmy2z.cn/gaokao/595279.html

数据结构专题--图的路径的相关文章

  • 余华爱情经典语录,余华爱情句子

    余华的经典语录——余华《第七天》40、我不怕死,一点都不怕,只怕再也不能看见你——余华《第七天》4可是我再也没遇到一个像福贵这样令我难忘的人了,对自己的经历如此清楚,

    语文
  • 心情低落的图片压抑,心情低落的图片发朋友圈

    心情压抑的图片(心太累没人理解的说说带图片)1、有时候很想找个人倾诉一下,却又不知从何说起,最终是什么也不说,只想快点睡过去,告诉自己,明天就好了。有时候,突然会觉得

    语文
  • 经典古训100句图片大全,古训名言警句

    古代经典励志名言100句译:好的药物味苦但对治病有利;忠言劝诫的话听起来不顺耳却对人的行为有利。3良言一句三冬暖,恶语伤人六月寒。喷泉的高度不会超过它的源头;一个人的事

    语文
  • 关于青春奋斗的名人名言鲁迅,关于青年奋斗的名言鲁迅

    鲁迅名言名句大全励志1、世上本没有路,走的人多了自然便成了路。下面是我整理的鲁迅先生的名言名句大全,希望对你有所帮助!当生存时,还是将遭践踏,将遭删刈,直至于死亡而

    语文
  • 三国群英单机版手游礼包码,三国群英手机单机版攻略

    三国群英传7五神兽洞有什么用那是多一个武将技能。青龙飞升召唤出东方的守护兽,神兽之一的青龙。玄武怒流召唤出北方的守护兽,神兽之一的玄武。白虎傲啸召唤出西方的守护兽,

    语文
  • 不收费的情感挽回专家电话,情感挽回免费咨询

    免费的情感挽回机构(揭秘情感挽回机构骗局)1、牛牛(化名)向上海市公安局金山分局报案,称自己为了挽回与女友的感情,被一家名为“实花教育咨询”的情感咨询机构诈骗4万余元。

    语文