美文网首页
2019-05-18LeetCode141. 环形链表

2019-05-18LeetCode141. 环形链表

作者: mztkenan | 来源:发表于2019-05-18 20:29 被阅读0次

25min,双指针,对链表的处理,关键点在于a.next 的时候 a 不能是None,特殊情况head 为空

class Solution(object):
    def hasCycle(self, head):
        """
        :type head: ListNode
        :rtype: bool
        """
        if(head!=None):pos=head.next
        else:return False  # head=None
        while(pos!=head):
            if(head!=None):
                head=head.next
            else:return False
            if(pos!=None and pos.next!=None):
                pos=pos.next.next
            else:return False
        return True

使用try catch简直优雅,因为所有的异常情况都表示无环!excellent!
Easier to ask for forgiveness than permission."

class Solution(object):
    def hasCycle(self, head):
        """
        :type head: ListNode
        :rtype: bool
        """
        try:
            fast=head.next
            while(fast!=head):
                fast=fast.next.next
                head=head.next
            return True
        except:
            return False

相关文章

  • 2019-05-18LeetCode141. 环形链表

    25min,双指针,对链表的处理,关键点在于a.next 的时候 a 不能是None,特殊情况head 为空 使用...

  • 实现单向-双向环形链表

    单向环形链表 双向环形链表

  • 双指针

    一、双指针总结 1.1题目 快慢指针(主要解决链表中的问题) 141.环形链表 142.环形链表 II 876.链...

  • 02-14:leetcode重刷8之哈希与数组

    链表: 判断链表是否环形、是否回文 1、是否链表 #Definitionforsingly-linkedlist....

  • Tourist with Data Structure Seco

    链表 读题要仔细,只看题干,容易死的很惨。 设计链表 环形链表 一般环形链表使用快慢指针方式去做,快慢指针算法。参...

  • 算法(Algorithms)第4版 练习 1.3.29

    题目 使用环形链表实现队列(FIFO),环形链表也是链表,只是没有任何一个节点的链接是空的,且只有链表非空则 la...

  • 判断一个链表是否为环形链表

    判断一个链表是否为环形链表 思路:通过检测一个节点此前是否已经被访问过来判断链表是否为环形链表。 算法: 我们遍历...

  • 单项环形链表介绍和约瑟夫问题

    单项环形链表介绍和约瑟夫问题 1.单项环形链表图解 2.Josephu(约瑟夫)问题 Josephu 问题为:设...

  • 链表—环形链表

    给定一个链表,判断链表中是否有环。 分析 由于每一个父亲只有可能有一个孩子,故这里的环实际上是指list中某一个节...

  • 链表——环形链表

    首先,来列一下环形链表的特征: 至少存在一个节点,且有两个指针指向这个节点 链表中有且只有一个环,且这个环一定不能...

网友评论

      本文标题:2019-05-18LeetCode141. 环形链表

      本文链接:https://www.haomeiwen.com/subject/cgcxzqtx.html