算法系列001---dfs|多叉|解空间树理解
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|多叉|解空间树理解的更多相关文章
- POJ 3321 Apple Tree dfs+二叉索引树
题目:http://poj.org/problem?id=3321 动态更新某个元素,并且求和,显然是二叉索引树,但是节点的标号不连续,二叉索引树必须是连续的,所以需要转化成连续的,多叉树的形状已经建 ...
- [LeetCode系列]卡特兰数(Catalan Number) 在求解独特二叉搜寻树(Unique Binary Search Tree)中的应用分析
本文原题: LeetCode. 给定 n, 求解独特二叉搜寻树 (binary search trees) 的个数. 什么是二叉搜寻树? 二叉查找树(Binary Search Tree),或者是一棵 ...
- 聊聊算法——BFS和DFS
如果面试字节跳动和腾讯,上来就是先撕算法,阿里就是会突然给你电话,而且不太在意是周末还是深夜, 别问我怎么知道的,想确认的可以亲自去试试.说到算法,直接力扣hard三百题也是可以的,但似乎会比较伤脑, ...
- NOI 2015 荷马史诗【BZOJ 4198】k叉Huffman树
抱歉因为NOIP集训,好长时间没再写题解了. NOI 2015也就只有这道题一看就能懂了-- 4198: [Noi2015]荷马史诗 Time Limit: 10 Sec Memory Limit: ...
- <转>从K近邻算法、距离度量谈到KD树、SIFT+BBF算法
转自 http://blog.csdn.net/likika2012/article/details/39619687 前两日,在微博上说:“到今天为止,我至少亏欠了3篇文章待写:1.KD树:2.神经 ...
- 从K近邻算法、距离度量谈到KD树、SIFT+BBF算法
转载自:http://blog.csdn.net/v_july_v/article/details/8203674/ 从K近邻算法.距离度量谈到KD树.SIFT+BBF算法 前言 前两日,在微博上说: ...
- 玩转算法系列--图论精讲 面试升职必备(Java版)
第1章 和bobo老师一起,玩转图论算法欢迎大家来到我的新课程:<玩转图论算法>.在这个课程中,我们将一起完整学习图论领域的经典算法,培养大家的图论建模能力.通过这个课程的学习,你将能够真 ...
- 简答一波 HashMap 常见八股面试题 —— 算法系列(2)
请点赞,你的点赞对我意义重大,满足下我的虚荣心. Hi,我是小彭.本文已收录到 GitHub · Android-NoteBook 中.这里有 Android 进阶成长知识体系,有志同道合的朋友,关注 ...
- 二叉索引树BIT
定义 二叉索引树,binary index tree,又名树状数组,或Fenwick Tree,因为本算法由Fenwick创造. 对于数组A,定义Query(i,j) = Ai +Ai ...
随机推荐
- 《JavaScript高级程序设计》读书笔记 ---变量
ECMAScript 的变量是松散类型的,所谓松散类型就是可以用来保存任何类型的数据.换句话说,每个变量仅仅是一个用于保存值的占位符而已.定义变量时要使用var 操作符(注意var 是一个关键字),后 ...
- POJ 1523 SPF (去掉割点能形成联通块的个数)
思路:使用tarjan算法求出割点,在枚举去掉每一个割点所能形成的联通块的个数. 注意:后来我看了下别的代码,发现我的枚举割点的方式是比较蠢的方式,我们完全可以在tarjan过程中把答案求出来,引入一 ...
- eclipse,android Localization (Internationalization) 安卓本地化(国际化)
1.创建新的资源文件,名字保持一致.提示"已存在",继续. 2.使用“语言”作为识别器,然后选择相应的语言代码.Tips:其他的适配,如国家.屏幕大小等,也是通过这里的识别器实现适 ...
- 优化のzen cart调用WordPress
zen cart调用wordpress博客系统文章的方法 zencart根目录下新建blog 解压wp进去然后 wp-admin 安装 数据库共用 之前将wordpress和zencart整合起来 是 ...
- jQuery两种扩展插件的方式
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- emacs search, 讲的很清楚。
默认情况下,Emacs采用了一种很待殊的”增量搜索”的功能,虽然它与我们常用的搜索方法在操作习惯上有很大的不同,但习惯后确实是十分的方便. 要让Emacs开始执行搜索,可以按C-s或C-r,前者是从光 ...
- 【dp】 poj 1953
用n个数字0或者1组成一个排列,要求每两个1不相邻,问有多少种排法 dp[n][0]记录n个连续数,结尾为0的不同排列数dp[n][1]记录第n个连续数,结尾为1的不同排列数 DP公式: dp[i][ ...
- ural1424 Minibus
Minibus Time limit: 1.0 secondMemory limit: 64 MB Background Minibus driver Sergey A. Greedson has b ...
- 使用compass更高效的编辑css --- 图片精灵
compass是sass的一个库,关系相当于js中的jq.比较可惜的是compass的文档比较混乱 看的不太舒服,下面是compass的文档地址,有兴趣的可以去看看 http://compass-st ...
- STL入门2
1:给出n个字符串,输出每个字符串是第几个出现的字符串?多组数据 2:对每组数据,第一行输入n表示接下来有n个字符串 1 <= n <= 100000接下来的n行,每行输入一个非空的且长度 ...