您的位置:首页 > 财经 > 产业 > 平面设计鉴赏网站_合肥seo排名公司_aso搜索优化_推广普通话标语

平面设计鉴赏网站_合肥seo排名公司_aso搜索优化_推广普通话标语

2025/2/27 14:24:44 来源:https://blog.csdn.net/xxxmmc/article/details/145875652  浏览:    关键词:平面设计鉴赏网站_合肥seo排名公司_aso搜索优化_推广普通话标语
平面设计鉴赏网站_合肥seo排名公司_aso搜索优化_推广普通话标语

题目链接

https://leetcode.com/problems/linked-list-cycle/
https://leetcode.com/problems/linked-list-cycle-ii/

题意

给定一个环形链表,求找到链表的环的位置,返回一个指针(以Leetcode 142为例)

题解

首先判断是否有环。可以用快慢指针来确定,由于快的那个指针一直在环中移动,慢的指针每次移动一步,二者一定会相遇,如果能相遇则说明有环。第二步假设从链表头到环的起点距离为a,相遇点为c,那么一定满足a+c+kb = 2(a+c),则满足a+c = kb,也就是说如果一个指针从链表头开始,另一个指针从相遇点开始走,那么两者相遇的点就是环的起点。

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:ListNode *detectCycle(ListNode *head) {bool hasCycle = false;ListNode *p1 = head;ListNode *p2 = head;while (p1 != nullptr && p1->next != nullptr) {p1 = p1->next->next;p2 = p2->next;if(p1 == p2) {hasCycle = true;break;}}if(hasCycle) {ListNode *p3 = head;while( p1 != p3) {p1 = p1->next;p3 = p3->next;}return p1;} return nullptr;}
};

时间复杂度: O ( n ) O(n) O(n) n是链表的长度
空间复杂度: O ( 1 ) O(1) O(1)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com