回文单链表(java)

如何判断一个单链表是回文单链表?

思路分析

回文单链表:链表反转后和原链表一样

  1. 思路一:根据回文单链表的特点很容易分析出
    ① 反转单链表
    ② 遍历比较原链表和反转后的链表,如果有不一样的结点,说明不是回文的,如果两链表完全一样,说明是回文的
  2. 思路二
    ① 使用快慢指针找出链表的中间结点,其中快指针步长为2,慢指针步长为1
    根据中间结点反转后半部分链表
    ③ 遍历比较前后两部分链表的结点是否一致

反转实现

由于两个思路都需要反转,这里先实现一下单链表反转

  • 图示
    在这里插入图片描述

  • 代码实现

public static ListNode reverseLinked(ListNode head) {
       if(head == null) {
           return head;
       }
        // 当前结点
        ListNode cur = head;
        // 反转后的链表
        ListNode newHead = new ListNode(head.val);
        // 遍历原链表,构造反转链表
        while (true) {
            if (cur.next == null) {
                newHead.val = cur.val;
                break;
            }
            ListNode nextTemp  = newHead.next;
            newHead.next = new ListNode(cur.val);
            newHead.next.next = nextTemp;
            // 结点后移,继续遍历
            cur = cur.next;
        }
        return newHead;
    }

思路一实现

public boolean isPalindrome(ListNode head) {
        // 反转链表
        ListNode reservedListNode = reverseLinked(head);
        // 遍历比较原链表和反转后链表的结点
        ListNode cur = head;
        ListNode cur1 = reservedListNode;
        while (cur != null && cur1 != null) {
            if (cur.val != cur1.val) {
                return false;
            }
            // 后移,继续遍历比较
            cur = cur.next;
            cur1 = cur1.next;
        }
        return true;
    }

思路二实现

  • 图示
    在这里插入图片描述
    在这里插入图片描述
    结点个数为奇数:当满足fast.next = null时,slow指向中间结点
    结点个数为偶数:当满足fast.next.next = null时,slow指向中间结点

  • 代码实现

public boolean isPalindrome2(ListNode head) {
        // 使用快慢指针找出中间结点
        ListNode middle = getMiddle(head);
        // 反转后半部分链表
        ListNode reverseLinked = reverseLinked(middle);
        // 比较前后两部分链表
        ListNode cur = head;
        ListNode cur1 = reverseLinked;
        while (cur != null && cur1 != null) {
            if (cur.val != cur1.val) {
                return false;
            }
            // 后移
            cur = cur.next;
            cur1 = cur1.next;
        }
        return true;
    }

    private static ListNode getMiddle(ListNode head) {
        if(head == null) {
           return head;
        }
        ListNode slow = head;
        ListNode fast = head;
        while (fast.next != null && fast.next.next != null) {
            slow = slow.next;
            fast = fast.next.next;
        }
        // 不管链表结点个数是奇数还是偶数,循环退出,slow就是中间结点
        return slow;
    }
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值