二叉树(二叉链表实现)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 ...
随机推荐
- java记事本
新知识点 1.撤销 textArea添加一个实现监听接口的类(添加了之后可以一直监视着添加的删除的情况,以便来撤销 textArea.getDocument().addUndoableEditList ...
- hdu 1548 A strange lift (bfs)
A strange lift Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) T ...
- ch01.深入理解C#委托及原理(转)
ch01..深入理解C#委托及原理_<没有控件的ASPDONET> 一.委托 设想,如果我们写了一个厨师做菜方法用来做菜,里面有 拿菜.切菜.配菜.炒菜 四个环节,但编写此方法代码的人想让 ...
- 离线安装maven,重新打开eclipse报错处理方法
报错截图如下 1.eclipse 添加 jre Window -> Preferences -> Java -> Installed JREs If you can’t find a ...
- jQuery自带的一些常用方法总结
jQuery自带的一些常用方法总结 这篇文章主要介绍了jQuery自带的一些常用方法总结,包括$.trim .$.contains.$.each.$.map.$.inArray.$.extend等,需 ...
- python使用platform模块获取系统环境并去除换行符
近来在porting一个网站,企图拿到这个网站的数据来做分析.为了支持多系统环境的正常运行.需要知道当前系统环境的是什么OS? 1.python内置platform库.可以很方便得到当前系统环境时什么 ...
- linux下的工具总结
1. 编译阶段 gcc: -Wall -Werror -O2 make nm: nm -C a.o c++filt strip objdump readelf 2. 链接 ldd: ldd ./a.o ...
- swift material
import UIKit extension UIColor { convenience init(hex:Int, alpha:CGFloat=1.0) { let red = CGFloat((h ...
- poj 2528Mayor's posters
http://poj.org/problem?id=2528 这个题有个细节,整个区间的长度为10000000,而n最大只有1000,所以我们要进行离散化. #include<cstdio> ...
- Android ContentProvider 简介
当在系统中部署一个又一个Android应用之后,系统里将会包含多个Android应用,有时候就需要在小同的应用之问芡亭数据,比如现在有一个短信接收应用,用户想把接收到的陌生短信的发信人添加到联系人管理 ...