码迷,mamicode.com
首页 > 其他好文 > 详细

输出图中顶点i到顶点j之间的所有简单路径

时间:2017-09-01 20:32:30      阅读:449      评论:0      收藏:0      [点我收藏+]

标签:之间   find   class   graph   回溯   highlight   简单   else   art   

简单路径(不包括环)

DFS遍历以及回溯得到结果

void dfs(ALGraph graph, int v, int end, bool visit[], int path[], int cnt)
{
    visit[v] = true;
    path[cnt++] = v;
    if(v == end)
    {
        for(int i = 0; i < cnt; i++)
        {
            cout<<path[i]<<" ";
        }
        cout<<endl;
        return;
    }

    for(ArcNode* edge = graph.adjList[v].first; edge != NULL; edge = edge->next)
    {
        if(!visit[edge->adjvex])
        {
            dfs(graph, edge->adjvex, end, visit, path, cnt);
        }
        //回溯
        visit[edge->adjvex] = false;
    }
}

//输出顶点i到顶点j之间的所有简单路径(不包含回路)
void findAllPath(ALGraph graph, int start, int end)
{
    if(start == end)
        cout<<start<<endl;
    else
    {
        bool visit[MAX_NUM];
        memset(visit, 0, sizeof(visit));
        int path[MAX_NUM];
        dfs(graph, start, end, visit, path, 0);
    }

}

  

输出图中顶点i到顶点j之间的所有简单路径

标签:之间   find   class   graph   回溯   highlight   简单   else   art   

原文地址:http://www.cnblogs.com/wt20/p/7464855.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!