234.回文链表

给你一个单链表的头节点 head ,请你判断该链表是否为

回文链表。如果是,返回 true ;否则,返回 false

一:

复杂度:n n

java 复制代码
puclic boolean isPalindrome(ListNode head){
    // 使用集合而不是array,可以避免创建数组前要先获取链表的长度问题
    List<Integer> list = new ArrayList<>();
    while(head != null){
        list.add(head.val);
        head = head.next;
    }
    int l = 0, r = list.size() - 1;
    while(l < r){
        if(list.get(l++) != list.get(r--)) return false;
    }
    return true;
}

二:

将链表的后半部分反转,判断前后部分是否相等

复杂度:n 1

java 复制代码
class Solution {
    public boolean isPalindrome(ListNode head) {
       //  
        int len = 0;
        ListNode pre = head;
        while(pre != null){
            len++;
            pre = pre.next;
        }
        
        // if(len != 1 && len % 2 == 1) return false;
        pre = head;
        for(int i = 0; i < len / 2; i++){
            pre = pre.next;
        }
        ListNode pre0 = pre, next = pre.next;
        pre0.next = null;
        while(next != null){
            pre0 = next;
            next = pre0.next;
            pre0.next = pre;
            pre = pre0;
        }
        while(pre != null){
            if(head.val != pre.val) return false;
            head = head.next;
            pre = pre.next;
        }
        return true;

    }
}
相关推荐
数智化精益手记局2 分钟前
4m变更管理实战:拆解4m变更管理四大要素的管控功能与常见难题
大数据·数据结构·数据库·人工智能·精益工程
agilearchitect34 分钟前
Matlab导入Excel表格教程:从基础到进阶全攻略
数据结构·其他·matlab·excel
xieliyu.39 分钟前
Java手搓数据结构:从零模拟实现单向无头非循环链表
java·数据结构·学习·链表
爱写代码的倒霉蛋1 小时前
2021天梯赛L2-4真题解析
数据结构·算法
white-persist1 小时前
逆向入门经典题:从 IDA 反编译坑点到 Python 解题详细分析解释
c语言·开发语言·数据结构·python·算法·逆向·安全架构
北顾笙9802 小时前
day30-数据结构力扣
数据结构·算法·leetcode
01二进制代码漫游日记2 小时前
【C语言数据结构】之解锁双向链表(指定位置插入、删除节点、查找、销毁链表等操作)
c语言·数据结构·链表
Engineer邓祥浩3 小时前
知识点1 时间复杂度、空间复杂度
java·数据结构·算法
博界IT精灵3 小时前
森林和二叉树的转换(哈喜老师)
数据结构
Severus_black3 小时前
算法题C——用队列实现栈/用栈实现队列
c语言·数据结构·算法·链表