欢乐力扣:存在重复元素二

文章目录


1、题目描述

存在重复元素

给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 。

2、思路1

暴力法,直接两层for循环,但会超时。

代码

python 复制代码
class Solution:
    def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
        # 暴力会超时 
        for i in range(len(nums)-1):
            for j in range(i+1, len(nums)):
                if nums[i] != nums[j]:
                    continue 
                else:
                    res = abs(i - j) <= k
                    if res is True:
                        return True 
        return False 

3、思路2

借助哈希表,来不断的存储元素值以及下标,若当前元素已经在字典里,则取出对应下标与k进行比较;若不满足条件,则将当前遍历的元素的下标存入字典,覆盖掉原来的下标。

代码

python 复制代码
class Solution:
    def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
        # 哈希表
        from collections import defaultdict 
        hash_map = defaultdict(int)
        for i in range(len(nums)):
            # 若当前元素不在哈希表,则存进去
            if nums[i] not in hash_map:
                hash_map[nums[i]] = i   
            # 若在哈希表里:
            else:
                res = abs(i - hash_map[nums[i]]) <= k 
                # 若查找成功,则返回True
                if res is True:
                    return True 
                else:
                    hash_map[nums[i]] = i  # 覆盖字典为最新的下标
        return False 
相关推荐
.格子衫.4 小时前
018数据结构之队列——算法备赛
数据结构·算法
怎么没有名字注册了啊5 小时前
求一个矩阵中的鞍点
数据结构·算法
Greedy Alg5 小时前
LeetCode 74. 搜索二维矩阵
算法
小猪咪piggy6 小时前
【算法】day7 滑动窗口+二分查找
算法
仟千意6 小时前
数据结构:二叉树
数据结构·算法
一水鉴天6 小时前
整体设计 逻辑系统程序 之34七层网络的中台架构设计及链路对应讨论(含 CFR 规则与理 / 事代理界定)
人工智能·算法·公共逻辑
DuHz6 小时前
C程序中的数组与指针共生关系
linux·c语言·开发语言·嵌入式硬件·算法
而后笑面对6 小时前
力扣2025.10.19每日一题
算法·leetcode·职场和发展
·白小白7 小时前
力扣(LeetCode) ——11.盛水最多的容器(C++)
c++·算法·leetcode
沐浴露z8 小时前
【JVM】详解 垃圾回收
java·jvm·算法