234. 回文链表

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public boolean isPalindrome(ListNode head) {
        ListNode fast = head;
        ListNode slow = head;
        while(fast != null && fast.next != null){
            fast = fast.next.next;
            slow = slow.next;
        }
        // 链表为奇数个节点
        if(fast != null){
            slow = slow.next;
        }
        fast = head;
        slow = reverse(slow);
        while(slow!=null && fast!=null){
            if(slow.val != fast.val)
                return false;
            slow = slow.next;
            fast = fast.next;
        }
        return true;

    }

    public ListNode reverse(ListNode head){
        ListNode pre = null;
        ListNode cur = head;
        ListNode next;
        while(cur!=null){
            next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
        return pre;
    }
}

题解:
快慢指针+链表反转

先用快慢指针,快指针走两步,慢指针走一步,快指针走完之后,慢指针要不指向后一半的第一个节点(偶数个节点),要不指向最中间的一个节点(奇数个节点),再对后半个链表进行反转,对前后链表进行判断,如果有不一样的值,则不是回文链表。

相关推荐
拾光Ծ2 小时前
【数据结构】二叉树接口实现指南:递归方法的高效运用 (附经典算法OJ)
数据结构·算法
2501_901245532 小时前
二叉树的概念以及二叉树的分类,添加,删除
数据结构
焊锡与代码齐飞4 小时前
嵌入式第十八课!!数据结构篇入门及单向链表
c语言·数据结构·学习·算法·链表·排序算法
啊阿狸不会拉杆6 小时前
《算法导论》第 1 章 - 算法在计算中的作用
开发语言·数据结构·c++·算法·排序算法
刃神太酷啦6 小时前
C++ 容器适配器与核心数据结构精解:栈、队列、deque 底层实现与实战应用----《Hello C++ Wrold!》(17)--(C/C++)
java·c语言·数据结构·c++·qt·算法·leetcode
遇见尚硅谷8 小时前
挑战指针题
c语言·数据结构·算法
是阿建吖!8 小时前
【优选算法】分治--归并排序
数据结构·算法·排序算法
孟柯coding9 小时前
链表问题解决分析框架
数据结构·链表
ikkkkkkkl9 小时前
LeetCode:209.长度最小的子数组&&3.无重复字符的最长子串
数据结构·c++·算法·leetcode
非科班CPP程序员9 小时前
新手BUG:函数中 static 变量的赋值语句只会执行一次
数据结构·c++·算法