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;
    }

}
相关推荐
苏瞳儿2 小时前
java对数据库的增删改查
java·数据库·oracle
zhangjw342 小时前
Java基础语法:变量、数据类型与运算符,从原理到实战
java·开发语言
yaoxin5211235 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
NotFound4865 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
一 乐7 小时前
医院挂号|基于springboot + vue医院挂号管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·医院挂号管理系统
鱼鳞_7 小时前
Java学习笔记_Day29(异常)
java·笔记·学习
烟锁池塘柳07 小时前
一文讲透 C++ / Java 中方法重载(Overload)与方法重写(Override)在调用时机等方面的区别
java·c++·面向对象
一叶飘零_sweeeet7 小时前
深入拆解 Fork/Join 框架:核心原理、分治模型与参数调优实战
java·并发编程
云烟成雨TD7 小时前
Spring AI Alibaba 1.x 系列【23】短期记忆
java·人工智能·spring
摇滚侠8 小时前
帮我整理一份 IDEA 开发中常用快捷键
java·ide·intellij-idea