El tipo de los árboles binarios
El árbol binario
1 2 3 4 5 6 |
5 / \ / \ 3 7 / \ / \ 1 4 6 9 |
se puede representar por
1 2 3 |
ejArbol = Nodo (Nodo (Hoja 1) 3 (Hoja 4)) 5 (Nodo (Hoja 6) 7 (Hoja 9)) |
El tipo de los árboles binarios se puede definir por
1 2 |
data Arbol = Hoja Int | Nodo Arbol Int Arbol |
Definir las funciones
1 2 |
ocurre :: Int -> Arbol -> Bool aplana :: Arbol -> [Int] |
tales que
ocurre m a
se verifica sim
ocurre en el árbola
. Por ejemplo,
1 2 |
ocurre 4 ejArbol == True ocurre 10 ejArbol == False |
aplana a
es la lista obtenida aplanando el árbola
. Por ejemplo,
1 |
aplana ejArbol == [1,3,4,5,6,7,9] |
Soluciones
A continuación se muestran las soluciones en Haskell y las soluciones en Python.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
data Arbol = Hoja Int | Nodo Arbol Int Arbol ejArbol :: Arbol ejArbol = Nodo (Nodo (Hoja 1) 3 (Hoja 4)) 5 (Nodo (Hoja 6) 7 (Hoja 9)) ocurre :: Int -> Arbol -> Bool ocurre m (Hoja n) = m == n ocurre m (Nodo i n d) = m == n || ocurre m i || ocurre m d aplana :: Arbol -> [Int] aplana (Hoja n) = [n] aplana (Nodo i n d) = aplana i ++ [n] ++ aplana d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
from dataclasses import dataclass @dataclass class Arbol: pass @dataclass class Hoja(Arbol): x: int @dataclass class Nodo(Arbol): i: Arbol x: int d: Arbol ejArbol = Nodo(Nodo(Hoja(1), 3, Hoja(4)), 5, Nodo(Hoja(6), 7, Hoja(9))) def ocurre(m: int, a: Arbol) -> bool: match a: case Hoja(n): return m == n case Nodo(i, n, d): return m == n or ocurre(m, i) or ocurre(m, d) assert False def aplana(a: Arbol) -> list[int]: match a: case Hoja(n): return [n] case Nodo(i, n, d): return aplana(i) + [n] + aplana(d) assert False |