Skip to content

Commit

Permalink
Merge pull request #1738 from Warclimb/main
Browse files Browse the repository at this point in the history
#7 - Python
  • Loading branch information
Roswell468 authored Feb 14, 2024
2 parents 5a5ca57 + c1336cc commit 80fca6c
Showing 1 changed file with 41 additions and 0 deletions.
41 changes: 41 additions & 0 deletions Roadmap/07 - PILAS Y COLAS/python/warclimb.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
"""
* EJERCICIO:
* Implementa los mecanismos de introducción y recuperación de elementos propios de las
* pilas (stacks - LIFO) y las colas (queue - FIFO) utilizando una estructura de array
* o lista (dependiendo de las posibilidades de tu lenguaje).
*
* DIFICULTAD EXTRA (opcional):
* - Utilizando la implementación de pila y cadenas de texto, simula el mecanismo adelante/atrás
* de un navegador web. Crea un programa en el que puedas navegar a una página o indicarle
* que te quieres desplazar adelante o atrás, mostrando en cada caso el nombre de la web.
* Las palabras "adelante", "atras" desencadenan esta acción, el resto se interpreta como
* el nombre de una nueva web.
* - Utilizando la implementación de cola y cadenas de texto, simula el mecanismo de una
* impresora compartida que recibe documentos y los imprime cuando así se le indica.
* La palabra "imprimir" imprime un elemento de la cola, el resto de palabras se
* interpretan como nombres de documentos.
"""
from collections import deque

# Implementamos las pilas y colas
# impelemntacion como pila
pila = []
pila.append("fuego") # añadimos fuego a la pila
pila.pop("fuego") # sacamos fuego de la pila

# implementacion como cola
cola = []

def enqueue(element):
cola.append(element)

def dequeue():
if len(cola) > 0:
return cola.pop(0)
else:
return None

# añadimos a la cola:
enqueue("fuego") # añadimos fuego a la cola
dequeue() # sacamos fuego de la cola

0 comments on commit 80fca6c

Please sign in to comment.