树是一种重要的非线性数据结构,二叉树又是每个节点最多只有两个字节点的树。每一层的节点从左至右顺序排列叫做有序二叉树
二叉树主要用途用于排序和查找。
以下是java实现的,给定一个无序的数字集合,将他们生成二叉树,排序,并且可以查询某个数字是否在树中。
package com.tree;
import java.util.ArrayList;
import java.util.Date;
import java.util.LinkedList;
import java.util.List;
/**
* yuyong 2012-11-2
*/
public class BinaryTree {
public LinkedList list=new LinkedList();
public TreeNode root;
public BinaryTree(Double[] objs){
for(Double obj:objs){
if(root==null){
root=new TreeNode(obj);
}else
add(obj,root);
}
sort(root);
}
private void add(Double obj,TreeNode node){
int result=node.value.compareTo(obj);
if(result>0){
if(node.left==null)
node.left=new TreeNode(obj);
else
add(obj,node.left);
}else if(result==0){
node.count++;
}else if(result <0){
if(node.right==null)
node.right=new TreeNode(obj);
else
add(obj,node.right);
}
}
private void sort(TreeNode node){
if(node.left!=null){
sort(node.left);
}
for(int i=1;i<=node.count;i++){
list.addLast(node.value);
}
if(node.right!=null){
sort(node.right);
}
}
public boolean search(TreeNode node,double value){
if(node.value==value)
return true;
else{
if(node.value>value)
if(node.left!=null)
search(node.left,value);
else{
if(node.right!=null)
search(node.right,value);
}
}
return false;
}
class TreeNode{
public Double value;
public int count=1;
public TreeNode left;
public TreeNode right;
public TreeNode(Double value){
if(this.value==value)
count++;
this.value=value;
}
}
public static void main(String args[]){
Double[] v=new Double[10];
double j = 0;
for(int i=0;i<10;i++){
v[i]=Math.random()*10.0;
if(i==0)
j=v[i];
}
BinaryTree tree=new BinaryTree(v);
System.out.println(tree.list);
System.out.println(tree.search(tree.root,j));
System.out.println(tree.search(tree.root,12));
}
}
输出 [0.46790557311640946, 1.8071286450071067, 3.3232331287984884, 3.8719511345032886, 4.324591780113119, 5.4900862924918705, 5.5018668278276035, 5.834691623616115, 6.31628258744162, 7.180319020755257]
true
false
add方法是添加节点到树中,取数字集合的第一个数字为整棵树的跟节点。然后依次取后面的数字,从根节点开始进行比较,如果大于节点,就到节点的右子树中进行比较,如果小于根节点,就到节点的左子树中进行比较,直到找不到节点的时候,就在相应位置生成一个新的节点。如果找到和他相同的值的节点,就此节点记录相同值的次数。这样比数字集合第一个数字小的数字都在根节点的左子树中,比他大的数字都在根节点的右子树中。
sort方法是从先取出左子树的节点,取出中间节点,取出右子树节点,如此方式从根节点开始,这样最后得到的是升序的数字集合
search方法是将要查询的数字和中间节点进行比较。比中间节点值大就到右子树中如此查询,反之就到左子树中如此查询。
分享到:
相关推荐
数据结构-二叉树Java实现及其遍历算法,代码示例中实现了中序遍历,简单易学。
在Java中实现二叉树,我们可以自定义一个类来表示树节点,并通过节点之间的连接来构建整个树形结构。这篇博客主要讨论了如何在Java中实现二叉树的基本操作,包括递归和非递归方式的三种遍历顺序:前序遍历、中序遍历...
平衡二叉树Java实现,平衡二叉树Java实现,平衡二叉树Java实现,平衡二叉树Java实现,
总结来说,理解和掌握二叉树以及如何用JAVA实现它们是成为优秀程序员的关键一步。通过实践,你可以更深入地了解数据结构的精髓,提升算法设计能力,并为解决复杂问题打下坚实基础。对于初学者,可以从简单的二叉树...
本文将深入探讨“数据结构 二叉树 java图形界面实现”这一主题,主要围绕二叉树的基本概念、常见操作以及如何在Java环境中结合图形界面进行实现。 首先,二叉树是一种非线性的数据结构,每个节点最多有两个子节点,...
代码实现: 二叉树的查找、插入、删除和输出根节点到当前节点的路径 二叉树的前序遍历,中序遍历和后续遍历 TreeNode.java --定义树节点 Mytree.java----创建树结构和上述功能函数 TestTree.java --测试上述的功能
java二叉树实现 (简单实现,入门用) /**创建二叉树*/ public BinaryTree createTree(String treeStr); /**寻找结点*/ public BinaryTree findNode(BinaryTree tree ,char sign); /**找所给结点的左子树*/ ...
后序遍历的Java实现通常使用栈来辅助操作: ```java public void postOrderTraversal(TreeNode node) { if (node == null) return; Stack<TreeNode> stack = new Stack(); TreeNode prev = null; while (node...
java实现二叉树非递归前序中序后序遍历
在本项目中,“基于JAVA开发的二叉树课程设计与实现”主要涵盖了计算机科学中的数据结构和算法领域,特别是关于二叉树的理论知识、Java编程语言的应用以及软件工程的基本实践。二叉树是一种重要的非线性数据结构,...
在Java中动态实现二叉树,即在运行时根据需要创建、更新和操作树结构,这涉及到对数据结构和Swing组件的深入理解。 首先,二叉树是一种特殊的树形数据结构,每个节点最多有两个子节点,分别称为左孩子和右孩子。...
下面是一些常见的二叉树操作的Java实现示例: 1. **创建二叉树**: 创建二叉树通常从空节点开始,通过插入节点来构造。例如,插入新节点的函数可能如下: ```java public void insert(int val) { root = insert...
编程实现如下功能: 1、假设二叉树的结点值是字符,根据输入的一颗二叉树的标明了空子树的完整先根遍历序列,建立一棵以二叉链表表示的二叉树。 2、对二叉树进行先根、中根和后根遍历操作,并输出遍历序列,同时观察...
总之,Java实现二叉树的最佳方法依赖于对二叉树性质的深入理解以及对Java语言特性的熟练应用。递归构建和遍历是实现二叉树的两个核心方面,它们共同构建了复杂二叉树算法的基石。在实际应用中,还需要考虑树结构的...
数据结构二叉树(Binary Tree)的Java实现; 包括最基本的清空方法/判断为空方法/求树的深度的方法/获得父结点的方法/获得左/右兄弟结点的方法/递归先序/中序/后序遍历二叉树的方法;
文档中是我自己实现的用java语言实现(1)判断给定的二叉树是否平衡;(2)二叉树插入新数据后,如果失衡自我旋转调整的方法。
1:构造一个二叉树 2:二叉树前序遍历(递归) 3:二叉树中序遍历(递归) 4:二叉树后续遍历(递归) 5:二叉树前序遍历(非递归) 6:二叉树中序遍历(非递归) 7:二叉树后序遍历(非递归)
在"二叉树java源码完整"这个项目中,我们可以期待找到用Java实现的二叉树类及其相关方法。源码通常会包括以下部分: 1. **基础定义**:首先,会有一个类(例如`BinaryTree`或者`Node`)来表示二叉树的节点,每个...
在这个Java实现中,我们可以看到一个完整的二叉树可视化系统,包括四个关键的Java源文件:BinaryNode、Show1_12、Display_Tree和TreeControl。 1. **BinaryNode.java**: 这个文件代表二叉树的基本节点。在Java中,...