zknlz 2023-07-25 14:22 采纳率: 75%
浏览 12
已结题

求解惑 :Leetcode128. 最长连续序列

当判断完毕当前数字n的前一个n-1 不在集合中之后
为何需要一个current nums 来储存nums的值? 直接用n不可以吗
以下是lc标准题解

def longestConsecutive(self, nums: List[int]) -> int:
        longest_streak = 0
        num_set = set(nums)

        for num in num_set:
            if num - 1 not in num_set:
                current_num = num #为什么需要这步
                current_streak = 1

                while current_num + 1 in num_set:
                    current_num += 1
                    current_streak += 1

                longest_streak = max(longest_streak, current_streak)

        return longest_streak

以下是我的题解 报错Time Limit Exceeded

    def longestConsecutive(self, nums: List[int]) -> int:
        nums = set(nums)
        longest = 0

        for n in nums:
            curLength = 0

            if n-1 not in nums: #该数字的前一个连续数字不在表里 也就是说当前数字可以当序列开头
                curLength += 1

                while n+1 in nums: #计数 当前数字的+1 +2...
                    curLength += 1

                longest = max(longest,curLength) #如果新序列长度更大 更新最长值
     
        return longest

  • 写回答

2条回答 默认 最新

  • threenewbee 2023-07-25 14:24
    关注

    while n+1 in nums:
    你这个循环里面一不会改变n,二不会改变num
    一旦循环条件满足,那么就永远满足条件,自然死循环了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月2日
  • 已采纳回答 7月25日
  • 创建了问题 7月25日

悬赏问题

  • ¥15 is not in the mmseg::model registry。报错,模型注册表找不到自定义模块。
  • ¥15 安装quartus II18.1时弹出此error,怎么解决?
  • ¥15 keil官网下载psn序列号在哪
  • ¥15 想用adb命令做一个通话软件,播放录音
  • ¥30 Pytorch深度学习服务器跑不通问题解决?
  • ¥15 部分客户订单定位有误的问题
  • ¥15 如何在maya程序中利用python编写领子和褶裥的模型的方法
  • ¥15 Bug traq 数据包 大概什么价
  • ¥15 在anaconda上pytorch和paddle paddle下载报错
  • ¥25 自动填写QQ腾讯文档收集表