首页 > 编程语言 > 详细

Leetcode练习(Python):数组类:第219题:给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的 绝对值 至多为 k。

时间:2020-04-24 18:34:53      阅读:505      评论:0      收藏:0      [点我收藏+]
题目:
给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的 绝对值 至多为 k。  
思路:
使用哈希就很简单了。
程序:
class Solution:
    def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:
        length = len(nums)
        if length <= 0:
            return False
        if length == 1:
            return False
        my_hashMap = {}
        for index in range(length):
            if nums[index] in my_hashMap and index - my_hashMap[nums[index]] <= k:
                return True
            my_hashMap[nums[index]] = index
        return False

Leetcode练习(Python):数组类:第219题:给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的 绝对值 至多为 k。

原文:https://www.cnblogs.com/zhuozige/p/12768420.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!