用IntStream生成0到n的流,并找出不在numSet中的数字列表
这是用IntStream生成0到n的流,并找出不在numSet中的数字-CSDN博客的升级版
给你一个含 n
个整数的数组 nums
,其中 nums[i]
在区间 [1, n]
内。请你找出所有在 [1, n]
范围内但没有出现在 nums
中的数字,并以数组的形式返回结果。
先看这题低配版的逻辑 用IntStream生成0到n的流,并找出不在numSet中的数字-CSDN博客
看完后,你发现直接把findFirst()后面的删掉,转成数组,再通过stream流把数组转为列表就欧克。上代码
public List<Integer> findDisappearedNumbers(int[] nums) {int n=nums.length;
// 创建一个包含nums中所有元素的setSet<Integer> numSet = Arrays.stream(nums).boxed().collect(Collectors.toSet());
// 使用Intstream生成o到n的流,并找出不在numSet中的数字int[] ints = IntStream.rangeClosed(1, n).filter(num -> !numSet.contains(num)).toArray();return Arrays.stream(ints).boxed().collect(Collectors.toList());}