news 2026/5/23 18:53:23

【 每天学习一点算法 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/5/21 6:56:27

薄膜光学与镀膜技术高清版PDF资源深度解析

薄膜光学与镀膜技术高清版PDF资源深度解析 【免费下载链接】薄膜光学与镀膜技术高清版PDF分享 薄膜光学与镀膜技术 高清版PDF 项目地址: https://gitcode.com/Open-source-documentation-tutorial/c516c 📚 光学领域的经典之作 今天为大家带来一本光学领域的…

作者头像 李华
网站建设 2026/5/21 5:31:17

弹药库房 “感知 - 传输 - 平台 - 应用” 四层架构温湿度监控方案

弹药库房温湿度监控系统技术方案弹药库房温湿度监控一、项目背景与需求1. 项目背景弹药库房存储的弹药、火工品等物资对温湿度环境具有严格要求(参考国家《弹药安全管理条例》:温度 15-25℃,相对湿度 45-65% RH),温湿度…

作者头像 李华
网站建设 2026/5/22 20:13:08

豆包手机为什么会被其他厂商抵制?它的工作原理是什么?

之所以会想写这个,首先是因为在知乎收到了这个推荐的问题,实际上不管是 AutoGLM 还是豆包 AI 手机,会在这个阶段被第三方厂商抵制并不奇怪,比如微信和淘宝一直以来都很抵制这种外部自动化操作,而非这次中兴的 AI 豆包手…

作者头像 李华
网站建设 2026/5/21 21:48:13

Fritzing:从电路新手到专业设计师的3大核心功能解析

Fritzing:从电路新手到专业设计师的3大核心功能解析 【免费下载链接】fritzing-app Fritzing desktop application 项目地址: https://gitcode.com/gh_mirrors/fr/fritzing-app 还在为复杂的电路图而头疼吗?是否希望有一款工具能够像搭积木一样轻…

作者头像 李华