Leetcode 532.数组中的K-diff数对
数组中的K-diff数对
给定一个整数数组和一个整数 k, 你需要在数组里找到不同的 k-diff 数对。这里将 k-diff 数对定义为一个整数对 (i, j), 其中 i 和 j 都是数组中的数字,且两数之差的绝对值是 k.
示例 1:
输入: [3, 1, 4, 1, 5], k = 2
输出: 2
解释: 数组中有两个 2-diff 数对, (1, 3) 和 (3, 5)。
尽管数组中有两个1,但我们只应返回不同的数对的数量。
示例 2:
输入:[1, 2, 3, 4, 5], k = 1
输出: 4
解释: 数组中有四个 1-diff 数对, (1, 2), (2, 3), (3, 4) 和 (4, 5)。
示例 3:
输入: [1, 3, 1, 5, 4], k = 0
输出: 1
解释: 数组中只有一个 0-diff 数对,(1, 1)。
注意:
- 数对 (i, j) 和数对 (j, i) 被算作同一数对。
- 数组的长度不超过10,000。
- 所有输入的整数的范围在 [-1e7, 1e7]。
1 import java.util.HashMap; 2 3 class Solution { 4 public static int findPairs(int[] nums, int k) { 5 int count = 0; 6 if(k < 0) 7 return count; 8 HashMap<Integer,Integer> hm = new HashMap<>(); 9 for(int i = 0; i < nums.length; i++){ 10 hm.put(nums[i],i); 11 } 12 for(int i = 0; i < nums.length; i++){ 13 if(hm.containsKey(nums[i] + k) && hm.get(nums[i]+k) != i){ 14 count++; 15 hm.remove(nums[i] + k); 16 } 17 } 18 return count; 19 } 20 21 public static void main(String[] args){ 22 int[] nums={1,3,4,1,5}; 23 int k=2; 24 System.out.println(findPairs(nums,k)); 25 } 26 }
转载于:https://www.cnblogs.com/kexinxin/p/10373945.html
Leetcode 532.数组中的K-diff数对相关推荐
- LeetCode 532. 数组中的K-diff数对
1. 题目 给定一个整数数组和一个整数 k, 你需要在数组里找到不同的 k-diff 数对. 这里将 k-diff 数对定义为一个整数对 (i, j), 其中 i 和 j 都是数组中的数字,且两数之差 ...
- Leetcode 215.数组中第k个最大元素 (每日一题 20210713)
给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素.请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素.示例 1:输入: [3,2,1,5,6,4] 和 ...
- LeetCode——寻找数组中第三大的数
给定一个非空数组,返回此数组中第三大的数.如果不存在,则返回数组中最大的数.要求算法时间复杂度必须是O(n). 示例 1: 输入: [3, 2, 1] 输出: 1 解释: 第三大的数是 1. 示例 2 ...
- Leetcode——2053. 数组中第 K 个独一无二的字符串
数组中第 K 个独一无二的字符串 题目 解题思路 题目 独一无二的字符串 指的是在一个数组中只出现过 一次 的字符串. 给你一个字符串数组 arr 和一个整数 k ,请你返回 arr 中第 k 个 独 ...
- LeetCode —— 532. 数组中的K-diff数对(Python)
给定一个整数数组和一个整数 k, 你需要在数组里找到不同的 k-diff 数对.这里将 k-diff 数对定义为一个整数对 (i, j), 其中 i 和 j 都是数组中的数字,且两数之差的绝对值是 k ...
- LeetCode 2053. 数组中第 K 个独一无二的字符串(哈希)
文章目录 1. 题目 2. 解题 1. 题目 独一无二的字符串 指的是在一个数组中只出现过 一次 的字符串. 给你一个字符串数组 arr 和一个整数 k ,请你返回 arr 中第 k 个 独一无二的字 ...
- LeetCode 1471. 数组中的 k 个最强值(排序)
1. 题目 给你一个整数数组 arr 和一个整数 k . 设 m 为数组的中位数,只要满足下述两个前提之一,就可以判定 arr[i] 的值比 arr[j] 的值更强: |arr[i] - m| > ...
- 第J题-=数组中等于K的数对(详解) =======给出一个整数K和一个无序数组A,A的元素为N个互不相同的整数
给出一个整数K和一个无序数组A,A的元素为N个互不相同的整数,找出数组A中所有和等于K的数对.例如K = 8,数组A:{-1,6,5,3,4,2,9,0,8},所有和等于8的数对包括(-1,9),(0 ...
- 2022-2-9 Leetcode 532.数组中的 k-diff 数对
第一版,巨慢 class Solution {public:// int findPairs(vector<int>& nums, int k) {// int ret = 0;/ ...
最新文章
- react学习系列之ajax
- 可视化篇(二)———使用matplotlib绘制常用3D图形及案例
- ITK:图像的拉普拉斯算子
- ubuntu安装qt4
- angular6 中使用bootstrap
- 【Elasticsearch】es 各种查询 详解
- Jmeter系列之数据库操作
- RHEL5.4 x86_64 GCC 4.1.2 升级到4.7.0版过程(含安装MPFR、GMP、MPC过程)
- 饭卡管理系统学生E-R图
- w ndows7安不上HP1020,惠普1020打印机驱动程序
- qq手机令牌 for android3.3 官方安装版,原QQ安全助手|QQ手机管家 for Android 安卓版v3.3.0 - PC6安卓网...
- graphpad导出图片不居中_Graphpad如何导出期刊所需图
- 【Android Gradle 插件】Splits 配置 ③ ( Splits#density{} 脚本块配置 | 根据屏幕像素密度进行分包 | DensitySplitOptions 配置简介 )
- 【行业云说直播间】-智慧能源 低碳未来正式上线
- java数字转为大写_java 数字转大写汉字
- Switch 开关,将字写在滑块上面
- onedrive指定文件夹备份
- 外贸客户如何选择供应商:5R原则
- ESP8266Wi-Fi数据通讯
- 搭建Kubernetes(k8s)集群(cka考试环境)
热门文章
- [leetcode]1007. 行相等的最少多米诺旋转
- SqlSugar ORM 入门到精通【一】入门篇
- 让jquery easyui datagrid列支持绑定嵌套对象
- 用形态学的方法实现图像的角点检测
- php truepath,php – 为什么switch(true)具有比if()elseif()更小的NPath复杂度?
- WebService大讲堂之Axis2(3):使用services.xml文件发布WebService
- git查找两个分支的共同节点
- leetcode算法题--反转链表 II★
- java一定时间间隔的定时任务_Java 定时任务---Timer
- python db api下载_python db api