分析
我们可以分三步来解决这个问题。
- 快慢指针找中点
- 反转后半部分
- 判断前半段与翻转后的后半段是否相同
第一步:快慢指针找中间节点
- fast(快指针一次走两步)
- slow(满指针一次走一步)
第二步反转后半部分
- prev(当前slow节点的前驱,用于反转链表)
- slowNext(当前slow的下一个节点,用于反转链表)
第三步判断前半段与翻转后的后半段是否相同
代码如下:
class Solution {
public boolean isPalindrome(ListNode head) {
// write code here
if(head==null)
{
return true;
}
ListNode fast=head;
ListNode slow=head;
while(fast!=null&&fast.next!=null)
{
fast=fast.next.next;
slow=slow.next;
}
ListNode pre = null;
ListNode slowNext=null;
while (slow != null) {
slowNext = slow.next;
slow.next = pre;
pre = slow;
slow = slowNext;
}
// 前后两段比较是否一致
while (pre != null) {
if (pre.val != head.val) {
return false;
}
pre = pre.next;
head = head.next;
}
return true;
}
}