大家好,我是苏貝,本篇博客带大家刷题,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️
目录
1.环形链表
data:image/s3,"s3://crabby-images/85daa/85daa66f3800b40ffab9f3550280a49fcf0824c4" alt=""
解题
思路:
data:image/s3,"s3://crabby-images/a95d7/a95d79b95f917a1f38845396738ac7f4ddb52caa" alt=""
c
bool hasCycle(struct ListNode *head) {
struct ListNode *slow=head;
struct ListNode *fast=head;
while(fast&&fast->next)
{
slow=slow->next;
fast=fast->next->next;
if(fast==slow)
return true;
}
return false;
}
拓展:
1
慢指针一次走2步,快指针一次走3步,可以解决上面的题目吗?
可以的,因为它们也只是相差了1步,证明同上
2
慢指针一次走1步,快指针一次走3步,走4步,...n步行吗?下面用慢指针一次走1步,快指针一次走3步来证明
data:image/s3,"s3://crabby-images/df435/df435588fca5626dc1437da7d465b2ca548005ec" alt=""
data:image/s3,"s3://crabby-images/77f43/77f43d64cbd2459f251c1b1be2ef285bbd2ac2ca" alt=""
2.环形链表II
data:image/s3,"s3://crabby-images/6fdfb/6fdfb7f5e24794b82d67b5c3e5aa537e7d34a1c4" alt=""
思路:
data:image/s3,"s3://crabby-images/93d11/93d11b2427978e7250671ca26fabdf31965c13c5" alt=""
c
struct ListNode *detectCycle(struct ListNode *head) {
struct ListNode *slow=head;
struct ListNode *fast=head;
while(fast&&fast->next)
{
slow=slow->next;
fast=fast->next->next;
//1.找到相遇的节点
if(slow==fast)
{
//让meet从相遇节点开始走
struct ListNode *meet=slow;
while(head!=meet)
{
head=head->next;
meet=meet->next;
}
return meet;
}
}
return NULL;
}
好了,那么本篇博客就到此结束了,如果你觉得本篇博客对你有些帮助,可以给个大大的赞👍吗,感谢看到这里,我们下篇博客见❤️