leetcode解题报告(19):Contains Duplicate II
描述
Given an array of integers and an integer k, find out whether there are two distinct indices i and j in the array such that nums[i] = nums[j] and the absolute difference between i and j is at most k.
分析
我的想法是:遍历该数组,并判断当前元素之后有没有和该元素相等的元素,如果有,就通过distance得到这两个值之间的长度,如果小于等于k,则返回true,否则继续遍历。
代码如下:
class Solution {
public:
    bool containsNearbyDuplicate(vector<int>& nums, int k) {
        if(nums.size() == 0)return false;
        if(k <= 0)return false;
        for(auto it = nums.begin(); it != nums.end(); ++it){
            if(it + 1 == nums.end())return false;
            auto f = find(it + 1,nums.end(),*it);
            if(f != nums.end()){
                if(distance(it,f) <= k)return true;
            }
        }
        return false;
    }
};
然而测试用例中最后一个数组超时了,没ac,想了一会儿后还是不知道怎么优化这个解法,于是看了下讨论区:
https://discuss.leetcode.com/topic/15012/share-my-easy-to-understand-c-code
代码看到就懂了,还是用unordered_map,以元素值为key,元素下标为value。 遍历该数组,如果该元素不在数组中,就把元素放到这个unordered_map里。否则,判断当前元素下标与map中该元素的下标之差是否小于等于k,如果是,返回true。
代码如下:
class Solution {
public:
    bool containsNearbyDuplicate(vector<int>& nums, int k) {
        if(nums.size() == 0)return false;
        unordered_map<int,int>m;
        for(int i = 0; i != nums.size(); ++i{
            if(m.find(nums[i]) != m.end() && i - m[nums[i]] <= k)
                return true;
            m[nums[i]] = i;
        }
        return false;
    }
};
我的解法和上述解法在复杂度上相比,主要是多了distance这个函数。不过影响复杂度的主要因素是find函数。
为了查找一个范围内的值,我调用的是stl里的find函数,而这个算法的性能会略低于map自己的find函数。此外,unordered_map的一些操作的复杂度也确实低于vector。
unordered_map大法好~
leetcode解题报告(19):Contains Duplicate II的更多相关文章
- LeetCode解题报告—— Word Search & Subsets II & Decode Ways
		1. Word Search Given a 2D board and a word, find if the word exists in the grid. The word can be con ... 
- LeetCode解题报告—— Linked List Cycle II & Reverse Words in a String & Fraction to Recurring Decimal
		1. Linked List Cycle II Given a linked list, return the node where the cycle begins. If there is no ... 
- LeetCode解题报告—— Reverse Linked List II & Restore IP Addresses & Unique Binary Search Trees II
		1. Reverse Linked List II Reverse a linked list from position m to n. Do it in-place and in one-pass ... 
- LeetCode解题报告:Linked List Cycle && Linked List Cycle II
		LeetCode解题报告:Linked List Cycle && Linked List Cycle II 1题目 Linked List Cycle Given a linked ... 
- leetcode解题报告(2):Remove Duplicates from Sorted ArrayII
		描述 Follow up for "Remove Duplicates": What if duplicates are allowed at most twice? For ex ... 
- LeetCode 解题报告索引
		最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中...... ... 
- LeetCode解题报告汇总! All in One!
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 把自己刷过的所有题目做一个整理,并且用简洁的语言概括了一下思路,汇总成了一个表格. 题目 ... 
- LeetCode解题报告—— Combination Sum & Combination Sum II & Multiply Strings
		1. Combination Sum Given a set of candidate numbers (C) (without duplicates) and a target number (T) ... 
- LeetCode解题报告—— Permutations & Permutations II & Rotate Image
		1. Permutations Given a collection of distinct numbers, return all possible permutations. For exampl ... 
随机推荐
- JPA 一对一 一对多 多对一 多对多配置
			1 JPA概述 1.1 JPA是什么 JPA (Java Persistence API) Java持久化API.是一套Sun公司 Java官方制定的ORM 方案,是规范,是标准 ,sun公司自己并没 ... 
- 在uboot里面添加环境变量使用run来执行
			在uboot里面添加环境变量使用run来执行 本文链接:https://blog.csdn.net/u010979030/article/details/41038259 Author:杨正 Dat ... 
- C#倒计时关闭提示框
			前两天实现某个功能需要做一个提示框 并且能够自动关闭的,就从网上搜了一个能够自动关闭的提示框 ,但由于我需要的场景是不确定计时时间的,所以并没有使用到该窗体,但是我觉得可以留存备用 ,后边也把我 这种 ... 
- webstorm处理代码冲突
			出现这个冲突界面后,不要关闭弹窗,不然会把冲突更新下来,也不要点merge. 正确做法:双击文件开始解决冲突!!!! 
- MySQL常见问题集锦及注意事项
			一.表设计上的坑 1.字段设计 1.1 字段类型设计 尽量使用整型表示字符串: `INET_ATON(str)`,address to number `INET_NTOA(number)`,numbe ... 
- mysql limit和offset用法
			limit和offset用法 mysql里分页一般用limit来实现 1. select* from article LIMIT 1,3 2.select * from article LIMIT 3 ... 
- Makefile中 的 phony target,empty target
			phony target Makefile的语法很简单 <target> : <prerequisites> [tab] <commands> 目标.先决条件.命令 ... 
- 用js刷剑指offer(二叉树中和为某一值的路径)
			题目描述 输入一颗二叉树的根节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径.(注意: 在返回值的list中,数组长度大 ... 
- 开源框架---tensorflow c++ API 一个卡了很久的问题
			<开源框架---tensorflow c++ API 运行第一个“手写字的例子”> 中可以说明tensorflow c++ API是好用的,....... 
- Castle.Windsor依赖注入的高级应用与生存周期
			1. 使用代码方式进行组件注册[依赖服务类] using System; using System.Collections.Generic; using System.Linq; using Syst ... 
