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;

    }
}
相关推荐
what丶k1 小时前
深度解析:以Kafka为例,消息队列消费幂等性的实现方案与生产实践
java·数据结构·kafka
爱敲代码的TOM3 小时前
基础算法技巧总结2(算法技巧零碎点,基础数据结构,数论模板)
数据结构·算法
惊讶的猫3 小时前
InnoDB选用B+树作为索引的原因
数据结构·b树
历程里程碑3 小时前
子串-----和为 K 的子数组
java·数据结构·c++·python·算法·leetcode·tornado
liu****3 小时前
Qt进阶实战:事件处理、文件操作、多线程与网络编程全解析
开发语言·网络·数据结构·c++·qt
寄存器漫游者3 小时前
数据结构 二叉树核心概念与特性
数据结构·算法
皮皮哎哟4 小时前
数据结构:从队列到二叉树基础解析
c语言·数据结构·算法·二叉树·队列
一匹电信狗4 小时前
【高阶数据结构】并查集
c语言·数据结构·c++·算法·leetcode·排序算法·visual studio
Hello World . .4 小时前
数据结构:二叉树(Binary tree)
c语言·开发语言·数据结构·vim
DeeplyMind5 小时前
少儿科技启蒙教材:《数据结构启蒙》
数据结构·计算机科学·少儿科技读物·蓝桥杯青少组