leetcode练习 存在重复元素 III

文章目录

题目描述

在整数数组 nums 中,是否存在两个下标 ij,使得 nums [i]nums [j] 的差的绝对值小于等于 t ,且满足 ij 的差的绝对值也小于等于 ķ

如果存在则返回 true,不存在返回 false

示例:
输入: nums = [1,2,3,1], k = 3, t = 0
输出: true

示例2:
输入: nums = [1,0,1,1], k = 1, t = 2
输出: true

题目思路

暴力法
直接查找元素

class Solution {
    
    
 public boolean containsNearbyAlmostDuplicate(int[] nums, int k, int t) {
    
    
        /**
         * 遍历一遍,存在则返回,时间复杂度为O(n*k),空间复杂度为O(1)
         */
        for (int i = 0; i < nums.length; i++) {
    
    
            for (int j = i + 1; j <= i + k; j++) {
    
    
                if (j < nums.length) {
    
    
                    if (Math.abs((long)nums[j] - (long)nums[i]) <= t) return true;
                }
            }
        }
        return false;
    }

}

集合法



class Solution {
    
    
    public boolean containsNearbyAlmostDuplicate(int[] nums, int k, int t) {
    
    
        if (nums.length == 0 || k == 0){
    
    
            return false;
        }
        Set<Integer> set = new HashSet<>();
        for(int i = 0; i < nums.length; i++){
    
    
            if (t == 0){
    
    
                if (set.contains(nums[i])){
    
    
                    return true;
                }
            }
            else{
    
    
                for(int num : set){
    
    
                    if (Math.abs((long)nums[i] - (long)num) <= t){
    
    
                        return true;
                    }
                }
            }
            set.add(nums[i]);
            if (set.size() > k){
    
    
                set.remove(nums[i - k]);
            }
        }
        return false;
    }
}

猜你喜欢

转载自blog.csdn.net/qq_45019698/article/details/108267747
今日推荐