在Go中遍历环形链表可以通过两种方法实现: 快慢指针法:使用两个指针,一个慢指针每次移动一步,一个快指针每次移动两步。如果链表中有
type Listnode struct {
Val int
Next *ListNode
}
func hasCycle(head *ListNode) bool {
if head == nil || head.Next == nil {
return false
}
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
}
type ListNode struct {
Val int
Next *ListNode
}
func hasCycle(head *ListNode) bool {
cur := head
for cur != nil {
if cur.Val == -1 {
return true
}
cur.Val = -1
cur = cur.Next
}
return false
}
--结束END--
本文标题: Go中怎么遍历环形链表
本文链接: https://lsjlt.com/news/594867.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0