Professional Documents
Culture Documents
Introducción
En el módulo 9 definimos la clase hilera con sus operaciones y se desarrollaron algunos
ejemplos de aplicación con objetos de dicha clase. No obstante, en los ejercicios elabo-
rados no nos preocupamos por la forma como se representaran las hileras dentro de la
máquina. En este módulo veremos las diferentes formas de representar hileras dentro
de un computador.
Objetivos
1. R epresentar objetos de la clase hilera en arreglos de una dimensión.
2. Representar objetos de la clase hilera como listas ligadas.
3. Desarrollar los algoritmos para las diferentes operaciones de la clase hilera, repre-
sentándolas en vectores.
4. Desarrollar los algoritmos para las diferentes operaciones de la clase hilera, repre- El código ASCII se desarrolló en el ámbito
sentándolas como listas ligadas. de la telegrafía y se usó por primera vez comer-
cialmente como un código de teleimpresión
Preguntas básicas impulsado por los servicios de datos de Bell.
1. ¿Cuál es el tipo base para representar hileras como vectores? Bell había planeado usar un código de seis bits,
2. ¿Cuáles son las diferentes formas para representar hileras? derivado de Fieldata, que añadía puntuación
y letras minúsculas al más antiguo código de
Contenidos teleimpresión Baudot, pero se les convenció
10.1 Representación secuencial (en vector) para que se unieran al subcomité de la Agen-
10.2 Representación como listas ligadas cia de Estándares Estadounidense (ASA), que
habían empezado a desarrollar el código ASCII.
Baudot ayudó en la automatización del envío
y recepción de mensajes telegráficos, y tomó
muchas características del código Morse; sin
embargo, a diferencia del código Morse, Baudot
usó códigos de longitud constante. Comparado
con los primeros códigos telegráficos, el código
propuesto por Bell y ASA resultó en una reorga-
nización más conveniente para ordenar listas
(especialmente porque estaba ordenado alfa-
béticamente) y añadió características como la
‘secuencia de escape’. La Agencia de Estándares
Estadounidense (ASA), que se convertiría más
tarde en el Instituto Nacional Estadouniden-
se de Estándares (ANSI), publicó por primera
vez el código ASCII en 1963. El ASCII publicado
en 1963 tenía una flecha apuntando hacia
arriba (↑) en lugar del circunflejo (^) y una
flecha apuntando hacia la izquierda en lugar
del guión bajo (_). La versión de 1967 añadió
las letras minúsculas, cambió los nombres de
algunos códigos de control y cambió de lugar
los dos códigos de control ACK y ESC de la zona 10.1 Representación secuencial (en vector)
de letras minúsculas a la zona de códigos de En esta representación los caracteres de una hilera se colocan consecutivamente, siendo
control. ASCII fue actualizado en consecuencia cada carácter un dato del tipo primitivo char. Si, por ejemplo, tenemos la hilera S = “peste”,
y publicado como ANSI X3.4-1968, ANSI X3.4- cada carácter se almacena en una posición del vector, comenzando en la posición 1. El
1977 y, finalmente, ANSI X3.4-1986. Otros final de la hilera se controla con un símbolo especial; además, en la posición 0 del vector
órganos de estandarización han publicado tendremos el número de caracteres en el vector (figura 10.1):
códigos de caracteres que son idénticos a ASCII.
Estos códigos de caracteres reciben a menudo 0 1 2 3 4 5 6 7 8 9
el nombre de ASCII, a pesar de que ASCII se V 5 p e s t e \n
define estrictamente solamente por los es-
tándares ASA/ANSI. El código ASCII también Figura 10.1
está incluido en su probable relevo, Unicode,
En otras palabras, definimos la clase hilera derivada de la clase vector. Por consiguiente,
constituyendo los primeros 128 caracteres (o
podremos usar todos los métodos para manipular vectores. En nuestro caso particular,
los ‘más bajos’) . usaremos el método longitud y el método datoEnPosicion(i), el cual retorna el dato que
se halla en la posición i del vector. Con esta forma de representación algunas funciones
Tomado de wikipedia serán fácilmente implementables. Funciones como longitud, subHilera, concat tendrán
algoritmos fáciles y eficientes. En general, digamos que se definen vectores de tamaño
256 elementos. Para hileras muy cortas se desperdicia memoria, ya que no se utiliza la
totalidad del vector definido. Además, operaciones como inserciones y borrados tendrán
algoritmos no muy eficientes ya que implican mover datos en el vector.
Una de las operaciones a la cual se le ha dedicado mucho esfuerzo buscando que sea lo
más eficiente posible es la función posicion. Un algoritmo para dicha operación, bajo esta
representación secuencial, es:
1. entero posicion(hilera p)
2. entero i, j, m, n
3. m = p.longitud()
4. n = longitud()
5. i=1
6. j=1
7. while i <= m and j <= n do
8. if (datoEnPosicion(j) == p.datoEnPosicion(i)) then
9. i=i+1
10. j=j+1
11. if i > m then
12. return j – i + 1
13. end(if)
14. else
15. j=j–i+2
16. i=1
17. end(if)
18. end(while)
19. return 0
20. fin(posicion)
Este algoritmo tiene el inconveniente de que se devuelve en la hilera que invocó el méto-
do cuando encuentra una desigualdad entre datoEnPosicion(j) y P.datoEnPosicion(i).
Fíjese que cuando el resultado de la comparación de los caracteres de las posiciones i
y j (instrucción 8) es falso ejecuta las instrucciones 15 y 16, las cuales lo que hacen es
devolverse en la hilera que invocó el método (instrucción 15) y posicionarse nuevamente
en el primer carácter de la hilera p (instrucción 16).
Para evitar este retroceso se puede construir un vector, que llamaremos siguientes,
el cual contendrá en la posición i la posición del carácter de la hilera P con el cual se debe
realizar la siguiente comparación con el carácter de la posición j de la hilera que invocó
el método, y de esta forma no tener que devolvernos en la hilera que invocó el método.
Es decir, si siguientes[6] = 4 significa que cuando se encuentre una desigualdad
entre P.datoEnPosicion(6) y algún datoEnPosicion(J) el carácter datoEnPosicion(J)
habrá que compararlo con P.datoEnPosicion(4), esto es, el contenido de siguientes[6].
Si siguientes[6] es igual a 0 se continuará comparando datoEnPosicion(J + 1) con
P.datoEnPosicion(1).
entero posicion(p, t)
m = p.longitud()
n = longitud()
i=1
j=1
while i <= m and j <= n do
if (p.datoEnPosicion (i) == datoEnPosicion (j)) then
i=i+1
j=j+1
if i > m then
return j – i + 1
end(if)
else
if siguientes[i] > 0 then
i = siguientes[i]
else
i=1
j=j+1
end(if)
end(if)
end(while)
return 0
fin(posición)
primero → p → e → s → t → e ┤
Figura 10.2
Algoritmia II 115|
copiar (parámetro j). Nuestro algoritmo es:
Las instrucciones 17 a 20 ubican a p en el nodo a partir del cual hay que realizar la copia
de j caracteres.
Las instrucciones 22 a 26 copian j caracteres insertando nodos al final de la lista que está
construyendo. Fíjese que utilizamos los métodos insertar y ultimoNodo que corresponden
a la clase LSL.
metro otro objeto de la clase hilera y retorna un nuevo objeto de la clase hilera.
1. hilera concat(hilera t)
2. hilera s
3. nodoSimple p
4. s = copiaHilera()
5. p = t.primerNodo()
6. while (no t.finDeRecorrido(p)) do
7. s.insertar(p.retornaDato(), s.ultimoNodo())
8. p = p.retornaLiga()
9. end(while)
10. return s
11. fin(concat)
El anterior algoritmo concatena la lista s con la lista t creando una nueva lista y dejando
intactas las listas s y t.
En la instrucción 5 nos ubicamos con p en el primer nodo de la lista t enviada como pa-
rámetro, y en las instrucciones 6 a 9 insertamos todos los nodos de la lista t al final de la
lista s.
1. hilera copiaHilera()
2. hilera s
3. nodoSimple p
4. p = primerNodo()
5. s = new hilera()
6. while (no finDeRecorrido(p)) do
7. s.insertar(p.retornaDato(). s.ultimoNodo())
8. p = p.retornaLiga()
9. end(while)
10. return s
11. fin(copiaHilera)
Ejercicios propuestos
1. Elabore un algoritmo para la operación subHilera considerando las hileras representa-
das como vectores.
Algoritmia II 117|
5. Elabore un algoritmo para la operación replace considerando las hileras representadas
como vectores.