Java教程

环形链表II

本文主要是介绍环形链表II,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

 

 

变量简洁正确完整思路

slow每次走一步fast每次走两步,相遇,ans从起点,和slow同时走,相遇,返回相遇点   画图
class Solution {
public:
    ListNode *detectCycle(ListNode *head) {
        ListNode*L=head,*R=head;
        bool hadCircle=false;
        while(R&&R->next){
            L=L->next;
            R=R->next->next;
            if(L==R){
                hadCircle=true;
                break;
            }
        }
        if(hadCircle){
            ListNode*ans=head;
            while(ans!=L)ans=ans->next,L=L->next;
            return ans;
        }
        return nullptr;
    }
};

 

 

 

这篇关于环形链表II的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!