当前位置:   article > 正文

算法练习:判断一个链表是否为回文结构_请判断一个链表是否为回文链表

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

【题目】给定一个单链表的头节点head,请判断该链表是否为回文结构。
【例子】1->2->1, 返回true; 1->2- ->2->1,返回true; 15->6->15, 返回true;
1->2->3, 返回false。
【提高】如果链表长度为N,时间复杂度达到O(N),能否做到额外空间复杂度达到O(1)?

解答本题用到了快慢指针的技巧,所以先介绍一下快慢指针,它主要作用是找到链表的中间节点。

链表快慢指针介绍:

慢指针slow一次走1步,快指针F一次走2步,fast刚越界时S刚好走到中间位置,边界条件需具体情况来定制。

边界条件包括快慢指针的起始位置,和循环(遍历)的终止条件,由此来控制慢指针slow的最终落点。

通常边界条件的设置有如下几种情况:

  1. //为避免段错误,假设前面已有空指针的判断
  2. //边界条件一:
  3. ListNode slow = head;
  4. ListNode fast = head;
  5. while (fast != null && fast.next != null) {
  6. slow = slow.next;
  7. fast = fast.next.next;
  8. } //循环结束后,slow跑到mid处(奇数个node)或右半边第一个node处(偶数个node),fast跑到尾节点或null处
  9. //边界条件二:
  10. ListNode slow = head;
  11. ListNode fast = head;
  12. while (fast.next != null && fast.next.next != null) {
  13. slow = slow.next;
  14. fast = fast.next.next;
  15. } //循环结束后,slow跑到mid处(奇数个node)或左半边最后一个node处(偶数个node),fast跑到尾节点或null处
  16. //边界条件三:
  17. ListNode slow = head.next;
  18. ListNode fast = head;
  19. while (fast.next != nul
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/612072
推荐阅读
相关标签
  

闽ICP备14008679号