力扣652. 寻找重复的子树

Problem: 652. 寻找重复的子树

文章目录

题目描述

思路

1.利用二叉树的后序遍历 将原始的二叉树序列化 (之所以利用后序遍历 是因为其在归的过程中是会携带左右子树的节点信息,而这些节点信息正是该解法要利用的东西);

2.在一个哈希表中存储每一个序列化后子树和其出现的次数(初始时设为出现0次,每当有一次重复就将其次数加一);

3.将哈希表中出现次数大于等于1的子树的节点添加到一个结果集合中

复杂度

时间复杂度:

O ( n ) O(n) O(n);其中 n n n二叉树中节点的个数

空间复杂度:

O ( n ) O(n) O(n)

Code

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    // Record all subtrees and the number of occurrences
    Map<String, Integer> memo = new HashMap<>();
    // Record duplicate child root nodes
    List<TreeNode> res = new LinkedList<>();

    /**
     * Find Duplicate Subtrees
     *
     * @param root The root of binary tree
     * @return List<TreeNode>
     */
    public List<TreeNode> findDuplicateSubtrees(TreeNode root) {
        traverse(root);
        return res;
    }

    /**
     * Find Duplicate Subtrees(Implementation function)
     *
     * @param root The root of binary tree
     * @return String
     */
    private String traverse(TreeNode root) {
        if (root == null) {
            return "#";
        }
        String left = traverse(root.left);
        String right = traverse(root.right);

        String subTree = left + "," + right + "," + root.val;

        int freq = memo.getOrDefault(subTree, 0);
        // Multiple repetitions will only be added to the result set once
        if (freq == 1) {
            res.add(root);
        }
        // Add one to the number of
        // occurrences corresponding to the subtree
        memo.put(subTree, freq + 1);
        return subTree;
    }
}
相关推荐
wearegogog12310 小时前
基于 MATLAB 的卡尔曼滤波器实现,用于消除噪声并估算信号
前端·算法·matlab
一只小小汤圆10 小时前
几何算法库
算法
Evand J11 小时前
【2026课题推荐】DOA定位——MUSIC算法进行多传感器协同目标定位。附MATLAB例程运行结果
开发语言·算法·matlab
leo__52011 小时前
基于MATLAB的交互式多模型跟踪算法(IMM)实现
人工智能·算法·matlab
忆锦紫11 小时前
图像增强算法:Gamma映射算法及MATLAB实现
开发语言·算法·matlab
t1987512811 小时前
基于自适应Chirplet变换的雷达回波微多普勒特征提取
算法
guygg8811 小时前
采用PSO算法优化PID参数,通过调用Simulink和PSO使得ITAE标准最小化
算法
老鼠只爱大米11 小时前
LeetCode算法题详解 239:滑动窗口最大值
算法·leetcode·双端队列·滑动窗口·滑动窗口最大值·单调队列
好好沉淀12 小时前
1.13草花互动面试
面试·职场和发展
mit6.82412 小时前
序列化|质数筛|tips|回文dp
算法