树 相关知识总结以及Java实现
最近在温习树相关的知识,并且用java实现了一下树的遍历相关,先贴上代码供大家参考吧。
package tree_problems;
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.Queue;
import java.util.Stack;
public class TreeNodec<E> {
E value;
TreeNodec<E> left;
TreeNodec<E> right;
public TreeNodec(E x){value=x;}
private static <E> void forPreOrderRecursion(TreeNodec<E> T,ArrayList<E> result) { //静态方法不可以访问类上定义的泛型,如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。
if(T!=null) {
result.add(T.value);
forPreOrderRecursion(T.left, result);
forPreOrderRecursion(T.right, result);
}
}
public static <E> ArrayList<E> preOrderRecursion(TreeNodec<E> T) {
ArrayList<E> result = new ArrayList<>();
forPreOrderRecursion(T, result);
return result;
}
private static <E> void forInOrderRecursion(TreeNodec<E> T,ArrayList<E> result) { //静态方法不可以访问类上定义的泛型,如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。
if(T!=null) {
forInOrderRecursion(T.left, result);
result.add(T.value);
forInOrderRecursion(T.right, result);
}
}
public static <E> ArrayList<E> inOrderRecursion(TreeNodec<E> T) {
ArrayList<E> result = new ArrayList<>();
forInOrderRecursion(T, result);
return result;
}
private static <E> void forPostOrderRecursion(TreeNodec<E> T,ArrayList<E> result) { //静态方法不可以访问类上定义的泛型,如果静态方法操作的应用数据类型不确定,可以将泛型定义在方法上。
if(T!=null) {
forPostOrderRecursion(T.left, result);
forPostOrderRecursion(T.right, result);
result.add(T.value);
}
}
public static <E> ArrayList<E> postOrderRecursion(TreeNodec<E> T) {
ArrayList<E> result = new ArrayList<>();
forPostOrderRecursion(T, result);
return result;
}
//非递归前序遍历
public static <E> ArrayList<E> preOrder(TreeNodec<E> T){
Stack<TreeNodec> stack = new Stack<>();
ArrayList<E> result = new ArrayList<>();
TreeNodec<E> p =T; //工作指针
while(p!=null||!stack.empty()) { //NLR,先读N,后进栈L和R
if(p!=null) {
result.add(p.value);
stack.push(p);
p=p.left;
}
else {
p=stack.pop().right;
}
}
return result;
}
public static <E> ArrayList<E> inOrder(TreeNodec<E> T){
Stack<TreeNodec> stack = new Stack<>();
ArrayList<E> result = new ArrayList<>();
TreeNodec<E> p =T; //工作指针
while(p!=null||!stack.empty()) { //LNR,先进栈L,再读,最后再进栈R
if(p!=null) {
stack.push(p);
p=p.left;
}
else {
p=stack.pop();
result.add(p.value);
p=p.right;
}
}
return result;
}
public static <E> ArrayList<E> postOrder(TreeNodec<E> T){//LRN和NRL结果倒过来一样,NRL和NLR又有什么区别呢……其实就是前序遍历啊……
Stack<TreeNodec> stack = new Stack<>();
ArrayList<E> result = new ArrayList<>();
TreeNodec<E> p =T; //工作指针
while(p!=null||!stack.empty()) {
if(p!=null) {
result.add(0,p.value);
stack.push(p);
p=p.right;
}
else {
p=stack.pop().left;
}
}
return result;
}
public static <E> ArrayList<E> postOrdersb(TreeNodec<E> T){//傻了,LRN和NRL结果倒过来一样,NRL和NLR又有什么区别呢……其实就是前序遍历啊……
Stack<TreeNodec> stack = new Stack<>();
Stack<E> values = new Stack<>();
ArrayList<E> result = new ArrayList<>();
TreeNodec<E> p =T; //工作指针
while(p!=null||!stack.empty()) { //LRN,先进栈(倒序NRL进栈),最后再读,用栈1负责顺序,用栈2负责读结果(如果用自己手动的栈可以将两个栈合并为1个)
if(p!=null) {
stack.push(p);
values.push(p.value);
p=p.right;
}
else {
p=stack.pop();
p=p.left;
}
}
while(!values.empty()) {
result.add(values.pop());
}
return result;
}
public static <E> ArrayList<E> levelTraverse(TreeNodec<E> T){
ArrayList<E> result = new ArrayList<>();
Queue<TreeNodec<E>> queue = new ArrayDeque<>();
queue.add(T);
TreeNodec<E> p = T;
while(!queue.isEmpty()) {
p = queue.remove();
result.add(p.value);
if(p.left!=null) queue.add(p.left);
if(p.right!=null) queue.add(p.right);
}
return result;
}
public static void main(String[] args) {
TreeNodec<Integer> T = new TreeNodec(1);
T.left = new TreeNodec(2);T.right = new TreeNodec(3);
T.left.right = new TreeNodec(4);T.left.right.left = new TreeNodec(6);
T.right.right = new TreeNodec(5);
ArrayList<Integer> preorder = TreeNodec.preOrderRecursion(T);
System.out.println(preorder);
ArrayList<Integer> inorder = TreeNodec.inOrderRecursion(T);
System.out.println(inorder);
ArrayList<Integer> postorder = TreeNodec.postOrderRecursion(T);
System.out.println(postorder);
ArrayList<Integer> prorder = TreeNodec.preOrder(T);
System.out.println(prorder);
ArrayList<Integer> iorder = TreeNodec.inOrder(T);
System.out.println(iorder);
ArrayList<Integer> porder = TreeNodec.postOrder(T);
System.out.println(porder);
ArrayList<Integer> levelTraversal = TreeNodec.levelTraverse(T);
System.out.println(levelTraversal);
}
}
树 相关知识总结以及Java实现的更多相关文章
- java中的字符串相关知识整理
字符串为什么这么重要 写了多年java的开发应该对String不陌生,但是我却越发觉得它陌生.每学一门编程语言就会与字符串这个关键词打不少交道.看来它真的很重要. 字符串就是一系列的字符组合的串,如果 ...
- 【转】java NIO 相关知识
原文地址:http://www.iteye.com/magazines/132-Java-NIO Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的 ...
- Java 容器相关知识全面总结
Java实用类库提供了一套相当完整的容器来帮助我们解决很多具体问题.因为我本身是一名Android开发者,包括我在内很多安卓开发,最拿手的就是ListView(RecycleView)+BaseAda ...
- [转]java中的字符串相关知识整理
字符串为什么这么重要 写了多年java的开发应该对String不陌生,但是我却越发觉得它陌生.每学一门编程语言就会与字符串这个关键词打不少交道.看来它真的很重要. 字符串就是一系列的字符组合的串,如果 ...
- 【Python五篇慢慢弹(5)】类的继承案例解析,python相关知识延伸
类的继承案例解析,python相关知识延伸 作者:白宁超 2016年10月10日22:36:57 摘要:继<快速上手学python>一文之后,笔者又将python官方文档认真学习下.官方给 ...
- HTML入门基础教程相关知识
HTML入门基础教程 html是什么,什么是html通俗解答: html是hypertext markup language的缩写,即超文本标记语言.html是用于创建可从一个平台移植到另一平台的超文 ...
- listener监听器的相关知识
从别人的博客上我学习了listener的相关知识现在分享给大家 1.概念: 监听器就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上 ...
- WEB相关知识和Tomcat服务器
WEB相关知识 1.Internet上供外界访问的Web资源分为: 静态web资源:指web页面中供人们浏览的数据始终是不变的. 动态web资源:指web页面中供人们浏览的数据是由程序产生的,不同时间 ...
- python实现单例模式的三种方式及相关知识解释
python实现单例模式的三种方式及相关知识解释 模块模式 装饰器模式 父类重写new继承 单例模式作为最常用的设计模式,在面试中很可能遇到要求手写.从最近的学习python的经验而言,singlet ...
随机推荐
- k8s数据管理(八)--技术流ken
volume 我们经常会说:容器和 Pod 是短暂的.其含义是它们的生命周期可能很短,会被频繁地销毁和创建.容器销毁时,保存在容器内部文件系统中的数据都会被清除. 为了持久化保存容器的数据,可以使用 ...
- 能够玩转BKY皮肤的 geek,有一半最后都成为了前端大师
By Conmajia March 9, 2018 剩下的那一半全部扑街了. 世纪之初,BKY那些花里胡哨的预设皮肤曾经让初识网络的懵懂学子雀跃不已. 然而以现在的审美眼光看来,这些带着一股子扑面而来 ...
- C# 创建、更改Excel命名区域(NamedRange)
创建命名区域是指给选定的某个单元格或多个单元格区域设置名称,目的是方便我们在文件中的其他地方对该单元格区域进行引用能够简化公式引用或者方便数据管理.下面记录了具体的C#示例代码.这里创建命名区域分为了 ...
- while,for,if输入账号密码判断(还请各位大牛能够优化,本人刚学习一周)
AccountNumber1 = [] password1 = [] flag = True while flag: num = 0 a = 1 print('-----------这是个欢迎界面-- ...
- C++系列总结——封装
前言 众所周知,封装.继承和多态是面向对象编程的三大特性.C++作为一门面向对象的编程语言,自然支持了这些特性,但C++是如何实现这些特性的呢?今天先说下我理解的封装. 封装 通常我们会把下面的行为也 ...
- vue中的tab栏切换内容变换
<!DOCTYPE html> <html lang="cn-zh"> <head> <meta charset="UTF-8& ...
- Jinja2用法总结
Jinja2用法总结 一:渲染模版 要渲染一个模板,通过render_template方法即可. @app.route('/about/') def about(): # return rende ...
- Dynamics 365 Customer Engagement中插件的调试
微软动态CRM专家罗勇 ,回复319或者20190319可方便获取本文,同时可以在第一间得到我发布的最新博文信息,follow me!我的网站是 www.luoyong.me . 本文主要根据官方的教 ...
- git-lfs插件
Git本地会保存文件所有版本,对于大文件很容易导致仓库体积迅速膨胀 为了解决这个问题,Github在2015.4宣布推出Git LFS(Large File Storage),详见:Announcin ...
- ThinkPad 安装 Ubuntu 18.10 系统 -- 高分屏各项配置与Nvdia独显驱动
索引: 目录索引 一.机器概述 1.屏幕:14'' 2.分辨率:1920*1080 3.显卡:Intel 核显 & Nvidia GeForce 940MX 独显 ,双显卡 4.其它硬件 ...