【C++刷题】力扣-#219-存在重复元素II

题目描述

给定一个整数数组 nums 和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j 使得 nums[i] = nums[j] 且 i!= j。也就是说,不能有重复的元素。

示例

示例 1:

bash 复制代码
输入: nums = [1,2,3,1], k = 3
输出: true

示例 2:

bash 复制代码
输入: nums = [1,2,3,1,2,4], k = 3
输出: false

示例 3:

bash 复制代码
输入: nums = [1,2,3,1,2,4], k = 2
输出: true

题解

这个问题可以通过使用哈希表来解决。

  1. 初始化:创建一个空的哈希表 hashMap 来存储数组元素及其索引。
  2. 遍历数组:遍历整数数组 nums。
    ○ 对于每个元素,检查它是否已经在哈希表中:
    ■ 如果在,并且索引差小于 k,则返回 true。
    ■ 如果在,并且索引差大于等于 k,则从哈希表中移除旧的索引。
    ■ 如果不在,将其添加到哈希表中,并记录当前索引。
  3. 返回结果:如果遍历结束后没有找到重复元素,则返回 false。

代码实现

cpp 复制代码
bool containsNearbyDuplicate(vector<int>& nums, int k) {
    unordered_map<int, int> hashMap;
    for (int i = 0; i < nums.size(); ++i) {
        if (hashMap.find(nums[i]) != hashMap.end() && i - hashMap[nums[i]] <= k) {
            return true;
        }
        hashMap[nums[i]] = i;
    }
    return false;
}

复杂度分析

● 时间复杂度:O(n),其中 n 是数组 nums 的长度。我们需要遍历一次数组,并且对于每个元素,我们进行常数时间的哈希表操作。

● 空间复杂度:O(n),因为在最坏的情况下,我们可能需要将所有元素存储在哈希表中。

这个算法的优势在于它的时间效率较高,只需要一次遍历即可判断是否存在重复元素,且直接利用了哈希表的快速查找特性。

相关推荐
老四啊laosi1 天前
[C++进阶] 24. 哈希表封装unordered_map && unordered_set
c++·哈希表·封装·unordered_map·unordered_set
2301_764441331 天前
LISA时空跃迁分析,地理时空分析
数据结构·python·算法
东北洗浴王子讲AI1 天前
GPT-5.4辅助算法设计与优化:从理论到实践的系统方法
人工智能·gpt·算法·chatgpt
妙为1 天前
银河麒麟V4下编译Qt5.12.12源码
c++·qt·国产化·osg3.6.5·osgearth3.2·银河麒麟v4
Billlly1 天前
ABC 453 个人题解
算法·题解·atcoder
玉树临风ives1 天前
atcoder ABC 452 题解
数据结构·算法
feifeigo1231 天前
基于马尔可夫随机场模型的SAR图像变化检测源码实现
算法
fengfuyao9851 天前
基于STM32的4轴步进电机加减速控制工程源码(梯形加减速算法)
网络·stm32·算法
无敌昊哥战神1 天前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜1 天前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展