「java对二叉树节点」二叉树 java

博主:adminadmin 2022-12-23 11:21:09 59

本篇文章给大家谈谈java对二叉树节点,以及二叉树 java对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

怎样使用java对二叉树进行层次遍历

public class BinaryTree {

 

 int data;      //根节点数据

 BinaryTree left;    //左子树

 BinaryTree right;   //右子树

 

 public BinaryTree(int data)    //实例化二叉树类

 {

  this.data = data;

  left = null;

  right = null;

 }

 

 public void insert(BinaryTree root,int data){     //向二叉树中插入子节点

  if(dataroot.data)                               //二叉树的左节点都比根节点小

  {

   if(root.right==null){

    root.right = new BinaryTree(data);

   }else{

    this.insert(root.right, data);

   }

  }else{                                          //二叉树的右节点都比根节点大

   if(root.left==null){

    root.left = new BinaryTree(data);

   }else{

    this.insert(root.left, data);

   }

  }

 }

}

当建立好二叉树类后可以创建二叉树实例,并实现二叉树的先根遍历,中根遍历,后根遍历,代码如下:

package package2;

public class BinaryTreePreorder {

 

 public static void preOrder(BinaryTree root){  //先根遍历

  if(root!=null){

   System.out.print(root.data+"-");

   preOrder(root.left);

   preOrder(root.right);

  }

 }

 

 public static void inOrder(BinaryTree root){     //中根遍历

  if(root!=null){

   inOrder(root.left);

   System.out.print(root.data+"--");

   inOrder(root.right);

  }

 }

 

 public static void postOrder(BinaryTree root){    //后根遍历

  if(root!=null){

   postOrder(root.left);

   postOrder(root.right);

   System.out.print(root.data+"---");

  }

 }

 

 public static void main(String[] str){

  int[] array = {12,76,35,22,16,48,90,46,9,40};

  BinaryTree root = new BinaryTree(array[0]);   //创建二叉树

  for(int i=1;iarray.length;i++){

   root.insert(root, array[i]);       //向二叉树中插入数据

  }

  System.out.println("先根遍历:");

  preOrder(root);

  System.out.println();

  System.out.println("中根遍历:");

  inOrder(root);

  System.out.println();

  System.out.println("后根遍历:");

  postOrder(root);

二叉树的java实现与几种遍历

二叉树的定义

二叉树(binary tree)是结点的有限集合,这个集合或者空,或者由一个根及两个互不相交的称为这个根的左子树或右子树构成.

从定义可以看出,二叉树包括:1.空树 2.只有一个根节点 3.只有左子树   4.只有右子树  5.左右子树都存在    有且仅有这5种表现形式

二叉树的遍历分为三种:前序遍历 中序遍历 后序遍历

前序遍历:按照“根左右”,先遍历根节点,再遍历左子树 ,再遍历右子树

中序遍历:按照“左根右“,先遍历左子树,再遍历根节点,最后遍历右子树

后续遍历:按照“左右根”,先遍历左子树,再遍历右子树,最后遍历根节点

其中前,后,中指的是每次遍历时候的根节点被遍历的顺序

具体实现看下图:

怎样用Java来体现二叉树(顺便加上注释)

二叉树,和数据库的B树操作流程是一样的,例如:有如下字段

F,C,B,H,K,I;

如果要形成二叉树的话,则,首先取第一个数据作为根节点,所以,现在是 F ,如果字段比根节点小,则保存在左子树,如果比根节点大或者等于根节点则保存在右子树,最后按左---根-----右输出所以数据。

所以,实现的关键就是在于保存的数据上是否存在大小比较功能,而String类中compareTo()有这个能力,节点类要保存两类数据,左节点,右节点

class Node

{

private String data;

private Node left;

private Node right;

public Node (String data){

this.data = data;

}

public void setLeft(Node left) {

this.left = left;

}

public void setRight(Node right){

this.right = right;

}

public String getDate() {

return this.data;

}

public Node getLeft(){

return this.left;

}

public Node getRight(){

return this.right;

}

public void addNode(Node newNode){

if(this.data.compareTo(newNode.data)=0) {

if(this.left == null){

this.left = newNode;

}else {

this.left.addNode(newNode);

}

}else {

if(this.right == null) {

this.right = newNode;

} else {

this.right.addNode(newNode);

}

}

}

public void printNode(){

if(this.left!= null){

this.left.printNode();

}

System.out.println(this.data);

if(this.right != null){

this.right.printNode();

}

}

}

class BinaryTree

{

private Node root = null;

public void add(String data) {

Node newNode = new Node(data);

if(this.root == null) {

this.root = newNode;

}else{

this.root.addNode(newNode);

}

}

public void print() {

this.root.printNode();

}

}

public class Hello

{

public static void main (String args[]) {

BinaryTree link = new BinaryTree();

link.add("F");

link.add("C");

link.add("B");

link.add("H");

link.add("K");

link.add("I");

link.print();

}

}

你一看就英文就知道什么意思了,应该可以理解了

这个二叉树捉摸不透就别琢磨了,开放中一般用不上

}

java二叉树的结点需要定义哪些内容啊?

private class Node{

Data date; //这里存放你需要存放的数据

Node leftNode;//存放该节点的左孩子,如果没有则为NULL;

NOde rightNode;//存放右孩子,没有则为NULL;

//有的树还会存放该节点的父母节点。这个按照需要来设计了

}

java二叉树节点不显示

java二叉树节点不显示

二叉树(Java实现) - 大数据阿嘉的博客 - CSDN博客 - java 二叉树

1. 创建一颗二叉树

2. 前序遍历 2.1先输出当前节点(初始的时候是root节点) 2.2如果左子节点不为空,则递归继续前序遍历 2.3如果右子节点不为空,则递归继续前序

java如何求二叉树中任意两个节点的最大距离

两个节点的距离的定义是这两个节点间边的个数,

比如某个孩子节点和父节点间的距离是1,和相邻兄弟节点间的距离是2,

优化时间空间复杂度。

代码:

void MaxDistance(Tree* root,int deep,int maxdis)

{

if(root)

{

deep=0;

maxdis=0;

}

int l_deep,l_maxdis;

int r_deep,r_maxdis;

if(root-left!=null)

MaxDistance(root-left,l_deep,l_maxdis);

if(root-right!=null)

MaxDistance(root-right,r_deep,r_maxdis);

deep=(l_deepr_deep?l_deep:r_deep)+1;

maxdis=l_maxdisr_maxdis?l_maxdis:r_maxdis;

maxdis=(l_deep+r_deep)maxdis?l_deep+r_deep:maxdis;

}

}

关于java对二叉树节点和二叉树 java的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

The End

发布于:2022-12-23,除非注明,否则均为首码项目网原创文章,转载请注明出处。