leetcode-219-存在重复元素②

题目描述:

 

 第一次提交:超时

class Solution:
    def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
        for i in range(len(nums)-1):
            for j in range(i+1,min(i+k+1,len(nums))):           
                if nums[i] == nums[j]:return True
        return False

第二次提交:超时

class Solution:
    def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
        if k>=len(nums):
            if len(set(nums))!=len(nums):
                return True
        else:
            for i in range(len(nums)-k):
                if len(set(nums[i:i+k+1]))!=len(nums[i:i+k+1]):return True
        return False

优化:哈希表维护滑动窗口:O(N)

class Solution:
    def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
        windows = set()
        for i in range(len(nums)):
            if nums[i] in windows:
                return True
            windows.add(nums[i])
            if len(windows) > k:
                windows.remove(nums[i-k])
        return False

 

相关文章

这篇文章主要介绍LeetCode二维数组中如何实现对角线遍历,文...
这篇文章主要介绍了leetcode如何解决从根到叶的二进制数之和...
这篇文章主要为大家展示了“leetcode多线程之如何解决按序打...
这篇文章给大家分享的是有关LeetCode中二维数组如何实现旋转...
这篇文章主要介绍了LeetCode中二维数组如何实现零矩阵,具有...
本篇内容介绍了“leetcode怎么解决青蛙跳台阶问题”的有关知...