【多解LeetCode】 142.环形链表 II

142.环形链表 II

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */

struct ListNode * judgecircle(struct ListNode *head) 
{
    if(head == NULL)    return 0;
    struct ListNode * fast ,* slow ;
    fast = slow = head;
    while(fast && fast -> next)
    {
        fast = fast -> next -> next ;
        slow = slow -> next ;
        if(fast == slow )    return slow;
    }
    return NULL;
}

struct ListNode *detectCycle(struct ListNode *head) 
{
    struct ListNode * meet = judgecircle(head);//(1)
    struct ListNode * cur = head;
    if(meet)//如果存在环
    {
        while(cur)//(2)
        {
            if(meet == cur)     return meet;//找到就返回地址
            meet = meet -> next;
            cur = cur -> next; 
        }
    }
    else    return NULL;//找不到返回NULL
    return ;
}   

(1)判断是否有环存 如果有环存在 meet != NULL 如果无环 则是NULL 无法进入if 条件语句
(2)寻找相遇节点

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值