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

}
相关推荐
paopaokaka_luck1 分钟前
基于Spring Boot+Vue的吉他社团系统设计和实现(协同过滤算法)
java·vue.js·spring boot·后端·spring
Warren982 小时前
Java Stream流的使用
java·开发语言·windows·spring boot·后端·python·硬件工程
架构师沉默3 小时前
Java优雅使用Spring Boot+MQTT推送与订阅
java·开发语言·spring boot
tuokuac3 小时前
MyBatis 与 Spring Boot版本匹配问题
java·spring boot·mybatis
zhysunny4 小时前
05.原型模式:从影分身术到细胞分裂的编程艺术
java·原型模式
草履虫建模4 小时前
RuoYi-Vue 项目 Docker 容器化部署 + DockerHub 上传全流程
java·前端·javascript·vue.js·spring boot·docker·dockerhub
皮皮林5514 小时前
强烈建议你不要再使用Date类了!!!
java
做一位快乐的码农5 小时前
基于Spring Boot和Vue电脑维修平台整合系统的设计与实现
java·struts·spring·tomcat·电脑·maven
77qqqiqi5 小时前
mp核心功能
java·数据库·微服务·mybatisplus
junjunyi6 小时前
高效实现 LRU 缓存机制:双向链表与哈希表的结合
java·哈希表·双向链表