zoukankan      html  css  js  c++  java
  • 【算法总结】深搜

    算法总结-深搜

    由于是深度优先,后进入的结点需要先读取,因此选取堆栈实现,在栈中保存从起始结点(状态)到当前结点的路径上的所有结点。一般用递归实现。

    非递归框架

    DFS()
    {
        初始化栈
            while (栈不为空 & 未找到目标结点)
        {
            取栈顶元素扩展,扩展出的结点放回栈顶
        }
        ......
    }

    递归框架

    在深度优先搜索中,状态空间的图结构并不一定需要显式地保存下来。

    type node;
    void DFS(int depth)
    {
        for (node的每一个可行变化)
        {
            改变node
            DFS(depth+1)
            恢复node
        }
    }

    该做法需要一个全局数组array来存放每个走过的node,array[depth]就是进入DFS函数时需要扩展的结点。

     

  • 相关阅读:
    shared pointer
    realsense数据分析
    cmake log
    Qt自定义类添加qvector报错
    Java csv
    opencv C++ mask_rcnn
    realsense data
    Test
    ubuntu18 bluebooth
    LSTM_Model
  • 原文地址:https://www.cnblogs.com/yun-an/p/11052029.html
Copyright © 2011-2022 走看看