Método TreeSet lower() en Java

El método lower(E ele) de la clase TreeSet en Java se usa para devolver el elemento más grande de este conjunto, que es estrictamente menor que el elemento dado. Si no existe tal elemento en esta colección TreeSet, este método devuelve NULL.

Aquí, E es el tipo de los elementos mantenidos por esta colección.

Sintaxis :

public E lower(E ele)

Parámetros: Solo se necesita un elemento de parámetro . Es el elemento a partir del cual se determina el mayor valor del conjunto estrictamente menor que este valor.

Valor devuelto: Devuelve un valor de tipo E que es nulo o el valor requerido.

Excepciones:

  • ClassCastException : este método lanza una ClassCastException si el elemento especificado no se puede comparar con los elementos del conjunto.
  • NullPointerException : este método lanza una NullPointerException si el elemento dado es nulo y el conjunto usa un orden natural o el comparador no permite valores nulos.

Los siguientes programas ilustran el método lower() :

Programa 1 :

// Java program to illustrate lower() method
// of TreeSet class
  
import java.util.TreeSet;
public class GFG {
    public static void main(String args[])
    {
        TreeSet<Integer> tree = new TreeSet<Integer>();
  
        // Add elements to this TreeSet
        tree.add(10);
        tree.add(5);
        tree.add(8);
        tree.add(1);
        tree.add(11);
        tree.add(3);
  
        System.out.println(tree.lower(15));
    }
}

Salida :

11

Programa 2 (demostración de NullPointerException):

// Java program to illustrate lower() method
// of TreeSet class
  
import java.util.TreeSet;
public class GFG {
    public static void main(String args[])
    {
        TreeSet<String> tree = new TreeSet<String>();
  
        try {
  
            // Add elements to TreeSet
            tree.add("10");
            tree.add("5");
            tree.add("8");
            tree.add("1");
            tree.add("11");
            tree.add("3");
  
            System.out.println(tree.lower(null));
        }
        catch (Exception e) {
            e.printStackTrace();
        }
    }
}

Salida :

java.lang.NullPointerException
    at java.util.TreeMap.compare(TreeMap.java:1294)
    at java.util.TreeMap.getLowerEntry(TreeMap.java:494)
    at java.util.TreeMap.lowerKey(TreeMap.java:711)
    at java.util.TreeSet.lower(TreeSet.java:414)
    at GFG.main(GFG.java:20)

Programa 3 (demostración de ClassCastException):

// Java program to illustrate lower() method
// of TreeSet class
  
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.TreeSet;
  
public class GFG {
    public static void main(String args[])
    {
        TreeSet<List> tree = new TreeSet<List>();
  
        List<Integer> l1 = new LinkedList<Integer>();
        l1.add(1);
        l1.add(2);
        tree.add(l1);
  
        List<Integer> l2 = new LinkedList<Integer>();
        l2.add(3);
        l2.add(4);
  
        List<Integer> l3 = new ArrayList<Integer>();
        l2.add(5);
        l2.add(6);
  
        try {
            System.out.println(tree.lower(l3));
        }
        catch (Exception e) {
            System.out.println(e);
        }
    }
}

Salida :

Exception in thread "main" java.lang.ClassCastException: 
java.util.LinkedList cannot be cast to java.lang.Comparable
    at java.util.TreeMap.compare(TreeMap.java:1294)
    at java.util.TreeMap.put(TreeMap.java:538)
    at java.util.TreeSet.add(TreeSet.java:255)
    at GFG.main(GFG.java:17)

Referencia : https://docs.oracle.com/javase/7/docs/api/java/util/TreeSet.html#lower(E)

Publicación traducida automáticamente

Artículo escrito por psil123 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 *