力扣: 回文链表

文章目录

需求

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

示例 1:

输入:head = [1,2,2,1]

输出:true

示例 2:

输入:head = [1,2]

输出:false
提示:

链表中节点数目在范围[1, 105] 内

0 <= Node.val <= 9
进阶:你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?

分析

题意还是挺简单的, 我们可以先把链表遍历一遍, 将链表里的数据存到一个容器里面, 再拿容器里的数据和链表比较就行了, 想这里 , 栈 是再合适不过了, 我说的是数据结构里的栈, 注意不是下图里 的 zhan 啊.

思路到了这里, 其实代码也就跃然纸上了:

java 复制代码
public boolean isPalindrome(ListNode head) {
     //  全部放到栈里
    ListNode temp = head;
    Stack<Integer> stack = new Stack<>();
    while( temp != null ){
        stack.push(temp.val);
        temp = temp.next;
    }
    temp = head;
    while( temp != null ){
       if( temp.val != stack.pop() ){
           return false;
       }
       temp = temp.next;
    }
    return true;
}

代码解释:

首先,定义一个 temp 变量指向链表的头节点 head。

创建一个 Stack 类型的栈 stack,用于存储链表节点的值。

使用 while 循环遍历整个链表,将每个节点的值 temp.val 压入栈中,然后将 temp 移动到下一个节点 temp.next。遍历完成后,栈中保存了链表节点值的逆序。

重新将 temp 指向链表的头节点。

再次使用 while 循环遍历链表:

对于每个节点,弹出栈顶的值,并与当前节点的值进行比较。

如果当前节点的值与弹出的栈顶值不相等,则说明链表不是回文链表,返回 false。

否则,继续遍历下一个节点。

如果所有节点的值与栈中的值都匹配,则说明链表是回文链表,返回 true。

执行结果:

优化下

上面的解答解决了, 但是有些点事可以优化的, 在比较的过程中其实没有必要全部比较啊, 我们只需要拿前一半和后一半比较就行了 , 那么问题的关键就是拿到链表的长度, 然后再拿到中间节点就行了.

java 复制代码
public boolean isPalindrome(ListNode head) {
     //  全部放到栈里
    ListNode temp = head;
    Stack<Integer> stack = new Stack<>();
    int l = 0;
    while( temp != null ){
        stack.push(temp.val);
        temp = temp.next;
        l++;
    }
    temp = head;
    l = l / 2;
    while( l > 0 ){
       if( temp.val != stack.pop() ){
           return false;
       }
       temp = temp.next;
       l--;
    }
    return true;
}

结尾

以上 是我对这道算法的一些遐想和延伸, 可能不是最优解, 但是算法的优化嘛 本身就是一个思索的过程, 能在这个思索和迭代的过程中有所收获和乐趣就是在成长了, 欢迎大家一起来交流更多的解答...

相关推荐
程序员东岸17 小时前
数据结构杂谈:双向链表避坑指南
数据结构·链表
油泼辣子多加18 小时前
【实战】自然语言处理--长文本分类(3)HAN算法
算法·自然语言处理·分类
Shinom1ya_18 小时前
算法 day 46
数据结构·算法
夏鹏今天学习了吗18 小时前
【LeetCode热题100(64/100)】搜索旋转排序数组
算法·leetcode·职场和发展
alphaTao19 小时前
LeetCode 每日一题 2025/11/3-2025/11/9
windows·leetcode
2301_7965125219 小时前
Rust编程学习 - 问号运算符会return一个Result 类型,但是如何使用main函数中使用问号运算符
开发语言·学习·算法·rust
小龙报19 小时前
算法通关指南:数据结构和算法篇 --- 队列相关算法题》--- 1. 【模板】队列,2. 机器翻译
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
晨非辰19 小时前
【数据结构初阶】--从排序算法原理分析到代码实现操作,参透插入排序的奥秘!
c语言·开发语言·数据结构·c++·算法·面试·排序算法
三川69820 小时前
排序算法介绍
数据结构·算法·排序算法
智驱力人工智能1 天前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算