【数据结构】二叉树相关oj题(一)

简介: 【数据结构】二叉树相关oj题(一)

1、二叉树的构建及遍历

1.1、题目介绍



示例1:


输入:abc##de#g##f###


输出:c b e g d f a


1.2、解题思路

根据题意可知,读入的字符串是一串先序遍历字符串,那么根据字符串创建二叉树也就需要遵循先序遍历进行创建。


1.3、代码描述

首先自行定义一个TreeNode类


class TreeNode {
    public char val;
    public TreeNode left;
    public TreeNode right;
    public TreeNode(char val) {
        this.val = val;
    }
}

因为递归创建,为了确保str能够正常遍历结束,因此这里定义一个成员变量 i 用于记录str当前访问的位置。


char ch = str.charAt(i++); 此时当ch不为#时再创建节点root,并且对左孩子和右孩子分别进行递归创建。
    public static int i = 0;
    public static TreeNode createTree(String str) {
        if(str == null) {
            return null;
        }
        TreeNode root = null;
        char ch = str.charAt(i++);
        if(ch != '#') {
            root = new TreeNode(ch);
            root.left = createTree(str);
            root.right = createTree(str);
        } 
        return root;
    }

最后执行中序遍历将结果打印出来即可


 

public static void inOrder(TreeNode root) {
        if(root == null) {
            return;
        }
        inOrder(root.left);
        System.out.print(root.val + " ");
        inOrder(root.right);
    }

1.4、完整代码

import java.util.Scanner;
class TreeNode {
    public char val;
    public TreeNode left;
    public TreeNode right;
    public TreeNode(char val) {
        this.val = val;
    }
}
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String str = in.nextLine();
        //创建二叉树
        TreeNode root = createTree(str);
        //中序遍历二叉树
        inOrder(root);
    }
    public static int i = 0;
    public static TreeNode createTree(String str) {
        if(str == null) {
            return null;
        }
        TreeNode root = null;
        char ch = str.charAt(i++);
        if(ch != '#') {
            root = new TreeNode(ch);
            root.left = createTree(str);
            root.right = createTree(str);
        } 
        return root;
    }
   
    public static void inOrder(TreeNode root) {
        if(root == null) {
            return;
        }
        inOrder(root.left);
        System.out.print(root.val + " ");
        inOrder(root.right);
    }
}


2、二叉树的层次遍历

2.1、题目介绍


示例1:



输入:root = [3,9,20,null,null,15,7]

输出:[[3],[9,20],[15,7]]


示例2:


输入:root = [1]

输出:[[1]]


示例3:


输入:root = []

输出:[]


提示:


树中节点数目在范围 [0, 2000] 内

-1000 <= Node.val <= 1000

2.2、解题思路

       层次遍历需要使用到队列,利用队列先进先出的特性使遍历能够从上到下,从左到右顺序遍历。该题唯一的难点就是返回值的规范。


       题目中要求返回的是List<List<Integer>>,从示例中可以看出,每一层的节点分别使用有一个List来存储,这就要求我们不仅需要实现层序遍历,还需要将遍历结果按照层数划分。


2.3、代码描述

首先实现层次遍历,判断root不等于null后执行以下代码,将root入队之后,观察队列状况,当队列不为空时将节点出队,并判断出队节点是否存在左右节点,如果存在则入队。依次执行循环后最终得到打印结果就为层次遍历结果。


   

Queue<TreeNode> queue = new LinkedList<>();
        queue.add(root);
        while(!queue.isEmpty()) {
            TreeNode cur = queue.poll();
            //此处对cur.val执行打印操作,打印的顺序就是层次遍历顺序
            System.out.print(root.val + " ");
            if(cur.left != null) {
                queue.add(cur.left);
            }
            if(cur.right != null) {
                queue.add(cur.right);
            }
        }

假设二叉树的结构如下:




       通过画图可以观察到,当将1入队后,此时队长为1。然后1出队后将2,3入队 ,此时队长为2。然后2出队4,5入队,3出队6入队,此时队长为3。


       相信大家都看出规律了,即每当执行完一组入队操作之后,此时队列的长度就等于层数个数。根据这个规律,我们可以在每次while循环的开始计算此时队列的长度,用于记录该层需要出队的次数,从而确定每一层的节点,并将其存放到list中,最后当while循环结束时将list添加到retList中。



具体优化后的代码如下文的【完整代码】


2.4、完整代码

class Solution {
    public List<List<Integer>> levelOrder(TreeNode root) {
        List<List<Integer>> retList = new LinkedList<>();
        if(root == null) {
            return retList;
        }
        Queue<TreeNode> queue = new LinkedList<>();
        queue.add(root);
        while(!queue.isEmpty()) {
            List<Integer> list = new LinkedList<>();   //存放一层节点的集合List
            int size = queue.size();   //每次计算队列长度
            while(size --> 0) {   //每完成一次出队,size自减1
                TreeNode cur = queue.poll();
                list.add(cur.val);   
                if(cur.left != null) {
                    queue.add(cur.left);
                }
                if(cur.right != null) {
                    queue.add(cur.right);
                }
            }
            retList.add(list);  //将一层的节点添加到返回集合retList中
        }
        return retList;
    }
}
目录
相关文章
|
9月前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
296 10
 算法系列之数据结构-二叉树
|
10月前
|
DataX
☀☀☀☀☀☀☀有关栈和队列应用的oj题讲解☼☼☼☼☼☼☼
### 简介 本文介绍了三种数据结构的实现方法:用两个队列实现栈、用两个栈实现队列以及设计循环队列。具体思路如下: 1. **用两个队列实现栈**: - 插入元素时,选择非空队列进行插入。 - 移除栈顶元素时,将非空队列中的元素依次转移到另一个队列,直到只剩下一个元素,然后弹出该元素。 - 判空条件为两个队列均为空。 2. **用两个栈实现队列**: - 插入元素时,选择非空栈进行插入。 - 移除队首元素时,将非空栈中的元素依次转移到另一个栈,再将这些元素重新放回原栈以保持顺序。 - 判空条件为两个栈均为空。
|
11月前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
335 12
|
11月前
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
193 10
|
11月前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
500 3
|
12月前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
机器学习/深度学习 存储 算法
数据结构实验之二叉树实验基础
本实验旨在掌握二叉树的基本特性和遍历算法,包括先序、中序、后序的递归与非递归遍历方法。通过编程实践,加深对二叉树结构的理解,学习如何计算二叉树的深度、叶子节点数等属性。实验内容涉及创建二叉树、实现各种遍历算法及求解特定节点数量。
332 4
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
986 8
|
存储 算法 关系型数据库
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
这篇文章主要介绍了多路查找树的基本概念,包括二叉树的局限性、多叉树的优化、B树及其变体(如2-3树、B+树、B*树)的特点和应用,旨在帮助读者理解这些数据结构在文件系统和数据库系统中的重要性和效率。
181 0
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
|
存储 算法 搜索推荐
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
这篇文章主要介绍了顺序存储二叉树和线索化二叉树的概念、特点、实现方式以及应用场景。
304 0
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树

热门文章

最新文章