java二叉树简易计算机_自己的写简单的二叉树java | 学步园

public class twoTree {

private static Node root;

public class Node{

private int data;

private Node left;

private Node right;

public int getData() {

return data;

}

public void setData(int data) {

this.data = data;

}

public Node getLeft() {

return left;

}

public void setLeft(Node left) {

this.left = left;

}

public Node getRight() {

return right;

}

public void setRight(Node right) {

this.right = right;

}

}

public void insert(int data){

root = creatNode(root,data);

}

public Node creatNode(Node node, int data){

if(node == null){

node = new Node();

node.setData(data);

}else{

if(node.getData()>data){

node.setLeft(creatNode(node.getLeft(),data));

}else{

node.setRight(creatNode(node.getRight(),data));

}

}

return node;

}

/** 只实现有一个节点的删除 */

public boolean delete(int key){

Node current = root;

Node parent = null;

boolean isLeftChild = false;

while (current.getData() != key){

parent = current;

if (key < current.getData()){

current = current.getLeft();

isLeftChild = true;

}else{

current = current.getRight();

isLeftChild = false;

}

}

/** 无子节点 */

if (current.getLeft() == null && current.getRight() == null){

if (current == root){

root = null;

}else if (isLeftChild){

Node del = null;

parent.setLeft(del);

}else{

Node del = null;

parent.setRight(del);

}

}

/**

* 三种情况

* 1仅有右节点

* 2仅有左节点

* 3左右都有

* 符号 && 不是 & 呵呵

*/

/** 仅有右节点 */

else if ((current.getLeft() == null && current.getRight() != null)){

if (current == root){

root = current.getRight();

}else if (isLeftChild){

parent.setLeft(current.getRight());

}else{

parent.setRight(current.getRight());

}

/** 仅有左节点 */

}else if ((current.getLeft() != null && current.getRight() == null)){

if (current == root){

root = null;

}else if (isLeftChild){

parent.setLeft(current.getLeft());

}else{

parent.setRight(current.getLeft());

}

}

return true;

}

public Node find(int key){

Node node = root;

while (node != null){

if (node.getData() == key){

break;

}else if (node.getData() > key){

System.out.println("left"+node.getData());

node = node.getLeft();

}else{

System.out.println("right"+node.getData());

node = node.getRight();

}

}

return node;

}

public void readDatas(int data[]){

for(int i:data){

insert(i);

}

}

public void printTree(){

leftPrinTree(root);

System.out.println();

rightPrinTree(root);

System.out.println();

PrinTree(root);

System.out.println();

delete(78);

System.out.println(">>>>>>>>>>>>>>>>");

leftPrinTree(root);

System.out.println();

rightPrinTree(root);

System.out.println();

PrinTree(root);

//System.out.println(find(45).data+"@@@@@@@@@");

}

/**

* 前序遍历,也叫先根遍历,遍历的顺序是,根,左子树,右子树

* @param node

*/

public void leftPrinTree(Node node){

if(node == null) return ;

System.out.print(node.getData()+",");

leftPrinTree(node.getLeft());

leftPrinTree(node.getRight());

}

/**

* 中序遍历,也叫中根遍历,顺序是 左子树,根,右子树

* @param node

*/

public void rightPrinTree(Node node){

if(node == null) return ;

rightPrinTree(node.getLeft());

System.out.print(node.getData()+",");

rightPrinTree(node.getRight());

}

/**

* 后序遍历,也叫后根遍历,遍历顺序,左子树,右子树,根

* @param node

*/

public void PrinTree(Node node){

if(node == null) return ;

PrinTree(node.getLeft());

PrinTree(node.getRight());

System.out.print(node.getData()+",");

}

public static void main(String []args){

int data [] ={7,12,1,4,50,78,33,55,56,45,46};

twoTree tree = new twoTree();

tree.readDatas(data);

tree.printTree();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java程序员面试中可能会问到二叉树的高度,这是一个常见的问题。二叉树是一种数据结构,它由节点组成,每个节点最多有两个子节点。二叉树的高度表示从根节点到最深节点的距离。以下是Java实现二叉树高度的代码示例: ``` public class BinaryTreeHeight { //定义二叉树节点 class Node { int data; Node left; Node right; public Node(int data) { this.data = data; left = null; right = null; } } //计算二叉树高度的方法 public int getHeight(Node root) { if (root == null) { return 0; } else { int leftHeight = getHeight(root.left); int rightHeight = getHeight(root.right); return Math.max(leftHeight, rightHeight) + 1; } } //测试方法 public static void main(String[] args) { BinaryTreeHeight tree = new BinaryTreeHeight(); Node root = tree.new Node(1); root.left = tree.new Node(2); root.right = tree.new Node(3); root.left.left = tree.new Node(4); root.left.right = tree.new Node(5); System.out.println("二叉树的高度是:" + tree.getHeight(root)); } } ``` 在这个示例中,我们定义了一个Node类来表示二叉树的节点,它包含节点值以及左右子节点。然后,我们定义了一个getHeight()方法来计算二叉树的高度。在计算高度时,我们使用递归来遍历左右子树,并计算它们的高度。最后,我们返回左右子树中较大的高度加1作为二叉树的高度。 在面试中,你可能会被问到如何在二叉树中查找一个节点、如何插入和删除一个节点等问题。因此,在准备Java程序员面试时,建议你熟悉二叉树的基本操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值