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

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

题目:回文链表

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

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

    typescript 复制代码
    function isPalindrome(head: ListNode | null): boolean {
      if (!head) {
        return false;
      }
      if (!head.next) {
        return true;
      }
      const stack: number[] = [];
      let tem: ListNode | null = head;
      while (tem) {
        stack.push(tem.val);
        tem = tem.next;
      }
      console.log(stack);
      return stack.join("") === stack.reverse().join("");
    };
  2. 如果这个题目要用递归方法来解,我们要怎么做呢?老规矩

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

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

    typescript 复制代码
    function isPalindrome(head: ListNode | null): boolean {
      // 边界条件提前处理:空链表/单节点直接返回true
      if (head === null || head.next === null) return true;
    
      let frontPointer: ListNode | null = head;
    
      const recursivelyCheck = (currentNode: ListNode | null): boolean => {
        // 终止条件:遍历到尾部,返回true
        if (currentNode === null) return true;
    
        // 递归深入:先遍历到链表末端
        const isNextValid = recursivelyCheck(currentNode.next);
        // 提前短路:后续节点已判定非回文,直接返回false
        if (!isNextValid) return false;
    
        // 核心比较:当前递归节点(从后往前)与前向指针节点(从前往后)
        if (currentNode.val !== frontPointer!.val) return false;
    
        // 前向指针后移
        frontPointer = frontPointer!.next;
    
        return true;
      };
    
      return recursivelyCheck(head);
    }

题目来源:力扣(LeetCode)

相关推荐
逑之2 分钟前
C语言笔记10:sizeof和strlen,指针与数组
c语言·笔记·算法
saoys5 分钟前
Opencv 学习笔记:创建与原图等尺寸的空白图像
笔记·opencv·学习
求梦8206 分钟前
【力扣hot100题】旋转图像(15)
算法·leetcode·职场和发展
C雨后彩虹4 小时前
任务最优调度
java·数据结构·算法·华为·面试
晓幂6 小时前
【2025】HECTF
笔记·学习·web安全
少林码僧6 小时前
2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法
人工智能·python·算法·机器学习·ai·数据挖掘
钱彬 (Qian Bin)6 小时前
项目实践15—全球证件智能识别系统(切换为Qwen3-VL-8B-Instruct图文多模态大模型)
人工智能·算法·机器学习·多模态·全球证件识别
慕云紫英7 小时前
基金申报的一点经验
学习·aigc
微露清风7 小时前
系统性学习C++-第十八讲-封装红黑树实现myset与mymap
java·c++·学习
宝贝儿好7 小时前
【强化学习】第六章:无模型控制:在轨MC控制、在轨时序差分学习(Sarsa)、离轨学习(Q-learning)
人工智能·python·深度学习·学习·机器学习·机器人