算法系列001---dfs|多叉|解空间树理解

1.研究范围

1)多叉树,图的遍历

2)回溯法的解空间树=多叉树的遍历

2.研究方法

    我们现在研究的是多叉树的遍历,突然想到为什么不能直接用二叉树的遍历方法呢?我们抱着这个问题,先找到多叉树的结构不同于二叉树的地方,然后研究二叉树的遍历,找到其适用范围的限制和多叉树不能采用二叉树遍历的原因,并解决,最后就得到了我们的多叉树的遍历方法。

2.1 从二叉树和多叉树|图的结构来研究

1)二叉树

   

1 public class TreeNode {
2 
3    int val;
4   TreeNode left;
5   TreeNode right;
6    TreeNode(int x) { val = x; }
7    }

        

 2)多叉树|图

 

1  class UndirectedGraphNode {
2       int label;
3     List<UndirectedGraphNode> neighbors;
4     UndirectedGraphNode(int x) { label = x; neighbors = new      ArrayList<UndirectedGraphNode>(); }
5    };

 3)不同点或不能直接用二叉树遍历的原因

   二叉树的邻接点是确定的(或者说是可以直接点名点到的),而多叉树和图的邻接点是不确定的,我们不可能直接点名某节点君的第i个邻接点。

2.2二叉树遍历方法,适用范围,多叉树|图不能适用的原因

1)二叉树的先序递归遍历

 1 public class Solution {
 2     List<Integer> l = new ArrayList<Integer>();
 3     public List<Integer> preorderTraversal(TreeNode root) {
 4 
 5         if (root != null) {
 6             l.add(root.val);
 7             preorderTraversal(root.left);
 8             preorderTraversal(root.right);
 9 
10         }
11         return l;
12     }
13 }

2)从上面的遍历得知,它的递归遍历中,preorderTraversal(root.left)是直接点名去遍历的,然后结合二叉树和多叉树和图结构的不同点,得出多叉和图不能直接使用二叉遍历的原因,就是它们的邻接点不确定,不能直接点到自己邻接点的名字。当然,这可以应用到三叉,四叉。。,必然要给其邻接点起好名字,下面以四叉为例,

结构:

public class TreeNode {
  int val;
 TreeNode first;
  TreeNode second;
    TreeNode third;
    TreeNode fouth;
    TreeNode(int x) { val = x; }
}

遍历:

public class Solution {
    List<Integer> l = new ArrayList<Integer>();
    public List<Integer> preorderTraversal(TreeNode root) {
        if (root != null) {
            l.add(root.val);
            preorderTraversal(root.first);
            preorderTraversal(root.second);
            preorderTraversal(root.third);
            preorderTraversal(root.fouth);
        }
        return l;
    }
}

所以,如果想要五叉,六叉都要给其邻接点起好名字,然后再列举出来分别遍历,呀,我们看出来了,这是在是很麻烦,也正是循环起源的原因,当邻接点可以起名字但很多,或者根本就不能起名字(当邻接点的个数不确定的时候)的时候,我们就不能采用二叉遍历的方法,我们要加入循环。当然,如果是图的话,我们还要加入visit[]数组,判断是否已经遍历过了。

2.3

1)不确定几叉的多叉的结构和遍历

import java.util.ArrayList;
import java.util.List;
class TreeNode{
    int val;
     List<TreeNode> neighbors;
     TreeNode(int x) { val = x; neighbors = new ArrayList<TreeNode>(); }
}
public class b {
    List<Integer> l = new ArrayList<Integer>();    
    public List<Integer> DFS(TreeNode root) {
        if (root != null) {
            l.add(root.val);
            for(int i=0;i<root.neighbors.size();i++){
                    DFS(root.neighbors.get(i));
            }
        }
        return l;
    }
}

2)图的遍历

  • 由于图的联通性未知,所以要对每个节点进行确认,循环遍历,如果没有visit过就要对其进行DFS;如果是连通的话,只需考虑下面一点即可。
  • 由于图没有层次性特点,加入visit的hashMap结构
原文地址:https://www.cnblogs.com/thehappyyouth/p/3927039.html