Java8中的新特性 removeif

有一个List <Map.> ,要看其中的map是否包含有指定的value值,如果有则移除这个map,我最开始运用的是for循环,但是效率可能会低一些,后来了解到了可以使用removeif进行判断,了解了一下,以前从来没有用过这个东西,所以记录一下
代码:
在这里插入图片描述
点进去源码看一下:
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,可以使用多种方法对数组进行去重操作。以下是几种常见的方法: 1. 使用Set集合:将数组元素添加到Set集合,由于Set集合的特性不允许有重复元素,最后再将Set集合转换回数组。 示例代码如下: ```java import java.util.HashSet; import java.util.Set; public class ArrayDuplicateRemoval { public static int[] removeDuplicates(int[] arr) { Set<Integer> set = new HashSet<>(); for (int num : arr) { set.add(num); } int[] result = new int[set.size()]; int i = 0; for (int num : set) { result[i++] = num; } return result; } public static void main(String[] args) { int[] arr = {1, 2, 3, 3, 4, 4, 5}; int[] result = removeDuplicates(arr); for (int num : result) { System.out.print(num + " "); } } } ``` 输出结果:1 2 3 4 5 2. 使用List集合:将数组元素添加到List集合,然后利用List集合的contains方法判断是否已存在该元素,最后再将List集合转换回数组。 示例代码如下: ```java import java.util.ArrayList; import java.util.List; public class ArrayDuplicateRemoval { public static int[] removeDuplicates(int[] arr) { List<Integer> list = new ArrayList<>(); for (int num : arr) { if (!list.contains(num)) { list.add(num); } } int[] result = new int[list.size()]; for (int i = 0; i < list.size(); i++) { result[i] = list.get(i); } return result; } public static void main(String[] args) { int[] arr = {1, 2, 3, 3, 4, 4, 5}; int[] result = removeDuplicates(arr); for (int num : result) { System.out.print(num + " "); } } } ``` 输出结果:1 2 3 4 5 3. 使用双重循环:遍历数组,将每个元素与后面的元素进行比较,如果相同则跳过,不同则将其添加到新数组。 示例代码如下: ```java public class ArrayDuplicateRemoval { public static int[] removeDuplicates(int[] arr) { int len = arr.length; for (int i = 0; i < len - 1; i++) { for (int j = i + 1; j < len; j++) { if (arr[i] == arr[j]) { arr[j] = arr[len - 1]; len--; j--; } } } int[] result = new int[len]; System.arraycopy(arr,0, result, 0, len); return result; } public static void main(String[] args) { int[] arr = {1, 2, 3, 3, 4, 4, 5}; int[] result = removeDuplicates(arr); for (int num : result) { System.out.print(num + " "); } } } ``` 输出结果:1 2 3 4 5

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值