算法第八天:leetcode234.回文链表

给你一个单链表的头节点 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) 空间复杂度解决此题?

该题的实现代码如下所示:

java 复制代码
   public boolean isPalindrome(ListNode head) {
        List<Integer> vals=new ArrayList<Integer>();
        ListNode currentNode=head;
        while(currentNode!=null){
            vals.add(currentNode.val);
            currentNode=currentNode.next;
        }
        int slow=0;
        int fast=vals.size()-1;
        while(slow<fast){
            if(!vals.get(slow).equals(vals.get(fast))){
                return false;
            }
            slow++;
            fast--;
        }
        return true;
    }

解题的思路如下:1.复制当前节点的数组到新数组vals中;

2.定义快慢指针,如果slow指针的值不等于fast指针的值,则返回false;

3.慢指针slow从起始位置向末端位置查找,而fast快指针则从末端位置向起始位置开始进行查找。

感谢各位读者的阅读与支持,您的支持是我前进的动力!我希望我的博文能够带给您有用的算法知识和启发。希望本题对大家有帮助,谢谢各位读者的支持!!!

相关推荐
KaMeidebaby1 分钟前
卡梅德生物技术快报|基因测序技术在 46,XY 性发育障碍变异筛查中的流程与数据分析
服务器·前端·数据库·人工智能·算法·数据挖掘·数据分析
摇滚侠1 分钟前
浏览器调试工具 检查元素 谷歌模拟器 控制台 断点调试
java·html
ZengLiangYi3 分钟前
SourceAdapter 插件架构详解
javascript·算法·架构
妄想出头的工业炼药师11 分钟前
特征检测和特征筛选
算法·开源
cxr82812 分钟前
高分子复合材料 AI 逆向设计合——学证明、算法实现、验证数据与学术资源全集
人工智能·线性代数·算法
心之伊始15 分钟前
Spring Boot 接入 MCP 实战:用 Spring AI 调用本地工具的最小闭环
java·spring boot·agent·spring ai·mcp
ZengLiangYi20 分钟前
如何解析 5 种完全不同格式的 AI 对话
javascript·人工智能·算法
Refrain_zc21 分钟前
无触摸屏场景下的蓝牙交互:Android 纯按键蓝牙扫描配对与 A2DP/Headset 连接
java·蓝牙
计算机安禾24 分钟前
【算法设计与分析】第29篇:启发式与元启发式搜索方法综述
java·数据库·算法