当前位置: 首页 > news >正文

存在重复元素Ⅱ python3

存在重复元素Ⅱ

  • 问题描述
  • 解题思路
  • 代码实现
  • 复杂度

问题描述

给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 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

解题思路

哈希表结构,key存储数字,value存储该数字出现的索引,且value为列表结构。若当前数字对应的列表长度大于2,则表明至少存在相同的两个索引,使得nums[i] == nums[j],将此列表降序排列,一一比较,如存在i-j小于等于k则返回True。

代码实现

def containsNearbyDuplicate(self, nums: List[int], k: int) -> bool:my_dict ={}index = 0for num in nums:if num not in my_dict.keys():my_dict.setdefault(num,[]).append(index)else:my_dict[num].append(index)index+=1print(f"my_dict:{my_dict}")keys = my_dict.keys()for i in keys:if len(my_dict[i])>=2:sorted_dict_list = sorted(my_dict[i], reverse = True)n = len(my_dict[i]) u = 0while u <n:j = n-1while j >u:if sorted_dict_list[u]-sorted_dict_list[j]<=k:return Trueelse:j-=1u+=1return False

复杂度

时间复杂度:O(NLogN)

http://www.lryc.cn/news/379411.html

相关文章:

  • 【CV炼丹师勇闯力扣训练营 Day13:§6二叉树1】
  • 代码随想录算法训练营第46天 [ 121. 买卖股票的最佳时机 122.买卖股票的最佳时机II 123.买卖股票的最佳时机III ]
  • 基于IDEA的Maven简单工程创建及结构分析
  • 解锁空间数据奥秘:ArcGIS Pro与Python双剑合璧,处理表格数据、矢量数据、栅格数据、点云数据、GPS数据、多维数据以及遥感云平台数据等
  • 后端路线指导(4):后端春招秋招经验分享
  • 面完小红书算法岗,心态崩了。。。
  • Android 断点续传进阶之多线程下载
  • Python爬虫学习 | Scrapy框架详解
  • 用户态协议栈05—架构优化
  • 模拟退火算法
  • Java匿名类
  • G7易流赋能化工物流,实现安全、环保与效率的共赢
  • y=sin(2x)
  • 快捷方式(lnk)--加载HTA-CS上线
  • 从同—视角理解扩散模型(Understanding Diffusion Models A Unified Perspective)
  • docker 基本用法及跨平台使用
  • Vscode远程ubuntu
  • SHA256 安全散列算法加速器实验
  • Elasticsearch-ES查询单字段去重
  • 【Apache Doris】周FAQ集锦:第 7 期
  • EE trade:炒伦敦金的注意事项及交易指南
  • JAVA医院绩效考核系统源码 功能特点:大型医院绩效考核系统源码
  • Python神经影像数据的处理和分析库之nipy使用详解
  • 非关系型数据库NoSQL数据层解决方案 之 Mongodb 简介 下载安装 springboot整合与读写操作
  • 使用Redis优化Java应用的性能
  • 基于Python的数据可视化大屏的设计与实现
  • 什么是N卡和A卡?有什么区别?
  • 四边形不等式优化
  • 这家民营银行起诉担保公司?暴露担保增信兜底隐患
  • vscode禅模式怎么退出