【LeetCode:1457. 二叉树中的伪回文路径 | 二叉树 + DFS +回文数】

| 🚀 算法题 🚀 |
🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域新星创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯
| 🚀 算法题 🚀 |


🍔 目录
- 🚩 题目链接
- ⛲ 题目描述
- 🌟 求解思路&实现代码&运行结果
- ⚡ 二叉树 + DFS
- 🥦 求解思路
- 🥦 实现代码
- 🥦 运行结果
- 💬 共勉
🚩 题目链接
- 1457. 二叉树中的伪回文路径
⛲ 题目描述
给你一棵二叉树,每个节点的值为 1 到 9 。我们称二叉树中的一条路径是 「伪回文」的,当它满足:路径经过的所有节点值的排列中,存在一个回文序列。
请你返回从根到叶子节点的所有路径中 伪回文 路径的数目。
示例 1:

输入: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] 。
示例 2:

输入:root = [2,1,1,1,3,null,null,null,null,null,1]
输出:1
解释:上图为给定二叉树。总共有 3 条从根到叶子的路径:绿色路径 [2,1,1] ,路径 [2,1,3,1] 和路径 [2,1] 。
这些路径中只有绿色路径是伪回文路径,因为 [2,1,1] 存在回文排列 [1,2,1] 。
示例 3:
输入:root = [9]
输出:1
提示:
给定二叉树的节点数目在范围 [1, 105] 内
1 <= Node.val <= 9
🌟 求解思路&实现代码&运行结果
⚡ 二叉树 + DFS
🥦 求解思路
- 考察点1:树的深度优先遍历,找到从根节点到叶子节点的所有节点。
- 考察点2:怎么判断一条路径中的节点是否是一个回文路径呢?计数,如果一个路径中某一个数字出现的次数是偶数,那么忽略,如果是奇数,至少容忍一次,多于一次,不可以构成回文路径。
- 考察点3:什么是回文序列,就是正着读,和反着读都一样,构成回文序列。
- 具体实现代码如下:
🥦 实现代码
/*** 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 {public int pseudoPalindromicPaths (TreeNode root) {int[] cnt=new int[10];return process(root,cnt);}public int process(TreeNode root,int[] cnt){if(root==null) return 0;cnt[root.val]++;int ans=0;if(root.left==null&&root.right==null){int dif=0;for(int i=0;i<cnt.length;i++){if(cnt[i]%2==1) dif++;}ans=dif<=1?1:0;}else{ans=process(root.left,cnt)+process(root.right,cnt);}cnt[root.val]--;return ans;}
}
🥦 运行结果

💬 共勉
| 最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |


相关文章:
【LeetCode:1457. 二叉树中的伪回文路径 | 二叉树 + DFS +回文数】
🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…...
《golang设计模式》第三部分·行为型模式-06-备忘录模式(Memento)
文章目录 1. 概述1.1 角色1.2 类图 2. 代码示例2.1 设计2.2 代码2.3 类图 1. 概述 备忘录(Memento)用于在不破坏目标对象封装特性的基础上,将目标对象内部的状态存储到外部对象中,以备之后恢复状态时使用。 1.1 角色 Originato…...
Cache学习(4):Cache分配策略Cache更新策略Cache逐出策略
Cache的数据流 常用名词 Allocation 分配Eviction 驱逐分配策略和更新策略分别为当产生Cache miss和Cache hit的时候数据流的具体行为 1 Cache分配策略(Cache Allocation Policy) Cache的分配策略是指不同情况下为数据分配Cache Line的不同行为。Cac…...
角色管理--产品经理岗
研发组织管理--角色管理--产品经理岗 定位 相对稳定和简单产品的独立产品打造者,复杂产品的辅助者 所需资质 校招新人,拥有灵性拥有基础的产品力(认知,设计,创新,推进,学习)Axur…...
SQL数据迁移实战:从产品层级信息到AB测试表
文章目录 创建表插入数据清空数据表数据迁移和筛选查询数据结论 创建表 首先,代码中定义了两个表格:dim_prod_hierarchy_info 和 app_abtest_product_info,都位于 test 数据库中。 dim_prod_hierarchy_info 表用于存储产品层级信息…...
VMware系列:VMware安装Android虚拟机
VMware系列:VMware安装Android虚拟机 一. 下载镜像这里提供了三种下载镜像方式,也就是三个下载链接,这里推荐百度网盘下载二. 使用VMware Workstation Pro 创建新的虚拟机操作系统应该可以选择任意一个,笔者只试过下图中,如果读者感兴趣可以多试几个,但笔者不保证每个都可…...
链接1:编译器驱动程序
文章目录 GNU编译器示例编译 GNU编译器 GNU编译器(GNU Compiler)是由自由软件基金会(Free Software Foundation,FSF)开发和维护的一套编译器集合。这些编译器主要用于编译各种编程语言的源代码,将其转换为…...
经典滑动窗口试题(二)
📘北尘_:个人主页 🌎个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上,不忘来时的初心 文章目录 一、水果成篮1、题目讲解2、讲解算法思路3、代码实现 二、找到字符串中所有字母异位词1、题目…...
easyexcel指定sheet页动态给行列加背景色
需求 1、easyexcel,有多个sheet页,某些sheet页的行、列动态需要加背景色。 2、扩展支持cellStyle标记单元格超过64000 import com.alibaba.excel.metadata.CellData; import com.alibaba.excel.metadata.Head; import com.alibaba.excel.write.handler.…...
设计模式在实际业务中应用 - 模版方法
1. 业务背景 作者在工作中主要主导 A 业务线的系统建设,A 业务线主要是零售场景酒水的售卖与即时配送服务。为了方便运营在自研系统中对多平台商品进行管理而开发的三方平台商品管理功能,本次介绍的模版方法模式则是在该功能开发过程中的落地实践。 2.…...
BGP综合实验
任务如下: 1.AS1存在两个环回,一个地址为192.168.1.0/24该地址不能在任何协议中宣告 AS3存在两个环回,一个地址为192.168.2.0/24该地址不能在任何协议中宣告,最终要求这两个环回可以互相通讯 2.整个AS2的IP地址为172.16.0.0/16&…...
Global Surface Summary of the Day 全球逐日气象站点数据 GSOD数据集
数据名称 Global Surface Summary of the Day 数据内容 数据包含以下气象要素的日值观测数据: 气压:平均气压、海平面气压;气温:平均气温、日最高气温、日最低气温;湿度:露点温度(需自行换算…...
Harmony OS4开发入门
代码地址: https://gitee.com/BruceLeeAdmin/harmonyos/tree/master 项目目录介绍 ArkTS介绍 简单案例: State times: number 0/*数据类型:stringnumberany: 不确定类型,可以是任意类型*/State msg: string "hello"…...
.net core 事务
在 .NET Core 中,可以使用 Entity Framework Core 来实现事务处理。下面是一个简单的示例,展示了如何在 .NET Core 中使用 Entity Framework Core 来创建和执行事务: using System; using Microsoft.EntityFrameworkCore; using System.Tran…...
【Python】python天气数据抓取与数据分析(源码+论文)【独一无二】
👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉公众号👈:测试开发自动化【获取源码商业合作】 👉荣__誉👈:阿里云博客专家博主、5…...
MPPT工作流程及算法和硬件的选择
MPPT算法选择 目前,MPPT算法有开路电压比率(离线)、短路电流比率(离线)、观察调节(在线)、极限追踪控制法(在线)。 在光伏控制系统中,因为日照、温度等条件的变化,光伏电池的输出功率也是在不断变化的,为保证使得光伏电池的输出功…...
C#,《小白学程序》第十九课:随机数(Random)第六,随机生成任意长度的大数(BigInteger)
1 文本格式 using System; using System.Linq; using System.Text; using System.Collections.Generic; /// <summary> /// 大数的(加减乘除)四则运算、阶乘运算 /// 乘法计算包括小学生算法、Karatsuba和Toom-Cook3算法 /// 除法运算为 Truffer…...
每日一练【移动零】
一、题目描述 283. 移动零 - 力扣(LeetCode) 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。 二、题目解析 可以…...
QT修改windowTitle的名字以及图片
1.修改名字:点击ui的QMainWindow,然后找到windowTitle的选项修改即可 2.修改windowTitle的图片,依旧是找到windowIcon,选择资源,这个资源可以是你放到qrc里面的图片也可以是外置的图片 3.然后运行就可以看到效果了...
C语言-指针讲解(3)
文章目录 1.字符指针变量1.1 字符指针变量类型是什么1.2字符指针变量的两种使用方法:1.3字符指针笔试题讲解1.3.1 代码解剖 2.数组指针变量2.1 什么是数组指针2.2 数组指针变量是什么?2.2.3 数组指针变量的举例 2.3数组指针和指针数组的区别是什么&#…...
[具身智能-354]:定制化无人机系统的组成
无人机系统整体采用“平台-链路-指控-保障”一体化架构,主要由以下核心分系统、软件数字架构及配套接口模块构成:一、 无人机飞行平台机体与起降结构:高强度轻量化机身、起落架及高原/大风环境适应性设计,支撑安全起降与地面滑行。…...
造相Z-Image文生图模型v2快速上手:从部署到出图只需3步
造相Z-Image文生图模型v2快速上手:从部署到出图只需3步 1. 为什么选择Z-Image文生图模型 如果你正在寻找一款能在消费级显卡上运行的高质量文生图模型,Z-Image v2绝对值得考虑。作为阿里通义万相团队开源的最新作品,这个20亿参数的模型在24…...
小白也能搞定的语义搜索:Qwen3-Embedding-4B极简部署与使用全攻略
小白也能搞定的语义搜索:Qwen3-Embedding-4B极简部署与使用全攻略 1. 引言:为什么你需要语义搜索 想象一下,你在公司内部知识库搜索"如何提高客户满意度",传统搜索只能找到包含这几个关键词的文档。但如果有一份文档标…...
Sunshine终极指南:5个步骤搭建你的免费游戏串流服务器
Sunshine终极指南:5个步骤搭建你的免费游戏串流服务器 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 想要在客厅电视、平板电脑甚至手机上流畅玩PC大作吗?…...
手把手教你用Qwen3-ASR-0.6B:上传音频秒出文字,无需代码配置
手把手教你用Qwen3-ASR-0.6B:上传音频秒出文字,无需代码配置 还在为语音转文字发愁吗?下载软件、配置环境、调试代码、处理报错……一套流程下来,热情早就被消磨殆尽了。今天,我要给你介绍一个完全不同的体验…...
Qwen3Guard-Gen-WEB快速体验:网页界面一键审核内容安全
Qwen3Guard-Gen-WEB快速体验:网页界面一键审核内容安全 1. 为什么选择Qwen3Guard-Gen-WEB? 1.1 内容安全审核的痛点 在AI应用开发过程中,内容安全审核往往成为项目落地的最后一道障碍。传统方案面临三大挑战: 技术门槛高&…...
Phi-3-mini-128k-instruct在WSL2中的部署详解:Windows开发者的福音
Phi-3-mini-128k-instruct在WSL2中的部署详解:Windows开发者的福音 如果你是一名Windows开发者,想体验最新的AI模型,但又不想折腾双系统或者虚拟机,那今天这篇文章就是为你准备的。我们一起来聊聊怎么在Windows自带的WSL2里&…...
Kotaemon镜像实战:快速搭建技术支持智能问答机器人
Kotaemon镜像实战:快速搭建技术支持智能问答机器人 1. Kotaemon镜像简介 Kotaemon是由Cinnamon开发的开源项目,它是一个专注于文档问答(DocQA)的RAG UI界面。这个镜像为终端用户和开发者提供了一个开箱即用的解决方案,帮助快速搭建基于检索…...
手把手教你用bert-base-chinese:完型填空、语义相似度、特征提取一键体验
手把手教你用bert-base-chinese:完型填空、语义相似度、特征提取一键体验 1. 快速认识bert-base-chinese bert-base-chinese是Google专门为中文文本处理开发的预训练模型,它就像是一个"中文语言理解专家",经过海量中文文本的训练…...
卡证检测矫正模型在政务场景的应用:自动化表单信息录入系统
卡证检测矫正模型在政务场景的应用:自动化表单信息录入系统 每次去办事大厅,最头疼的是什么?对我来说,就是填表。身份证、户口本、房产证……一堆证件摆在面前,工作人员要一张张看,一个个字往电脑里敲。队…...
