题解 | #判断链表中是否有环#

判断链表中是否有环

https://www.nowcoder.com/practice/650474f313294468a4ded3ce0f7898b9

package main
import . "nc_tools"
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */

/**
 * 
 * @param head ListNode类 
 * @return bool布尔型
*/
func hasCycle( head *ListNode ) bool {
    if head == nil || head.Next == nil{
        return false
    }
    // write code here
    slow :=head
    fast := head.Next

    for fast !=nil && fast.Next !=nil{
        if slow == fast{
            return true 
        }
        slow = slow.Next
        fast = fast.Next.Next
    }
    return false
}

在这个函数中,我们使用了两个指针:slowfastslow 指针每次移动一个节点,而 fast 指针每次移动两个节点。如果链表中存在环,那么 fast 指针最终会追上 slow 指针,此时函数返回 true。如果链表中没有环,fast 指针会先到达链表的尾部,函数返回 false

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-21 17:16
科大讯飞 算法工程师 28.0k*14.0, 百分之三十是绩效,惯例只发0.9
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务