stringtranslate.com

Conjunto (tipo de datos abstractos)

En informática , un conjunto es un tipo de datos abstracto que puede almacenar valores únicos, sin ningún orden particular . Es una implementación informática del concepto matemático de conjunto finito . A diferencia de la mayoría de los otros tipos de colecciones , en lugar de recuperar un elemento específico de un conjunto, normalmente se prueba la pertenencia de un valor a un conjunto.

Algunas estructuras de datos de conjuntos están diseñadas para conjuntos estáticos o congelados que no cambian después de su construcción. Los conjuntos estáticos sólo permiten operaciones de consulta sobre sus elementos, como comprobar si un valor determinado está en el conjunto o enumerar los valores en algún orden arbitrario. Otras variantes, llamadas conjuntos dinámicos o mutables , permiten también la inserción y eliminación de elementos del conjunto.

Un conjunto múltiple es un tipo especial de conjunto en el que un elemento puede aparecer varias veces en el conjunto.

Teoría de tipos

En la teoría de tipos , los conjuntos generalmente se identifican con su función indicadora (función característica): en consecuencia, un conjunto de valores de tipo puede denotarse por o . (Los subtipos y subconjuntos pueden modelarse mediante tipos de refinamiento , y los conjuntos cocientes pueden reemplazarse por setoides ). La función característica de un conjunto se define como:

En teoría, muchas otras estructuras de datos abstractas pueden verse como estructuras establecidas con operaciones adicionales y/o axiomas adicionales impuestos a las operaciones estándar. Por ejemplo, un montón abstracto puede verse como una estructura establecida con una operación que devuelve el elemento de menor valor.min(S)

Operaciones

Operaciones básicas de teoría de conjuntos

Se pueden definir las operaciones del álgebra de conjuntos :

Conjuntos estáticos

Las operaciones típicas que puede proporcionar una estructura de conjunto estático S son:

Conjuntos dinámicos

Las estructuras de conjuntos dinámicos suelen agregar:

Algunas estructuras establecidas pueden permitir sólo algunas de estas operaciones. El coste de cada operación dependerá de la implementación y posiblemente también de los valores particulares almacenados en el conjunto y del orden en que se inserten.

Operaciones adicionales

Hay muchas otras operaciones que pueden (en principio) definirse en términos de lo anterior, como por ejemplo:

Se pueden definir otras operaciones para conjuntos con elementos de un tipo especial:

Implementaciones

Los conjuntos se pueden implementar utilizando varias estructuras de datos , que proporcionan diferentes compensaciones de tiempo y espacio para diversas operaciones. Algunas implementaciones están diseñadas para mejorar la eficiencia de operaciones muy especializadas, como nearesto union. Las implementaciones descritas como "uso general" normalmente se esfuerzan por optimizar las operaciones element_of, addy . deleteUna implementación sencilla es utilizar una lista , ignorando el orden de los elementos y teniendo cuidado de evitar valores repetidos. Esto es simple pero ineficiente, ya que operaciones como la pertenencia a un conjunto o la eliminación de elementos son O ( n ), ya que requieren escanear toda la lista. [b] En cambio, los conjuntos a menudo se implementan utilizando estructuras de datos más eficientes, particularmente varios tipos de árboles , intentos o tablas hash .

Como los conjuntos pueden interpretarse como una especie de mapa (mediante la función indicadora), los conjuntos se implementan comúnmente de la misma manera que los mapas (parciales) ( matrices asociativas ), en este caso en el que el valor de cada par clave-valor tiene el tipo de unidad o un valor centinela (como 1), es decir, un árbol de búsqueda binario autoequilibrado para conjuntos ordenados [ definición necesaria ] (que tiene O(log n) para la mayoría de las operaciones), o una tabla hash para conjuntos no clasificados (que tiene O(1) caso promedio, pero O(n) peor caso, para la mayoría de las operaciones). Se puede utilizar una tabla hash lineal ordenada [8] para proporcionar conjuntos ordenados de manera determinista.

Además, en lenguajes que admiten mapas pero no conjuntos, los conjuntos se pueden implementar en términos de mapas. Por ejemplo, un modismo de programación común en Perl que convierte una matriz en un hash cuyos valores son el valor centinela 1, para usar como un conjunto, es:

mis %elementos = mapa { $_ => 1 } @elementos ;         

Otros métodos populares incluyen matrices . En particular, un subconjunto de los números enteros 1.. n se puede implementar de manera eficiente como una matriz de bits de n bits , que también admite operaciones de unión e intersección muy eficientes. Un mapa de Bloom implementa un conjunto de manera probabilística, utilizando una representación muy compacta pero con el riesgo de una pequeña posibilidad de falsos positivos en las consultas.

Las operaciones de conjuntos booleanos se pueden implementar en términos de operaciones más elementales ( pop, cleary add), pero los algoritmos especializados pueden producir límites de tiempo asintóticos más bajos. Si los conjuntos se implementan como listas ordenadas, por ejemplo, el algoritmo ingenuo tomará un tiempo proporcional a la longitud m de S multiplicada por la longitud n de T ; mientras que una variante del algoritmo de fusión de listas hará el trabajo en un tiempo proporcional a m + n . Además, existen estructuras de datos de conjuntos especializadas (como la estructura de datos union-find ) que están optimizadas para una o más de estas operaciones, a expensas de otras.union(S,T)

Ayuda de idioma

Uno de los primeros lenguajes que admitió conjuntos fue Pascal ; muchos lenguajes ahora lo incluyen, ya sea en el lenguaje principal o en una biblioteca estándar .

Como se señaló en la sección anterior, en lenguajes que no admiten conjuntos directamente pero sí admiten matrices asociativas , los conjuntos se pueden emular utilizando matrices asociativas, usando los elementos como claves y usando un valor ficticio como valores, que se ignoran.

Conjunto múltiple

Una generalización de la noción de conjunto es la de multiconjunto o bolsa , que es similar a un conjunto pero permite valores repetidos ("iguales") (duplicados). Esto se utiliza en dos sentidos distintos: o los valores iguales se consideran idénticos y simplemente se cuentan, o los valores iguales se consideran equivalentes y se almacenan como elementos distintos. Por ejemplo, dada una lista de personas (por nombre) y edades (en años), se podría construir un conjunto múltiple de edades, que simplemente cuente el número de personas de una edad determinada. Alternativamente, se puede construir un conjunto múltiple de personas, donde dos personas se consideran equivalentes si sus edades son las mismas (pero pueden ser personas diferentes y tener nombres diferentes), en cuyo caso cada par (nombre, edad) debe almacenarse y seleccionar en una edad determinada da a todas las personas de una edad determinada.

Formalmente, es posible que los objetos en informática se consideren "iguales" bajo alguna relación de equivalencia pero aún distintos bajo otra relación. Algunos tipos de implementaciones de conjuntos múltiples almacenarán distintos objetos iguales como elementos separados en la estructura de datos; mientras que otros lo colapsarán a una versión (la primera encontrada) y mantendrán un recuento entero positivo de la multiplicidad del elemento.

Al igual que con los conjuntos, los conjuntos múltiples se pueden implementar naturalmente utilizando tablas hash o árboles, que producen diferentes características de rendimiento.

El conjunto de todas las bolsas sobre el tipo T viene dado por la expresión bolsa T. Si por multiconjunto uno considera idénticos los elementos iguales y simplemente los cuenta, entonces un multiconjunto puede interpretarse como una función desde el dominio de entrada hasta los enteros no negativos ( naturales). números ), generalizando la identificación de un conjunto con su función indicadora. En algunos casos, un conjunto múltiple en este sentido de conteo puede generalizarse para permitir valores negativos, como en Python.

Cuando no esté disponible una estructura de datos de conjuntos múltiples, una solución alternativa es utilizar un conjunto regular, pero anulando el predicado de igualdad de sus elementos para devolver siempre "no igual" en objetos distintos (sin embargo, estos todavía no podrán almacenar múltiples apariciones de el mismo objeto) o use una matriz asociativa que asigne los valores a sus multiplicidades enteras (esto no podrá distinguir entre elementos iguales en absoluto).

Operaciones típicas sobre bolsas:

Conjuntos múltiples en SQL

En las bases de datos relacionales , una tabla puede ser un conjunto (matemático) o un conjunto múltiple, dependiendo de la presencia de restricciones de unicidad en algunas columnas (lo que la convierte en una clave candidata ).

SQL permite la selección de filas de una tabla relacional: esta operación generalmente producirá un conjunto múltiple, a menos que DISTINCTse use la palabra clave para forzar que las filas sean todas diferentes, o que la selección incluya la clave principal (o candidata).

En ANSI SQL, la MULTISETpalabra clave se puede utilizar para transformar una subconsulta en una expresión de colección:

SELECCIONE expresión1 , expresión2 ... DESDE nombre_tabla ...    

es una selección general que se puede utilizar como expresión de subconsulta de otra consulta más general, mientras que

MULTISET ( SELECT expresión1 , expresión2 ... FROM nombre_tabla ...)    

transforma la subconsulta en una expresión de colección que se puede usar en otra consulta o en la asignación a una columna del tipo de colección apropiado.

Ver también

Notas

  1. ^ Por ejemplo, en Python pickse puede implementar en una clase derivada del integrado setde la siguiente manera:
    clase  Conjunto ( set ):  def  pick ( self ):  regresa  siguiente ( iter ( self ))
  2. ^ La inserción de elementos se puede realizar en tiempo O (1) simplemente insertando al final, pero si se evitan duplicados, esto lleva tiempo O ( n ).

Referencias

  1. ^ Python: pop()
  2. ^ Gestión y procesamiento de estructuras de datos complejas: tercer taller sobre sistemas de información e inteligencia artificial, Hamburgo, Alemania, 28 de febrero - 2 de marzo de 1994. Actas, ed. Kai contra Suerte, Heinz Marburger, pág. 76
  3. ^ Python Issue7212: recuperar un elemento arbitrario de un conjunto sin eliminarlo; consulte msg106593 sobre el nombre estándar
  4. ^ Función Ruby n.º 4553: agregar Set#pick y Set#pop
  5. ^ Síntesis inductiva de programas funcionales: planificación universal, plegado de programas finitos y abstracción de esquemas mediante razonamiento analógico, Ute Schmid , Springer, 21 de agosto de 2003, p. 240
  6. ^ Tendencias recientes en la especificación de tipos de datos: décimo taller sobre especificación de tipos de datos abstractos conjunto con el quinto taller COMPASS, S. Margherita, Italia, 30 de mayo - 3 de junio de 1994. Artículos seleccionados, volumen 10, ed. Egidio Astesiano, Gianna Reggio, Andrzej Tarlecki, pág. 38
  7. ^ Rubí: aplanar()
  8. ^ Wang, Thomas (1997), Tabla hash lineal ordenada, archivado desde el original el 12 de enero de 2006
  9. ^ Stephen Adams, "Conjuntos eficientes: un acto de equilibrio", Journal of Functional Programming 3(4):553-562, octubre de 1993. Consultado el 11 de marzo de 2015.
  10. ^ "Especificación del lenguaje ECMAScript 2015 - ECMA-262, sexta edición". www.ecma-international.org . Consultado el 11 de julio de 2017 .