迭代和过滤数组2D Java 8

时间:2018-12-21 05:53:46

标签: java java-8 java-stream java-9

我有一个像这样的数组:

int[] array_example = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
Long count_array = Arrays.stream(array_example)
                      .filter(x -> x>5)
                      .count();

和类似的二维数组:

int[][] matrix_example = {{0, 1, 2, 3, 4}, {5, 6, 7, 8, 9}};
Long count_matrix = 0L;
for(int[] temp: matrix_example){
    for(int x_y: temp){
        if(x_y > 5)
           count_matrix++;
    }
}

如何获取大于等于Java 8或更高矩阵的x的元素数量?

2 个答案:

答案 0 :(得分:3)

您可以使用flatMapToInt创建矩阵的IntStream,然后像之前一样使用filtercount

Long count_matrix = Arrays.stream(matrix_example) // Stream<int[]>
        .flatMapToInt(Arrays::stream) // IntStream
        .filter(x_y -> x_y > 5) // filtered as per your 'if'
        .count(); // count of such elements

答案 1 :(得分:1)

这是解决问题的一种方法:

long count = Arrays.stream(matrix_example)
                   .mapToLong(a -> Arrays.stream(a).filter(x -> x > 5).count()).sum();
  • 通过matrix_exampleArrays.stream创建一个流
  • 通过5将每个数组映射到给定元素大于mapToLong的次数
  • 然后我们将所有这些金额相加并通过sum
  • 进行计数