哈希、数组、规则[5990] 找出数组中的所有孤独数字

// 5990. 找出数组中的所有孤独数字
class Solution {
    public List<Integer> findLonely(int[] nums) {
        // 存放当前所有的数字
        Set<Integer> aux = new HashSet<>();
        // 存放当前出现多次的数字
        Set<Integer> aux1 = new HashSet<>();
        
        // 遍历数组,填充辅助sejt
        for(int i = 0; i < nums.length; i++){
           if(!aux.add(nums[i])){
               // 如果aux中存在nus[i]则返回false
               aux1.add(nums[i]);
           }
        }
        
        // 设置返回结果,则里可以适当的设置一下数组的初始化长度 即 (无重复的元素个数 - 出现多次的元素个数)
        List<Integer> ans = new ArrayList<>(aux.size() - aux1.size());
        for(int i = 0; i < nums.length; i++){
            
           // 是否为出现多次的元素
           // 是否存在左右相邻的元素(注意这里减的顺序 nums[i] - 1)  
           if(aux1.contains(nums[i]) || aux.contains(nums[i] - 1) || aux.contains(nums[i] + 1))
               continue;
            
            // 将符合的元素加入结果
            ans.add(nums[i]);
        }
        
        return ans;
    }
}

上一篇:196. go goroutine && channel


下一篇:Linux查看占用内存前10的命令