DoubleStream reduce(doble identidad, DoubleBinaryOperator op) realiza una reducción de los elementos de esta secuencia, utilizando el valor de identidad proporcionado y una función de acumulación asociativa, y devuelve el valor reducido.
Una operación de reducción o pliegue toma una secuencia de elementos de entrada y los combina en un solo resultado de resumen, como encontrar la suma o el máximo de un conjunto de números. Un operador o función op es asociativo si se cumple lo siguiente:
(a op b) op c == a op (b op c)
Esta es una operación terminal, es decir, puede atravesar el flujo para producir un resultado o un efecto secundario. Una vez realizada la operación de terminal, la canalización de flujo se considera consumida y ya no se puede utilizar.
Sintaxis:
double reduce(double identity, DoubleBinaryOperator op)
Parámetros:
- identidad : El valor de identidad para la función de acumulación.
- DoubleBinaryOperator: una operación sobre dos operandos de doble valor y que produce un resultado de doble valor.
- op : una función asociativa sin estado para combinar dos valores.
Valor de Retorno: El resultado de la reducción.
Ejemplo 1 :
// Java code for DoubleStream reduce // (double identity, DoubleBinaryOperator op) import java.util.*; import java.util.stream.DoubleStream; class GFG { // Driver code public static void main(String[] args) { // Creating a DoubleStream DoubleStream stream = DoubleStream.of(1.2, 2.3, 3.4, 4.5, 5.6); // Using DoubleStream reduce // (double identity, DoubleBinaryOperator op) double answer = stream.reduce(5, (num1, num2) -> (num1 + num2)); // Displaying the result System.out.println(answer); } }
Producción :
22.0
Ejemplo 2:
// Java code for DoubleStream reduce // (double identity, DoubleBinaryOperator op) import java.util.*; import java.util.stream.DoubleStream; class GFG { // Driver code public static void main(String[] args) { // Creating a DoubleStream DoubleStream stream = DoubleStream.of(2.1, 3.2, 4.3, 5.4, 6.5); // Using DoubleStream reduce // (double identity, DoubleBinaryOperator op) double answer = stream.reduce(3, (num1, num2) -> (num1 * num2) * 2); // Displaying the result System.out.println(answer); } }
Producción :
97367.96160000002
Publicación traducida automáticamente
Artículo escrito por Sahil_Bansall y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA