1.研究范围

1)多叉树,图的遍历

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

2.研究方法

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

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

1)二叉树

 public class TreeNode {

    int val;
  TreeNode left;
  TreeNode right;
  TreeNode(int x) { val = x; }
}

2)多叉树|图

 

  class UndirectedGraphNode {
  int label;
   List<UndirectedGraphNode> neighbors;
  UndirectedGraphNode(int x) { label = x; neighbors = new ArrayList<UndirectedGraphNode>(); }
   };

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

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

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

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

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

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结构

算法系列001---dfs|多叉|解空间树理解的更多相关文章

  1. POJ 3321 Apple Tree dfs+二叉索引树

    题目:http://poj.org/problem?id=3321 动态更新某个元素,并且求和,显然是二叉索引树,但是节点的标号不连续,二叉索引树必须是连续的,所以需要转化成连续的,多叉树的形状已经建 ...

  2. [LeetCode系列]卡特兰数(Catalan Number) 在求解独特二叉搜寻树(Unique Binary Search Tree)中的应用分析

    本文原题: LeetCode. 给定 n, 求解独特二叉搜寻树 (binary search trees) 的个数. 什么是二叉搜寻树? 二叉查找树(Binary Search Tree),或者是一棵 ...

  3. 聊聊算法——BFS和DFS

    如果面试字节跳动和腾讯,上来就是先撕算法,阿里就是会突然给你电话,而且不太在意是周末还是深夜, 别问我怎么知道的,想确认的可以亲自去试试.说到算法,直接力扣hard三百题也是可以的,但似乎会比较伤脑, ...

  4. NOI 2015 荷马史诗【BZOJ 4198】k叉Huffman树

    抱歉因为NOIP集训,好长时间没再写题解了. NOI 2015也就只有这道题一看就能懂了-- 4198: [Noi2015]荷马史诗 Time Limit: 10 Sec  Memory Limit: ...

  5. <转>从K近邻算法、距离度量谈到KD树、SIFT+BBF算法

    转自 http://blog.csdn.net/likika2012/article/details/39619687 前两日,在微博上说:“到今天为止,我至少亏欠了3篇文章待写:1.KD树:2.神经 ...

  6. 从K近邻算法、距离度量谈到KD树、SIFT+BBF算法

    转载自:http://blog.csdn.net/v_july_v/article/details/8203674/ 从K近邻算法.距离度量谈到KD树.SIFT+BBF算法 前言 前两日,在微博上说: ...

  7. 玩转算法系列--图论精讲 面试升职必备(Java版)

    第1章 和bobo老师一起,玩转图论算法欢迎大家来到我的新课程:<玩转图论算法>.在这个课程中,我们将一起完整学习图论领域的经典算法,培养大家的图论建模能力.通过这个课程的学习,你将能够真 ...

  8. 简答一波 HashMap 常见八股面试题 —— 算法系列(2)

    请点赞,你的点赞对我意义重大,满足下我的虚荣心. Hi,我是小彭.本文已收录到 GitHub · Android-NoteBook 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注 ...

  9. 二叉索引树BIT

    定义     二叉索引树,binary index tree,又名树状数组,或Fenwick Tree,因为本算法由Fenwick创造.     对于数组A,定义Query(i,j) = Ai +Ai ...

随机推荐

  1. Linux学习 -- 文件系统管理

    1 分区和文件系统 分区类型 主分区:<= 4个 扩展分区:只能有一个,也算主分区的一种   不能存储数据和格式化,只能用来包含逻辑分区 逻辑分区:扩展分区中划分的   IDE--最多59个   ...

  2. ormlite 多表联合查询

    ormlite 多表联合查询 QueryBuilder shopBrandQueryBuilder = shopBrandDao.queryBuilder(); QueryBuilder shopQu ...

  3. L1,a private conversation

    words enjoy喜欢,享受,欣赏 pay,支付,pay money for sth 报酬,I have not received my pay yet. bear,忍受,支撑,承担,负担 I c ...

  4. vi join

    换行符删不掉?试试n shift+j,它合并其下n行到一行.

  5. mysql链接表,connection string, federated engine

    http://database.51cto.com/art/201011/234561.htm

  6. linux proxy

    ALL_PROXY=socks://192.168.2.1:3128/ HTTPS_PROXY=https://192.168.2.1:3128/HTTP_PROXY=http://192.168.2 ...

  7. angular指令系列---多行文本框自动高度

    angular.module('MyApp') .directive('autoTextare', ['$timeout', function ($timeout) { return { restri ...

  8. Rails (堆栈)<数据结构>

    题意:<看图片> 解题思路:栈的简单应用: #include<iostream> #include<stack> #include<algorithm> ...

  9. 解决Ubuntu系统中文乱码显示问题,终端打开文件及查看目录

    解决Ubuntu系统中文乱码显示问题 [日期:2014-02-20] 来源:Linux社区  作者:njchenyi [字体:大 中 小]   我是先安装了Ubuntu 12.04 Server,然后 ...

  10. HTTP Request header

    HTTP Request header HTTP协议详解 - 小坦克 - 博客园 HTTP Request header 当今web程序的开发技术真是百家争鸣,ASP.NET, PHP, JSP,Pe ...