LC1457. 二叉树中的伪回文路径

Problem: 1457. 二叉树中的伪回文路径

题目

给你一棵二叉树,每个节点的值为 1 到 9 。我们称二叉树中的一条路径是 「伪回文」的,当它满足:路径经过的所有节点值的排列中,存在一个回文序列。

请你返回从根到叶子节点的所有路径中 伪回文 路径的数目。

示例

输入:root = 2,3,1,3,1,null,1 输出:2

解释:上图为给定的二叉树。总共有 3 条从根到叶子的路径:红色路径 2,3,3 ,绿色路径 2,1,1 和路径 2,3,1

在这些路径中,只有红色和绿色的路径是伪回文路径,因为红色路径 2,3,3 存在回文排列 3,2,3 ,绿色路径 2,1,1 存在回文排列 1,2,1

文章目录

思路

检查每条路径是否为伪回文串,先明确伪回文串的判定:每个数都出现偶数次或只有某一个数出现奇数次(这道题好像只有出现1次的情况),这样就可以通过改变顺序构造出一个回文串,之后通过回溯的方法取得每一条路径上的数字,用哈希表统计,并检查是否符合要求;

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 {
    int ans=0;
    public int pseudoPalindromicPaths (TreeNode root) {
        int[] hs= new int[10];
        backTracking(root,hs);
        return ans;
    }

    public void backTracking(TreeNode root,int[] hs){
        if(root==null) return;

        hs[root.val]++;

        if(root.left==null&&root.right==null) ans+=check(hs);

        backTracking(root.left,hs);
        backTracking(root.right,hs);
        
        hs[root.val]--;
        return;

    }

    public int check(int[] hs){
        int sum=0;
        for(int i:hs){
            sum+=i%2;
        }
        if(sum<=1) return 1;
        return 0;
    }

}
相关推荐
Flittly17 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了17 小时前
Java 生成二维码解决方案
java·后端
人活一口气1 天前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP1 天前
Vibe Coding -- 完整项目案例实操
java
荣码1 天前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing1 天前
Google第三方授权登录
java·后端·程序员
明月光8181 天前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯1 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路2 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java