import java.util.Queue;
import java.util.LinkedList;
class TreeNode {
int value;
TreeNode left;
TreeNode right;
TreeNode(int value) {
this.value = value;
}
}
public class Main {
//levelOrder创建层序遍历方法
public static void levelOrder(TreeNode root) {
if (root == null) return;
Queue<TreeNode> queue = new LinkedList<>();
queue.offer(root);//offer() 方法用于将元素插入到队列中
while (!queue.isEmpty()) {//当队列不为空时
TreeNode node = queue.poll();
//queue.poll() 是从队列 queue 中移除并返回队列的头部元素。第一次执行时,将根节点取出。
System.out.print(node.value + " ");
if (node.left != null) {
queue.offer(node.left);
}
if (node.right != null) {
queue.offer(node.right);
}
}
}
public static void main(String[] args) {
// 构造一个示例二叉树
TreeNode root = new T
JAVA 二叉树的层序遍历
最新推荐文章于 2024-08-05 11:11:16 发布
本文深入探讨了JAVA中二叉树的层序遍历方法,通过实例解释了levelorder方法的工作原理。首先,当输入root节点1时,输出1。接着,将2、3加入队列并输出2。随后,将4、5、6、7加入队列并输出3。如果只有三层,那么后续输出4,最后输出5、6、7,完成层序遍历。文章还提到了快速建立二叉树并进行层序输出的步骤,包括创建二叉树类、快速读取类、层序输出方法以及构建二叉树的方法。
摘要由CSDN通过智能技术生成