DoubleStream reduce (doble identidad, DoubleBinaryOperator op) en Java con ejemplos

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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *