LeetCode234. 回文链表Golang版

本文介绍了一种使用Golang实现的算法来判断一个链表是否为回文结构。通过快慢指针找到链表中点,并反转后半部分链表,最后对比前后两部分是否完全相同。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

LeetCode234. 回文链表Golang版

1. 问题描述

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

示例 1:

输入: 1->2
输出: false
示例 2:

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

2. 思路

  1. 利用快慢指针,找到链表中间位置。
  2. 将链表后半段反转。
  3. 进行回文数的比较。

3. 代码

/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func isPalindrome(head *ListNode) bool {
    if head == nil {
        return true
    }
    firstEnd := endOfFirstHalfList(head)
    reverseHead :=  reverseList(firstEnd.Next)

    p1 := head
    p2 := reverseHead
    for p2 != nil {
        if p1.Val != p2.Val {
            return false
        }
        p1 = p1.Next
        p2 = p2.Next
    }
    firstEnd.Next = reverseList(firstEnd.Next)
    return true
}

func endOfFirstHalfList(head *ListNode) *ListNode {
    slow := head
    fast := head
    for fast.Next != nil && fast.Next.Next != nil {
        fast = fast.Next.Next
        slow = slow.Next
    }
    return slow
}

func reverseList(head *ListNode) *ListNode {
    prev := &ListNode{}
    current := &ListNode{}

    prev = nil
    current = head

    for current != nil {
        temp := current.Next
        current.Next = prev
        prev = current
        current = temp
    }
    return prev
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值