news 2026/1/31 19:00:03

【 每天学习一点算法 2025/12/12】回文链表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【 每天学习一点算法 2025/12/12】回文链表

每天学习一点算法 2025/12/12

题目:回文链表

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

  1. 首先想到的方法就是将链表的值放到数组中再看他们是不是回文。

    functionisPalindrome(head:ListNode|null):boolean{if(!head){returnfalse;}if(!head.next){returntrue;}conststack:number[]=[];lettem:ListNode|null=head;while(tem){stack.push(tem.val);tem=tem.next;}console.log(stack);returnstack.join("")===stack.reverse().join("");};
  2. 如果这个题目要用递归方法来解,我们要怎么做呢?老规矩

    递:这个没啥好说,终止条件就是遍历完链表

    归:我们这个时候回归处理就是从倒数节点开始处理了对吧?我们在归的过程中用另外一个指针从前往后移动,这样就是可以完成回文的比较了

    functionisPalindrome(head:ListNode|null):boolean{// 边界条件提前处理:空链表/单节点直接返回trueif(head===null||head.next===null)returntrue;letfrontPointer:ListNode|null=head;constrecursivelyCheck=(currentNode:ListNode|null):boolean=>{// 终止条件:遍历到尾部,返回trueif(currentNode===null)returntrue;// 递归深入:先遍历到链表末端constisNextValid=recursivelyCheck(currentNode.next);// 提前短路:后续节点已判定非回文,直接返回falseif(!isNextValid)returnfalse;// 核心比较:当前递归节点(从后往前)与前向指针节点(从前往后)if(currentNode.val!==frontPointer!.val)returnfalse;// 前向指针后移frontPointer=frontPointer!.next;returntrue;};returnrecursivelyCheck(head);}

题目来源:力扣(LeetCode)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/22 17:05:53

降本增效利器!腾讯云云服务器成本优势全解析

对于企业而言,数字化转型的核心诉求之一便是降本增效。传统自建数据中心模式存在前期投入大、运维成本高、资源利用率低等诸多痛点,而腾讯云云服务器通过创新的计费模式、硬件优化和资源调度能力,大幅降低了企业的IT总体拥有成本(…

作者头像 李华
网站建设 2026/1/27 10:48:34

如何5分钟搭建跨平台窗口监控系统:终极工具完全指南

如何5分钟搭建跨平台窗口监控系统:终极工具完全指南 【免费下载链接】active-win Get metadata about the active window (title, id, bounds, owner, etc) 项目地址: https://gitcode.com/gh_mirrors/ac/active-win 在前100字内,我们为您介绍一款…

作者头像 李华
网站建设 2026/1/29 17:37:51

NotchDrop:让MacBook刘海变身智能文件中转站

NotchDrop:让MacBook刘海变身智能文件中转站 【免费下载链接】NotchDrop Use your MacBooks notch like Dynamic Island for temporary storing files and AirDrop 项目地址: https://gitcode.com/gh_mirrors/no/NotchDrop 你是否曾想过,那个占据…

作者头像 李华
网站建设 2026/1/28 16:16:10

5亿参数改写边缘智能规则:腾讯Hunyuan-0.5B-Instruct轻量化模型深度解析

5亿参数改写边缘智能规则:腾讯Hunyuan-0.5B-Instruct轻量化模型深度解析 【免费下载链接】Hunyuan-0.5B-Instruct 腾讯开源高效大语言模型Hunyuan-0.5B-Instruct,专为指令优化而生。它支持256K超长上下文理解与双模式推理,兼具高效推理与强大…

作者头像 李华
网站建设 2026/1/23 6:38:35

如何快速解决Nacos数据库升级冲突:5个实用技巧

如何快速解决Nacos数据库升级冲突:5个实用技巧 【免费下载链接】nacos Nacos是由阿里巴巴开源的服务治理中间件,集成了动态服务发现、配置管理和服务元数据管理功能,广泛应用于微服务架构中,简化服务治理过程。 项目地址: https…

作者头像 李华
网站建设 2026/1/19 15:44:30

高密度互连板层压创新:从任意层互连到微孔填充技术

高密度互连板的层压技术已超越传统的粘合功能,演进为实现微米级互连的关键赋能者。随着5G毫米波天线与人工智能处理器对布线密度的需求突破每平方厘米万线级别,层压工艺需同步解决介厚均匀性、微孔对准及材料兼容性三重挑战。现代HDI板层压的核心&#x…

作者头像 李华