二叉树(二叉链表实现)JAVA代码

publicclassTest{publicstaticvoid main(String[] args){char[] ch =newchar[]{'A','B','D','#','#','G','#','#','C','J','#','#','M','#','#'};BinaryTree binaryTree =newBinaryTree(ch);binaryTree.preOrder();System.out.println();binaryTree.inOrder();System.out.println();binaryTree.postOrder();System.out.println();binaryTree.levelOrder();System.out.println();}}
publicclassBinaryTree{//二叉树结点publicclassBiNode{char data;BiNode left;BiNode right;BiNode(char data,BiNode left,BiNode right){this.data = data;this.left = left;this.right = right;}int flag =0;//供非递归后序遍历使用}//根结点publicBiNode root;privatestaticint i;publicBinaryTree(char[] pre){i =0;root = create(pre);}//初始化(先序遍历顺序存放数组、'#'表示null)privateBiNode create(char[] pre){if(i < pre.length){if(pre[i]=='#') //结点为空{i++;return null;}BiNode p =newBiNode(pre[i], null, null); //结点非空i++;p.left = create(pre); //递归建立左子树p.right = create(pre); //递归建立右子树return p;}return null;}//先序遍历publicvoid preOrder(){System.out.print("preOrder traversal with recursion:");preOrder(root);System.out.println();System.out.print("preOrder traversal without recursion:");preOrder2(root);System.out.println();}//递归privatevoid preOrder(BiNode root){if(root == null)return;System.out.print(root.data); //访问结点preOrder(root.left);preOrder(root.right);}//非递归privatevoid preOrder2(BiNode head){LinkedList<BiNode> s =newLinkedList<BiNode>();while(head != null ||!s.isEmpty()){while(head != null) //访问左子树{System.out.print(head.data); //访问左子树s.push(head); //结点入栈(待后面找其右子树使用)= =(“递归”)head = head.left;}if(!s.isEmpty()) //转向右子树{head = s.peek().right; //转向右子树s.pop(); //结点出栈(已经找到其右子树)= =(“递归结束”)}}}//中序遍历publicvoid inOrder(){System.out.print("inOrder traversal with recursion:");inOrder(root);System.out.println();System.out.print("inOrder traversal without recursion:");inOrder2(root);System.out.println();}//递归privatevoid inOrder(BiNode root){if(root == null)return;inOrder(root.left);System.out.print(root.data); //访问结点inOrder(root.right);}//非递归privatevoid inOrder2(BiNode head){LinkedList<BiNode> s =newLinkedList<BiNode>();while(head != null ||!s.isEmpty()){while(head != null) //左子树入栈{s.push(head); //结点入栈(待后面找其右子树使用)= =(“递归”)head = head.left;}System.out.print(s.peek().data); //访问左子树if(!s.isEmpty()) //转向右子树{head = s.peek().right; //转向右子树s.pop(); //结点出栈(已经找到其右子树)= =(“递归结束”)}}}//后序遍历publicvoid postOrder(){System.out.print("postOrder traversal with recursion:");postOrder(root);System.out.println();System.out.print("postOrder traversal without recursion:");postOrder2(root);System.out.println();}//递归privatevoid postOrder(BiNode root){if(root == null)return;postOrder(root.left);postOrder(root.right);System.out.print(root.data); //访问结点}//非递归//后序遍历特点:递归左右子树后,还需访问结点://1、左子树入栈//2、“两次出栈”(用flag标记模仿):第一次是为了找到左子树相应的右子树结点;第二次是为了访问结点privatevoid postOrder2(BiNode head){LinkedList<BiNode> s =newLinkedList<BiNode>();while(head != null ||!s.isEmpty()){while(head != null) //左子树入栈{head.flag =1;s.push(head); //结点连同flag入栈(待后面找其右子树使用)= =(“递归”)head = head.left;}while(!s.isEmpty()&& s.peek().flag ==2) //若flag为2(已经找到其右子树出过一次栈),访问结点{System.out.print(s.peek().data); //访问结点元素s.pop(); //(第二次“结点出栈”)实际结点出栈(已经访问结点元素)= =(“递归结束”)}if(!s.isEmpty()) //flag为1,转向右子树{head = s.peek().right; //转向右子树s.peek().flag =2; //(第一次“flag模拟出栈”)标记为2,但实际结点不出栈(已经找到其右子树)}}}//层序遍历publicvoid levelOrder(){levelOrder(root);}privatevoid levelOrder(BiNode root){LinkedList<BiNode>queue=newLinkedList<BiNode>(); //LinkedList实现了Queue接口BiNode p = root;while(p != null){System.out.print(p.data); //访问结点if(p.left != null)queue.add(p.left);if(p.right != null)queue.add(p.right);p =queue.poll(); //队头出队并返回为p}}//在p结点后插入datapublicvoid insert(BiNode p,char data, boolean left){if(p != null){if(left) //插入位置为左孩子p.left =newBiNode(data,p.left,null);else //插入位置为右孩子p.right =newBiNode(data,p.right,null);}}//删除p的一个子树publicvoiddelete(BiNode p, boolean left){if(p != null){if(left) //删除目标为左子树p.left = null;else //删除目标为右子树p.right = null;}}}
二叉树(二叉链表实现)JAVA代码的更多相关文章
- C#实现二叉树--二叉链表结构
二叉树的简单介绍 关于二叉树的介绍请看这里 : 二叉树的简单介绍 http://www.cnblogs.com/JiYF/p/7048785.html 二叉链表存储结构: 二叉树的链式存储结构是指,用 ...
- C语言递归实现二叉树(二叉链表)的三种遍历和销毁操作(实验)
今天写的是二叉树操作的实验,这个实验有三个部分: ①建立二叉树,采用二叉链表结构 ②先序.中序.后续遍历二叉树,输出节点值 ③销毁二叉树 二叉树的节点结构定义 typedef struct BiTNo ...
- 二叉树的二叉链表存储结构及C++实现
前言:存储二叉树的关键是如何表示结点之间的逻辑关系,也就是双亲和孩子之间的关系.在具体应用中,可能要求从任一结点能直接访问到它的孩子. 一.二叉链表 二叉树一般多采用二叉链表(binary linke ...
- c使用二叉链表创建二叉树遇到的一些疑问和思考
二叉链表存储二叉树 学习的时候参考的是<大话数据结构>,书中是这样定义的 typedef char TElemType; typedef struct BiTNode { TElemTyp ...
- 树(二叉树 & 二叉搜索树 & 哈夫曼树 & 字典树)
树:n(n>=0)个节点的有限集.有且只有一个root,子树的个数没有限制但互不相交.结点拥有的子树个数就是该结点的度(Degree).度为0的是叶结点,除根结点和叶结点,其他的是内部结点.结点 ...
- 编程算法 - 二叉搜索树 与 双向链表 代码(C++)
二叉搜索树 与 双向链表 代码(C++) 本文地址: http://blog.csdn.net/caroline_wendy 题目:输入一颗二叉搜索树, 将该二叉搜索树转换成一个排序的双向链表. 要求 ...
- 【算法与数据结构】二叉搜索树的Java实现
为了更加深入了解二叉搜索树,博主自己用Java写了个二叉搜索树,有兴趣的同学可以一起探讨探讨. 首先,二叉搜索树是啥?它有什么用呢? 二叉搜索树, 也称二叉排序树,它的每个节点的数据结构为1个父节点指 ...
- 二叉搜索树 思想 JAVA实现
二叉搜索树:一棵二叉搜索树是以一棵二叉树来组织的,这样一棵树可以使用链表的数据结构来表示(也可以采用数组来实现).除了key和可能带有的其他数据外,每个节点还包含Left,Right,Parent,它 ...
- 二叉搜索树及java实现
二叉搜索树(Binary Search Tree) 二叉搜索树是二叉树的一种,是应用非常广泛的一种二叉树,英文简称为 BST 又被称为:二叉查找树.二叉排序树 任意一个节点的值都大于其左子树所有节 ...
- 二叉搜索树的java实现
转载请注明出处 一.概念 二叉搜索树也成二叉排序树,它有这么一个特点,某个节点,若其有两个子节点,则一定满足,左子节点值一定小于该节点值,右子节点值一定大于该节点值,对于非基本类型的比较,可以实现Co ...
随机推荐
- directshow filter 调试步骤
1,编写filter 2,在debug模式下build 3,注册filter:控制台cd到工程的debug目录下,即欲注册的filter(.ax文件)目录,xx:>regsvr32 contra ...
- phpcms首页调用会员头像及金钱、积分等信息,并按照积分点数排列
<div class="box"> <h5>最新会员</h5> <div class="col-auto">&l ...
- 深入Java虚拟机读书笔记第一章Java体系结构介绍
第1章 Java体系结构介绍 Java技术核心:Java虚拟机 Java:安全(先天防bug的设计.内存).健壮.平台无关.网络无关(底层结构上,对象序列化和RMI为分布式系统中各个部分共享对象提供了 ...
- CSS 字体描边
-webkit-text-stroke: 2px #; text-stroke: 2px #; -o-text-stroke: 2px #;
- jquery 插件模版
;(function ($) { //插件的默认值属性 var defaults = { Weight: '300px', height: '230px', nextId: 'nextBtn', ne ...
- Lucene查询条数限制
运用Lucene进行索引,在查询的时候是有条数限制的 public virtual TopFieldDocs Search(Query query, Filter filter, int n, Sor ...
- Swift互用性: 使用Objective-C特性编写Swift类(Swift 2.0版)-b
本节包括内容: 继承Objective-C的类(Inheriting from Objective-C Classes) 采用协议(Adopting Protocols) 编写构造器和析构器(Writ ...
- kd树的构建以及搜索
构建算法 k-d树是一个二叉树,每个节点表示一个空间范围.表1给出的是k-d树每个节点中主要包含的数据结构. 表1 k-d树中每个节点的数据类型 域名 数据类型 描述 Node-data 数据矢量 数 ...
- JavaScript Web Application summary
Widget/ HTML DOM (CORE) (local dom) DOM, BOM, Event(Framework, UI, Widget) function(closure) DATA (c ...
- 破解简单Mifare射频卡密钥杂记
先要了解一点大学城浴卡用的是什么卡,经查证是Mifare S50卡,也有叫ISO14443A的(协议名).本来想看看大学城浴卡有没有安全漏洞,没想到浴卡公司在安全性上几乎是蔑视我们大学生的智商,虽然被 ...