首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >迭代式DFS比递归DFS快吗?

迭代式DFS比递归DFS快吗?
EN

Stack Overflow用户
提问于 2015-01-01 01:00:29
回答 1查看 1.1K关注 0票数 0

我以迭代和递归的方式实现了深度优先搜索算法。它们都可以很好地处理小文件(小于1MB)。然而,当我尝试在50MB的文件上运行它们时,似乎递归DFS (9秒)比使用迭代方法(至少几分钟)要快得多。事实上,迭代方法需要很长时间才能完成。

我选择实现迭代式DFS.But的唯一原因是,我认为它可能比递归DFS更快,但事实并非如此。这是意料之中的吗?

注意:我已经在使用java -Xmx1024m -Xms1024m -Xmn256m -Xss16m RunAlgo来增加内存了。

下面是我用来编写迭代式DFS的代码。

代码语言:javascript
复制
class IterativeDFS{
long time;
LinkedList<Vertex>topological_sort_list = new LinkedList<Vertex>();

public IterativeDFS(Digraph G){
    dfs(G);
}

public void dfs(Digraph G){
    for(Vertex u : G.getAllVertices()){
        u.set_color("WHITE");
        u.set_pi(-1);
    }
    time = 0;

    for(Vertex u : G.getAllVertices()){
        if(u.get_color().equals("WHITE")){
            dfs_stack(G, u);
        }
    }
}

public void dfs_stack(Digraph G, Vertex u){
    int size =  G.getAllVertices().size();

    /*
     *  to be able to iterate over each adjacency list, keeping track of which
     *  vertex in each adjacency list needs to be explored next.
     */
    HashMap<Vertex, Iterator<Vertex>> adj_map = new HashMap<Vertex, Iterator<Vertex>>();
    for(Vertex i : G.getAllVertices()){
        adj_map.put(i, G.adjEdges(i).iterator());
    }

    Stack<Vertex> stack = new Stack<Vertex>();
    // time++;          // white vertex u has just been discovered
    u.set_d(time);
    u.set_color("GRAY");
    stack.push(u);

    while(!stack.empty()){

        Vertex k = stack.peek();

        Vertex v = null;
        if(adj_map.get(k).hasNext()){
            v = adj_map.get(k).next();          // explore edges (k,v)
            if(v.get_color().equals("WHITE")){
                v.set_pi(k.get_node());
                //  time++;
                v.set_d(time);
                v.set_color("GRAY");
                stack.push(v);
            }
        } else{
                // v's adjacency list is exhausted
                Vertex t = stack.pop();
                time++;
                t.set_f(time);
                t.set_color("BLACK");
                /*
                 *  Topological Sort :
                 *      1. call DFS(G) to compute finishing times v.f for each vertex v
                 *      2. as each vertex is finished, insert it onto FRONT of linked list
                 *      3. return linked list of vertices
                 */
                topological_sort_list.addFirst(t);
        }
    }
}

public LinkedList<Vertex> topological_sort(){
    return topological_sort_list;
}

}
EN

回答 1

Stack Overflow用户

发布于 2020-04-20 03:49:48

如果你在谈论时间复杂性,答案是它们都是相同的。无论实现如何,DFS的运行时都是O(V),因为您应该只访问图中的每个顶点一次。此外,运行时也是Omega(V),因为无论输入大小如何,只需访问图中的所有顶点一次。这使得DFS的运行时处于Theta(V)。无论实现方式如何,总体DFS算法都保持不变。因此,递归DFS与迭代DFS的运行时在Theta(V)处应该是相同的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27724054

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档