Array - K-diff Pairs in an Array

题目 https://leetcode.com/problems/k-diff-pairs-in-an-array/#/description

代码

class Solution {
  public:
       int findPairs(vector<int>& nums, int k) {
        if(k < 0) 
            return 0;
        unordered_map<int,int> m;

        for(int i = 0; i < nums.size(); ++i)
        {
            ++m[nums[i]];
        }
           
        int res = 0;
        if(k != 0) {
            for(auto it = m.begin(); it != m.end(); ++it){
               cout<< it->first <<endl; 
               if(m.find(it->first+k) != m.end())//将map中的键值添加k,看能否寻找到对应的键值,如果能找到说明新增一pair
                   ++res;
            }
               
        } else {
            for(auto it = m.begin(); it != m.end(); ++it)
               if(it->second > 1)
                   ++res;
        }
        return res;
    }
};

解题:
1 根据题意,开始应将数组的重复数据“去掉”
2 利用unordered_map 储存不同数字以及出现的次数,实现1
3 unordered_map的键值加上k后的结果所表示的key在unordered_map中有对应value则表明输入数组中有1对满足绝对值为k的“组合”,以此类推计算出所有的“组合”数即为题目的解。
4 若k为0时则统计unordered_map 中key所对应的value(即key在数组中出现的次数)大于1的所有key的数量,即为题目的解。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,745评论 18 399
  • 教你如何迅速秒杀掉:99%的海量数据处理面试题 本文经过大量细致的优化后,收录于我的新书《编程之法》第六章中,新书...
    Helen_Cat阅读 12,123评论 1 39
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 5,427评论 0 3
  • Map 是一种很常见的数据结构,用于存储一些无序的键值对。在主流的编程语言中,默认就自带它的实现。C、C++ 中的...
    一缕殇流化隐半边冰霜阅读 13,090评论 23 67
  • 人世间的悲欢离合,人生中的苦痛哀伤,每一天都在上演,每一刻都在经历。 能够治愈心伤的,只有时间。今天的太阳闪耀的不...
    安福杨玉生阅读 1,747评论 0 1

友情链接更多精彩内容