Essays.club - Ensayos gratis, notas de cursos, notas de libros, tareas, monografías y trabajos de investigación
Buscar

Listas Enlazadas. Estructuras de Datos

Enviado por   •  8 de Noviembre de 2018  •  Tarea  •  500 Palabras (2 Páginas)  •  1.241 Visitas

Página 1 de 2

Listas Enlazadas

Sergio Eduardo Gallegos González

Estructuras de Datos

Instituto IACC

28 de Octubre de 2018


INSTRUCCIONES: 

1) Teniendo la siguiente lista de 15 números enteros:

(95,6,88,32,598,63,796,45,1,158,31,86,59,701)

Realice un ejemplo en php que almacene dichos números, para lo cual considere lo siguiente: si el número es impar, debe ser insertado al inicio y si es par, insértelo en el intermedio de la lista.

* Utilice como guía el recurso adicional.

2) Luego de insertar los 15 elementos:

a) Elimine 3 elementos: uno al inicio, uno al final y uno en la posición de su preferencia, y luego realice un ciclo que imprima los elementos restantes de la lista.

b) Inserte 10 elementos más. ¿Cuál es el límite de inserción de su lista? Explique brevemente.

c) Ejecute un ciclo para vaciar la lista eliminando uno a uno los elementos (sin utilizar la función vaciar del recurso adicional).

DESARROLLO:

class Nodo

{

public $dato;

public $proximo;

public function __construct($elemento)

{

$this->dato = $elemento;

$this->proximo = null;

}

}

class ListaEnlazada

{

public $primero = null;

private static $count = 0;

public function ContarNodos()

{

return self::$count;

}

public function InsertarPrimerovacia($elemento) {

$this->primero = new Nodo($elemento);

$this->proximo = null;

self::$count++;

}

public function InsertarPrimero($elemento) {

if ($this->primero == null) {

$this->primero = new Nodo($elemento);

} else {

$aux = new Nodo($elemento);

$aux->proximo = $this->primero;

$this->primero = $aux;

}

self::$count++;

}

public function InsertarUltimo($elemento) {

if ($this->primero == null) {

$this->primero = new Nodo($elemento);

} else {

$actual = $this->primero;

while ($actual->proximo != null)

{

$actual = $actual->proximo;

}

$actual->proximo = new Nodo($elemento);

}

self::$count++;

}

public function InsertarDespues($elemento,$key){

if($key == 0){

$this->InsertarPrimero($elemento);

}

else{

$aux = new Nodo($elemento);

$actual = $this->primero;

$anterior = $this->primero;

for($i=0;$i<$key;$i++)

{      

$anterior = $actual;

$actual = $actual->proximo;

}

$anterior->proximo = $aux;

$aux->proximo = $actual;

self::$count++;

}

}

public function EliminarPrimero() {

if ($this->primero != null) {  

$actual = $this->primero;

$this->primero = $actual->proximo;

}

self::$count--;

}

 public function EliminarDespues($key){

if($key == 0){

$this->EliminarPrimero($elemento);

}

else{

$actual = $this->primero;

$anterior = $this->primero;

for($i=0;$i<$key;$i++)

{      

$anterior = $actual;

$actual = $actual->proximo;

}

$anterior->proximo = $actual->proximo;

self::$count--;

}

}

public function EliminarNodo($key)

{

$actual = $anterior = $this->primero;

while($actual->dato != $key) {

$anterior = $actual;

$actual = $actual->proximo;

}

if ($actual == $anterior) {

$this->primero = $actual->proximo;

}

$anterior->proximo = $actual->proximo;

self::$count--;

...

Descargar como  txt (5.6 Kb)   pdf (407.1 Kb)   docx (150.2 Kb)  
Leer 1 página más »
Disponible sólo en Essays.club