存在重复元素 II

题意:

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

示例 1:

输入 :nums = [1,2,3,1], k = 3
输出:true

示例 2:

输入 :nums = [1,0,1,1], k = 1
输出:true

示例 3:

输入 :nums = [1,2,3,1,2,3], k = 2
输出:false

提示:

  • 1 <= nums.length <= 10^5
  • -10^9 <= nums[i] <= 10^9
  • 0 <= k <= 10^5

题目来源https://leetcode.cn/problems/contains-duplicate-ii/description/

解题方法:

一:暴力循环,运行会超出时间限制(不可取)

php 复制代码
    /**
 * @param Integer[] $nums
 * @param Integer $k
 * @return Boolean
 */
//超出时间限制
function containsNearbyDuplicate($nums, $k) {
    for($i = 0; $i < count($nums); $i++){
        for($j = $i + 1; $j < count($nums); $j++){
            if($nums[$i] == $nums[$j] && (abs($i-$j) <= $k)){
                return true;
            }
        }
    }
    return false;
}

方法二:解题思路 >>>> 类似hash,开辟一个临时数组,存储不重复的val,当有临时数组中存在该val时,做相关判断,如果符合条件,直接返回,如果不符合,则将该val的key替换为最新key

php 复制代码
function containsNearbyDuplicate($nums, $k) {
    $temp = [];
    foreach($nums as $key => $value){
        if(isset($temp[$value]) && abs($key - $temp[$value]) <= $k){
            return true;
        }
        $temp[$value] = $key;
    }
    return false;
}

$nums =[1,2,3,1,2,3]; $k =2; 为例
前三个为123,当轮到第4元素(第二次出现的1时),此时的索引差值不满足小于2的条件,已经不可能再有比这个小的差值了,所以替换到最新的位置

参考:

作者:xiaoxie

链接:https://leetcode.cn/problems/contains-duplicate-ii/solutions/1059994/phpjie-ti-by-xiaoxie-w-yaum/

来源:力扣(LeetCode)

相关推荐
灵感__idea7 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect17 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
BingoGo19 小时前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php
JaguarJack19 小时前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php·服务端
NAGNIP1 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱2 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub2 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉