Você está na página 1de 57

Asignatura: Estructura de Datos Avanzada

Tema: Listas
Diplomado en Informtica Aplicada
Centro de Estudio de Ingeniera de Sistemas (CEIS)
Instituto Superior Politcnico Jos Antonio Echeverra (CUJAE)
Tema 2: Listas
Contenido
Tipo de Dato Abstracto (TDA).
Listas lineales.
Tipos de implementaciones de listas.
Pilas y Colas.
Implementacin en C++ y Java.
Bibliografa
Data Structures / Algorithms in Java. Robert
Lafore. Pginas: 33-247.
El C++. Lenguaje de Programacin. Bjarne
Stroustrup. Pginas 143-180.
Tipo de Dato Abstracto
Un Tipo de Dato Abstracto (TDA) se define como
un modelo matemtico con un conjunto de
operaciones que se definen sobre este modelo.

Define un tipo de dato e incluye la descripcin de
todo el comportamiento asociado al dato.

No est asociado a ninguna implementacin. El
implementar un TDA supone la traduccin de las
especificaciones del TDA en las sintaxis de un
lenguaje de programacin en particular.
Tipo de Dato Abstracto
Al implementar un TDA en la POO, se debe
encapsular toda la lgica de almacenamiento y lograr
que la comunicacin sea a travs de los mtodos de
acceso que se definen en la interfaz pblica de la
implementacin del TDA.
Conceptos bsicos
Se denomina Nodo, elemento o tambin tem, a la
unidad de informacin ms elemental o indivisible.
TDA Lista Lineal
Una lista lineal es un conjunto de N nodos l
1
, l
2
,
l
n
, con n 0, cuyas propiedades estructurales
esenciales incluyen slo las posiciones lineales
(unidimensionales) relativas de los nodos; para ella
se definen operaciones como las siguientes:
Tener acceso a un nodo.
Insertar y eliminar un nodo en la lista.
Combinar dos o ms listas en una.
Dividir una lista en dos o ms listas.
Determinar la cantidad de nodos de la lista.
Ordenar la lista de acuerdo a un criterio.
Buscar un elemento bajo una condicin.
TDA Lista Lineal
Aclaraciones:
n = 0 denota a la lista vaca, o sea, una lista que no
tiene elementos.
Si n > 0, l
1
es el primer nodo.
Si 1 < k < n, l
k
es precedido por el nodo l
k+1
y
seguido por el nodo l
k+1.
Si n > 0, I
N
es el ltimo nodo.
TDA Lista Lineal
Una misma definicin de un TDA puede conllevar a
implementaciones diferentes en dependencia de las
necesidades, as como de las caractersticas del
lenguaje en el que se va a desarrollar dicha
implementacin.

Por su forma de almacenamiento, la lista lineal se
puede implementar en una de las siguientes
disposiciones:
Secuencial
Enlazada

Lista Secuencial
Una de las formas ms simples de implementacin
de este TDA es usando un arreglo unidimensional.

Todos los elementos de la lista se almacenan en
posiciones de memoria consecutivas. Por se habla
de disposicin secuencial en la memoria de la
computadora.

A la lista se le conoce como lista secuencial.

Lista Secuencial



. . .
1 2 3 4 5 N

ndice del ltimo Cantidad fsica
nodo de la lista de elementos
del arreglo
Ventajas y desventajas
Ventajas
Con esta disposicin se accede a cualquier elemento
de la estructura de datos en tiempo constante.

Desventajas
Al asignar el arreglo en tiempo de compilacin debe
establecerse un lmite a priori sobre el nmero de
elementos que pueden ser almacenados en las
listas.

Para inserciones y eliminaciones frecuentes hay que
hacer corrimientos costosos.
Lista enlazada
En una lista enlazada se asigna memoria para el
almacenar los elementos de la lista conforme se va
necesitando, es decir a medida que se aaden o
insertan los elementos, y se conectan los elementos
de la lista con punteros.

La memoria es liberada cuando ya no se necesita
ms un elemento en la lista.

Esquemticamente una lista enlazada se representa
por una secuencia de nodos conectados por enlaces.
Lista enlazada
Cada nodo est conectado al siguiente por un solo
enlace, a esta estructura de datos se llama lista
simplemente enlazada.
primero
Lista enlazada
Un nodo de una lista simplemente enlazada
contiene dos campos: datos (contiene un elemento
de la lista) y siguiente (almacena un enlace al
siguiente nodo de la lista).

El campo siguiente del ltimo nodo contiene un
smbolo especial que indica el final de las lista.

Se accede a la lista por medio de un apuntador al
primer elemento y solo se puede recorrer la lista en
un sentido, del primer nodo al ltimo nodo.
Lista doblemente enlazada
Cada nodo contiene tres campos: un campo que
almacena el elemento de la lista y los otros dos
almacenan los enlaces a los nodos precedente y
siguiente de la lista.
Se usan punteros nulos para marcar ambos
extremos de la lista.
primero

Lista enlazada circular
El campo siguiente del ltimo nodo de la lista apunta
al primer nodo de la lista.
primero
Lista doblemente enlazada circular
El campo siguiente del ltimo nodo apunte al primer
nodo de la lista y el campo anterior del primer nodo
apunte al ltimo nodo de la lista.
primero

Ventajas y desventajas
Ventajas
No es preciso conocer la cantidad de elementos en
tiempo de compilacin.
Ni las inserciones ni las eliminaciones implican
realizar corrimientos de los elementos de la lista.

Desventajas
No permite el acceso directo a un elemento arbitrario
de la lista. Para acceder al i-simo elemento,
debemos recorrer la lista, comenzando por el primer
nodo, hasta llegar al elemento deseado.


Pila
primero
(tope)
Una pila (stack) es un conjunto dinmico
que obedece al orden LIFO.

La pila es un caso particular de lista en la
que todas las inserciones y extracciones de
elementos se realizan por un solo extremo,
llamado el tope de la pila.




Operaciones en pilas
Estas operaciones reciben nombres especiales:
Insertar (x). Inserta x en S. (Apilar o Push).

Tope. Devuelve el elemento que fue insertado ms
recientemente en S. (Cima).

Eliminar. Devuelve el elemento que fue insertado
ms recientemente y lo elimina. (Desapilar o Pop).

Vaca. Devolver si la pila est vaca.
Cola
Una cola (queue) es un conjunto dinmico
que obedece al orden FIFO.

La cola es un caso particular de lista para
la que todas las inserciones se realizan
siempre por un extremo y las extracciones
se realizan siempre por el extremo opuesto.
primero
ltimo
Operaciones en colas
Estas operaciones reciben nombres especiales:
Insertar (x). Inserta x en la cola.

Primero. Devuelve el elemento que lleva ms
tiempo en la cola.

Eliminar. Devuelve el elemento que lleva ms
tiempo en la cola y lo elimina. (Avanzar)

Vaca. Devolver si la cola est vaca.
Ejemplos
Un ejemplo de pila lo constituye el mecanismo que
establecen los lenguajes de programacin para
garantizar las llamadas anidadas a subprogramas
dentro de una aplicacin.

Un ejemplo de cola es la cola de impresin en el
sistema operativo Windows. Cada usuario de una red
de Windows coloca sus trabajos de impresin y el
sistema lo imprime en el mismo orden en que fueron
insertados en la cola de impresin.

Cola secuencial


. . .
0 1 2 3 4 N-1

ndice del ndice del
primer elemento ltimo elemento

Cantidad fsica
de elementos

Cola secuencial
No hay correspondencia entre la posicin del
ltimo nodo y la cantidad de nodos de la cola.

La condicin de cola llena y de cola vaca, no se
pueden verificar haciendo uso del ndice del
arreglo.
Cola circular

0 1
N-1 2
.
. 3

13 4

12 5

11 6
10 7
9 8

La cola circular propone tratar el arreglo como un
crculo donde cuando aLength se hace igual a aSize,
el siguiente elemento es el de ndice 0. Esto permite
utilizar todos los espacios que quedan libres en el
arreglo luego de realizar eliminaciones de nodos.
Implementacin en C++
TSeqList
TGSeqList
TLinkedList
TGLinkedList
TDoubleList TCircLinked
TBaseList
TDoubleCirc
TNode
TDoubleNode
Iteradores en Java
Los iteradores son objetos que contienen referencias a
los elementos en la estructura de datos para atravesar
esta estructura.
Iteradores en Java
class ListIterator {
private Node aCursor;
private Node aPrevios;
private LinkedList aList;
public ListIterator(LinkedList list) {
aList = list;
reset();
}
public void reset(){
aCursor = aLIst.getFirst();
aprevios = null;
}
public void nextNode() {
aPrevios = aCursor;
aCursor = cursor.aNext;
}

}
Iteradores en Java
class ListIterator {

public Node getCursor() {
return aCursor;
}
public boolean atEnd() {
return (aCursor.aNext == null);
}
}
Iteradores en Java
class ListIterator {

public void insertAfter(int 2) {
Node node = new Node(3);
if (aList.isEmpty()) {
aList.setFirst(node);
aCursor =node;
}
else {
node.aNext = aCursor.aNext;
aCursos.aNext = node;
nextNode();
}
}
}
Iteradores en Java
Agregar un mtodo a LinkedList

class LinkedList {

public ListIterator getIterator() {
return new ListIterator(this);
}
}
Iteradores en Java
public static void main(String[] args){
LinKedList list = new LinkedList();
ListIterator it = list.getIterator();
it.insertAfter(21);
it.insertAfter(8);
it.insertAfter(24);
list.displayList();
}
Facilidades de los lenguajes
Los lenguajes de programacin proporcionan utilidades
que permiten al desarrollador crear estructuras de
datos.

Java posee el API Collections.

Se introdujo con la Java2SE (versin 1.2 de Java
Standar Edition)

Objetivo: proporcionar clases, interfaces y algoritmos
para utilizar las estructuras de una manera estandar.

Base del API Collections de Java
Collection Map
List Set
SortedSet
SortedMap
Conjunto de interfaces que forman la base del API
Collections.
API Collections de Java
La jerarqua tiene dos races:

Collection trabaja sobre conjuntos de elementos
singulares.

Map trabaja sobre pares de valores.

Interfaz Collection
boolean add(Object element)
boolean remove(Object element)
int size()
boolean isEmpty()
boolean contains(Object element)
Iterator iterator()
boolean containsAll(Collection collection)
boolean addAll(Collection collection)
void clear()
void removeAll(Collection collection)
void retainAll(Collection collection)
Interfaz Collection
Collection es una interfaz (no proporciona ninguna
implementacin concreta).
La base para las clases concretas del API se
encuentra en la clase AbstractCollection.

Para crear estructuras se debe:
1. Crear una clase que implemente todos los
mtodos de Collection.
2. Crear una clase que herede de AbstractCollection
e implemente los mtodos necesarios, como por
ejemplo size().
Interfaz List
Define un conjunto de datos ordenados permitiendo
elementos duplicados.
Aade operaciones con ndice y la posibilidad de
trabajar con una parte de la lista.

void add(int index, Object element)
boolean addAll(int index,
Collection collection)
Object get(int index)
int indexOf(Object object)
int lastIndexOf(Object object)
Object remove(int index)
Object set(int index, Object element)
Interfaz List
ListIterator listIterator()
ListIterator listIterator(int comienzo)
List sublist(int inicio, int fin)

Los dos primeros mtodos devuelven una vista de la
coleccin de datos (Iterator) que permiten recorrer
sus elementos.

La interfaz ListIterator extiende a Iterator
permitiendo realizar recorridos bidireccionales, aadir
o modificar elementos de la coleccin.

Ejemplo
List list = .........
ListIterator iterador =
list.listIterator(list.size());
while (iterator.hasPrevious()) {
Object element = iterator.previous();
System.out.println(element);
}

Se crea un iterador cuyo cursor se encuentra en la
ltima posicin de la lista.
Se recorre la lista en orden inverso mostrando los
elementos por pantalla.
La combinacin de List-ListIterator proporciona una
forma elegante de recorrer la estructuras de datos.
Interfaz List
En el API Collections dispone de dos
implementaciones concretas de la interfaz List:

ArrayList (Vector en Java 1.1 con mtodos sincronizados)
LinkedList.
List
ArrayList LinkedList
Clases ArrayList y LinkedList
ArrayList: No tiene ningn mtodo sincronizado
(soporta el acceso concurrente a los datos).

Se representa internamente utilizando un array de
objetos.

Comienza con un tamao que se puede especificar
en el constructor. Cuando se llena, aumenta su
tamao en un 50% o 100% dependiendo del SDK.

LinkedList: Est implementada mediante una lista de
nodos doblemente enlazada.
Ejemplo
import java.util.*;
public class Ejemplo {
public static void main(String[] args) {
List list = new ArrayList();
list.add(Liz);
list.add(Rosa);
list.add(Marta);
list.add(Luis);
System.out.println(list);
List list1 = new LinkedList(list);
Iterator it = list1.iterator();
while (it.hasNext()) {
System.out.print(it.next() + );
}
}
}
Salida:
[Liz, Rosa, Marta, Luis]
Liz Rosa Marta Luis
Interfaz Set
Hereda de Collection y no aade ningn mtodo.
Representa un conjunto de datos (sin duplicados).

Si se intenta aadir un elemento que ya se
encontraba, no se producir ningn cambio.

Para determinar si un dato ya se encuentra se basan
en los mtodos de la clase Object: equals() y
hashCode().

El API de Collections proporciona dos
implementaciones de esta interfaz :
HashSet y TreeSet.
Interfaz Set
HashSet y TreeSet son implementaciones de la
interfaz Set.

AbstractSet implementa algunos mtodos de la
interfaz Set y sobreescribe los mtodos equals y el
mtodo hashCode().
Set
HashSet TreeSet
AbstractSet
Interfaz Set
Implementa el conjunto de datos utilizando un tabla
hash (HashMap).

Los elementos no estn ordenados y pueden variar la
posicin por las operaciones de balanceo.

Al basarse en una tabla hash para aadir objetos
propios hay que sobreescribir el mtodo hashCode().

Por defecto, dos elementos se consideren iguales si:
Devuelven true al utilizar equals
Devuelven el mismo hashCode()
Interfaz Set
class MyObject {
private int aValue = -1;
public MyObject(int pValue) {
this.aValue = pValue;
}
public boolean equals(Object pObj) {
if (!(pObj instanceof MyObject))
return false;
if (((MyObject)pObj).value == this.aValue)
return true;
else
return false;
}
}
Interfaz Set
Set set = new HashSet();
set.add(new MyObject(5));
set.add(new MyObject(7));
System.out.println(set.contains(new MyObject(5));
Se cre una clase MyObject y se sobreescribi el
mtodo equals(). As dos instancias son iguales si
tienen el mismo valor pero no se sobre escruibi el
mtodo hashCode().

Por lo tanto, contains() devuelve false porque se le
pasa una instancia diferente (hashCode diferente que
el de la instancia del conjunto con valor 5).
false
Interfaz Set
class MyObject {
private int aValue = -1;
public MyObject(int pValue) {
this.aValue = pValue;
}
public boolean equals(Object pObj) {
if (!(pObj instanceof MyObject))
return false;
if (((MyObject)pObj).value == this.aValue)
return true;
else
return false;
}
public int hashCode() {
return aValue;
}
}
Sobreescribir
hasCode()
Interfaz TreeSet
Esta implementacin utiliza un TreeMap para
almacenar los objetos.
Los objetos se guardan ordenados ascendentemente
segn el orden del comparador que se pase en el
constructor.
El comparador debe ser consecuente con el mtodo
equals() de los elementos del conjunto ya que el
funcionamiento de la estructura se basa en el mtodo
equals pero el algoritmo de ordenamiento se basa en
el mtodo compareTo() de la interfaz Comparator.
Si dos objetos son iguales paar el mtodo
compareTo() lo sern para el conjunto (no se inserta)
aunque el mtodo equals() diga lo contrario.
Ejemplo
import java.util.*;
public class Ejemplo {
public static void main(String[] args) {
Set set = new HashSet();
set.add(Ins);
set.add(Ana);
set.add(Sonia);
set.add(Laura);
set.add(Rebeca);
System.out.println(set);
Set sortedSet = new TreeSet(set);
System.out.println(sortedSet);
}
}
Salida:
[Laura, Ins, Sonia, Rebeca, Ana]
[Ana, Ins, Laura, Rebeca, Sonia]
Interfaz Map
Define una estructura de datos que mapea claves
con valores sin permitir claves duplicadas.

Object put(Object clave, Object valor)
void putAll(Map mapa)
void clear()
Object remove(Object clave)
Object get(Object clave)
boolean containsKey(Object key)
boolean containsValue(Object value)
int size()
boolean isEmpty()
Set keySet()
Collection values()
Set entrySet()
Interfaz Map
La API Collections ofrece dos implementaciones de la
interfaz Map: HashMap y TreeMap.
Interfaz HashMap
Utiliza una tabla hash.
Permite el valor null tanto como clave o valor.
No garantiza el orden de los elementos.
Tiene dos parmetros que afectan a su rendimiento :
capacidad inicial (capacidad que tiene la tabla
cuando es creada) y factor de carga (medida de la
cantidad que podemos dejar llenarse a la tabla antes
de que su tamao deba aumentarse. Cuando el
nmero de entradas en la tabla excede el producto
del factor de carga y la capacidad actual, se doblar
la capacidad llamando al mtodo rehash.
Si la capacidad inicial es mayor que el mximo
nmero de entradas dividido por el factor de carga, la
operacin de rehash nunca ocurrir.
Interfaz TreeMap
La implementacin de esta clase ordena los
elementos por orden ascendente de clave ya sea el
orden natural de los objetos o el orden establecido
por el comparador que se pase en el constructor.

Como ocurre en la clase TreeSet el comparador ha
de ser consistente con el mtodo equals().

Você também pode gostar