Java for LeetCode 220 Contains Duplicate III
2024-08-24 10:02:40
Given an array of integers, find out whether there are two distinct indices i and j in the array such that the difference between nums[i] and nums[j] is at most t and the difference between i and j is at most k.
解题思路:
暴力枚举会LTE,解题思路是用sortedSet来解决,sortedSet可以返回一个在某个范围的subSet,同时判断这个subSet是否为空即可解决,主要,本题需要使用long类型!
JAVA实现如下:
import java.util.*;
public class Solution {
public boolean containsNearbyAlmostDuplicate(int[] nums, int k, int t) {
if(nums==null || nums.length<2||k<1 || t<0)
return false;
SortedSet<Long> set = new TreeSet<Long>();
for(int j=0; j<nums.length; j++) {
SortedSet<Long> subSet = set.subSet((long)nums[j]-t, (long)nums[j]+t+1);
if(!subSet.isEmpty())
return true;
if(j>=k)
set.remove((long)nums[j-k]);
set.add((long)nums[j]);
}
return false;
}
}
最新文章
- 一个Java文件至多包含一个公共类
- 【转】ContextMenuStrip菜单应用
- 51nod 1021 石头归并
- asp.net gridview 绑定图片字段,图片不显示
- 黑马程序员:Java基础总结----泛型(高级)
- idea svn 更新覆盖了本地代码
- android之活动状态、生存期、启动模式
- JavaScript基础——兼容性、错误处理
- lab1-Junit&;Eclemma
- dubbo源码—dubbo简介
- sublime安装、注册、插件
- C++ Primer 有感(标准库set类型)
- 洛谷P1115 最大字段和【线性dp】
- 如何在tomcat前部署一个nginx
- [HAOI 2015]按位或
- TensorFlow学习笔记——节点(constant、placeholder、Variable)
- 使用 IntraWeb (15) - 基本控件之 TIWEdit、TIWMemo、TIWText
- js返回页面顶部
- OleDbDataAdapter具体使用11
- python面向对象(二)