力扣.链表.876.链表的中间节点

本文介绍了如何使用快慢指针法改进寻找链表中间节点的算法,通过一个for循环实现,同时解释了while条件的正确设置。
摘要由CSDN通过智能技术生成

老规矩,题目如下:

这里将会介绍到一种新的算法思想,这里先酝酿一波。

看到题目,会想到之前xieC语言的时候类似的题目,思路清晰而明了:用计数器(count++)遍历链表,然后除2得到中间位置,然后使用for循环得到中间节点。

显然,在算法的简洁度方面,两个for循环还是有点多了,有没有可能改成一个for循环解决问题呢?

当然是有的,思路二/新的算法思想:

快慢指针法:定义两个指针,一个fast,一个slow,让fast一次走两个节点,slow一次走一个节点,当fast走到头的时候slow的位置就是中间节点,这样只用了一个循环,妙啊!

代码实现:

typedef struct ListNode ListNode;

struct ListNode* middleNode(struct ListNode* head) {
	ListNode* Fast = head;
	ListNode* Slow = head;
	while (Fast && Fast->next)
	{
		//慢指针每次走一步,快指针一次走两步
		Fast = Fast->next->next;
		Slow = Slow->next;
	}
	//此时Slow恰好是中间节点
	return Slow;

}

有个小细节while(Fast && Fast->next)不能改成while(Fast->next && Fast),否则不会通过,但这两个有什么区别呢?

前者(正确答案)先执行Fast,当Fast为空时不再执行Fast->next,即发生了短路;但错误答案先执行Fast->next,这个时候如果Fast已经空了,就不存在Fast->next了,当然会报错。

希望我的代码可以帮到你,如果有什么问题或者建议欢迎在评论区讨论,谢谢支持~

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值