刷题记录 leetcode234:回文链表

Posted 嫩西瓜

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了刷题记录 leetcode234:回文链表相关的知识,希望对你有一定的参考价值。

请判断一个链表是否为回文链表。

示例 1:

输入: 1->2
输出: false

示例2:

输入: 1->2->2->1
输出: true

思路:切成两半,把后半段反转,然后比较两半是否相等

class Solution {
    public boolean isPalindrome(ListNode head) {
        if(head == null || head.next == null)
            return true;
        ListNode slow = head;                          // slow是第二段的头结点
        ListNode fast = head.next;
        while(fast != null && fast.next!= null){
            slow = slow.next;
            fast = fast.next.next;
        }
        if(fast != null) slow = slow.next;            // 如果链表长度是偶数,slow再往前一个节点
        cut(head, slow);
        return isEqual(head, reverse(slow));
    }
    private void cut(ListNode head, ListNode cutNode){
        ListNode cur = head;
        while(cur.next != cutNode){
            cur = cur.next;
        }
        cur.next = null;
    }
    private ListNode reverse(ListNode head){        // 这种反转链表方法比递归和头插法快
        ListNode node = null;
        while(head != null){
            ListNode next = head.next;
            head.next = node;
            node =head;
            head =next;
        }
        return node;
    }
    private boolean isEqual(ListNode l1, ListNode l2){  
        while(l1 != null && l2 != null){                  // 如果链表长度是奇数个,分开的链表长度不一样,所以这里要用&&,只要任意一个链表遍历完就可以认为两个链表一样
            if(l1.val != l2.val) return false;
            l1 = l1.next;
            l2 = l2.next;
        }
        return true;
 }

 

以上是关于刷题记录 leetcode234:回文链表的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode刷题234-简单-回文链表

Leetcode刷题笔记之链表篇234. 回文链表

Leetcode刷题笔记之链表篇234. 回文链表

leetcode刷题19.回文链表——Java版

刷题15:回文链表

leetcode 234 回文链表