当前位置:   article > 正文

Golang | Leetcode Golang题解之第234题回文链表

Golang | Leetcode Golang题解之第234题回文链表

题目:

题解:

  1. func reverseList(head *ListNode) *ListNode {
  2. var prev, cur *ListNode = nil, head
  3. for cur != nil {
  4. nextTmp := cur.Next
  5. cur.Next = prev
  6. prev = cur
  7. cur = nextTmp
  8. }
  9. return prev
  10. }
  11. func endOfFirstHalf(head *ListNode) *ListNode {
  12. fast := head
  13. slow := head
  14. for fast.Next != nil && fast.Next.Next != nil {
  15. fast = fast.Next.Next
  16. slow = slow.Next
  17. }
  18. return slow
  19. }
  20. func isPalindrome(head *ListNode) bool {
  21. if head == nil {
  22. return true
  23. }
  24. // 找到前半部分链表的尾节点并反转后半部分链表
  25. firstHalfEnd := endOfFirstHalf(head)
  26. secondHalfStart := reverseList(firstHalfEnd.Next)
  27. // 判断是否回文
  28. p1 := head
  29. p2 := secondHalfStart
  30. result := true
  31. for result && p2 != nil {
  32. if p1.Val != p2.Val {
  33. result = false
  34. }
  35. p1 = p1.Next
  36. p2 = p2.Next
  37. }
  38. // 还原链表并返回结果
  39. firstHalfEnd.Next = reverseList(secondHalfStart)
  40. return result
  41. }
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/844476
推荐阅读
相关标签
  

闽ICP备14008679号