Haskell - Arbres AVL P79515


Statement
 

pdf   zip

html

Si ja heu fet el problema dels Arbres Binaris de Cerca, ara us podeu lluïr extenent la vostra implementació a Arbres AVL. En aquest problema es demana que definiu operacions per inserir en AVLs i per comprovar-ne la correctesa.

Per als AVLs, es defineix el tipus següent:

data AVL a = E | N a Int (AVL a) (AVL a) -- l’enter guarda l’alçada deriving (Show)

Sobre aquest tipus cal crear les operacions següents:

  • insert :: Ord a => AVL a -> a -> AVL a

    Retorna el resultat d’inserir un element en un arbre AVL. Si l’element ja hi era, el resultat és l’arbre original.

  • create :: Ord a => [a] -> AVL a

    Retorna un arbre AVL tot inserint un rera l’altre la llista d’elements donats.

  • check :: AVL a -> (Bool,Int)

    Donat un arbre, si és AVL, retorna cert i la seva alçada; si no és AVL, retorna fals i -99.

    Els arbres buits es consideren d’alçada -1, les fulles és consideren d’alçada zero, ...);

Public test cases
  • Input

    create [1..3]
    create [1..5]
    check $ create [1..3]
    check $ create [1..5]
    check (E :: AVL Int)
    check (N 1 2 (N 2 1 (N 3 0 E E) E) E)
    

    Output

    N 2 1 (N 1 0 E E) (N 3 0 E E)
    N 2 2 (N 1 0 E E) (N 4 1 (N 3 0 E E) (N 5 0 E E))
    (True,1)
    (True,2)
    (True,-1)
    (False,-99)
    
  • Information
    Author
    Jordi Petit
    Language
    Catalan
    Official solutions
    Haskell
    User solutions
    Haskell