java二叉树怎么初始化_java实现二叉树常见操作

packagecom.xk.test.struct.newp;importjava.util.ArrayList;importjava.util.LinkedList;importjava.util.Queue;importjava.util.Stack;public classMyBinaryTree {/*** 插入节点*@paramroot*@paramnode*@return*/TreeN...
摘要由CSDN通过智能技术生成

packagecom.xk.test.struct.newp;importjava.util.ArrayList;importjava.util.LinkedList;importjava.util.Queue;importjava.util.Stack;public classMyBinaryTree {/*** 插入节点

*@paramroot

*@paramnode

*@return

*/TreeNode insertNode(TreeNode root,TreeNode node){if(root ==node){returnnode;

}

TreeNode tmp= newTreeNode();

tmp=root;

TreeNode last= null;while(tmp!=null){

last=tmp;if(tmp.val>node.val){

tmp=tmp.left;

}else{

tmp=tmp.right;

}

}if(last!=null){if(last.val>node.val){

last.left=node;

}else{

last.right=node;

}

}returnroot;

}/*** 递归解法前序遍历

*@paramroot

*@return

*/ArrayListpreOrderReverse(TreeNode root){

ArrayList result = new ArrayList();

preOrder2(root,result);returnresult;

}void preOrder2(TreeNode root,ArrayListresult){if(root == null){return;

}

result.add(root.val);

preOrder2(root.left,result);

preOrder2(root.right,result);

}/*** 迭代解法前序遍历

*@paramroot

*@return

*/ArrayListpreOrder(TreeNode root){

Stack stack = new Stack();

ArrayList list = new ArrayList();if(root == null){returnlist;

}

stack.push(root);while(!stack.empty()){

TreeNode node=stack.pop();

list.add(node.val);if(node.right!=null){

stack.push(node.right);

}if(node.left != null){

stack.push(node.left);

}

}returnlist;

}/*** 中序遍历

*@paramroot

*@return

*/ArrayListinOrder(TreeNode root){

ArrayList list = new ArrayList();

Stack stack = new Stack();

TreeN

  • 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、付费专栏及课程。

余额充值