【链表OJ 3】链表的中间结点

前言:

本文收录于http://t.csdn.cn/n6UEP数据结构刷题的博客中,首先欢迎大家的来访,其次如有错误,非常欢迎大家的指正!我会及时更正错误!

目录

一.链表的中间结点

1.1原理:快慢指针的使用

链表元素个数为奇数时

链表元素个数为偶数时

1.2循环条件问题?


一.链表的中间结点

来源:876. 链表的中间结点 - 力扣(LeetCode)

题目:

1.1原理:快慢指针的使用

这个算法之所以有效,是因为fast指针的移动速度是slow指针的两倍。

快慢指针 的精妙之处在于,当快指针移动到链表尾部时,慢指针就刚好移动了链表长度的一半,从而找到中间节点。因此当,fast指针到达链表尾部时,slow指针将正好指向链表的中间节点。无论链表长度奇偶,这个方法都可以在一次遍历正确找到中间节点。

时间复杂度:O(n),因为只遍历链表一次。
空间复杂度:O(1),因为没有使用额外的空间。

整体思路:

  1. 函数以指向链表头部的指针作为参数。

  2. 初始化两个指针 slowfast,它们都指向链表的头部。

  3. 进入一个循环,只要fast 不为NULL且fast->next不为NULL,循环会继续执行。这个循环用于通过链表前进指针。

  4. 每次循环迭代中,slow 指针向前移动一步,通过赋值slow = slow-> next

  5. fast 指针向前移动两步,通过赋值fast = fast -> next -> next

  6. 当循环结束时,slow 指针将指向链表的中间节点。这是因为fast 指针的移动速度是slow指针的两倍,当 fast指针到达链表尾部时,slow指针刚好在链表的中间。

  7. 最后,函数返回slow指针,即链表的中间节点。

链表元素个数为奇数时

动图演示:

链表元素个数为偶数时

返回第二个中间结点的原因是题目要求:

动图演示:

1.2循环条件问题?

循环条件不能调换顺序:

while 循环条件 fast && fast->next 不能写成 fast->next && fast的目的是为了确保在遍历链表时不会出现空指针异常。

如果将循环条件调换为fast->next&& fast,在链表长度为奇数时,当快指针 fast指向最后一个节点时,fast->next仍然不为NULL,但此时fast已经为NULL,这样会导致在访问fastnext指针时出现错误。

通过保持条件为fast && fast->next ,可以确保在fast 和 fast->next 每次迭代中,快指针都不为NULL,从而避免了空指针的访问错误。这是正确处理快慢指针遍历的关键。

因此,为了保证代码的正确性,应该保持原始代码中的循环条件不变,即fast && fast->next

代码实现

struct ListNode* middleNode(struct ListNode* head){
      struct ListNode* slow=head,*fast=head;
      while(fast && fast->next)
      {
            slow=slow->next;
            fast=fast->next->next;
       }
       return slow;
}

代码执行:

本文到此结束,如有错误欢迎大家指正,感谢来访!

相关推荐
青椒大仙KI111 分钟前
24/9/19 算法笔记 kaggle BankChurn数据分类
笔记·算法·分类
^^为欢几何^^5 分钟前
lodash中_.difference如何过滤数组
javascript·数据结构·算法
豆浩宇5 分钟前
Halcon OCR检测 免训练版
c++·人工智能·opencv·算法·计算机视觉·ocr
Hello-Mr.Wang10 分钟前
vue3中开发引导页的方法
开发语言·前端·javascript
救救孩子把13 分钟前
Java基础之IO流
java·开发语言
WG_1714 分钟前
C++多态
开发语言·c++·面试
宇卿.21 分钟前
Java键盘输入语句
java·开发语言
浅念同学21 分钟前
算法.图论-并查集上
java·算法·图论
何不遗憾呢29 分钟前
每日刷题(算法)
算法
Amo Xiang30 分钟前
2024 Python3.10 系统入门+进阶(十五):文件及目录操作
开发语言·python