-- |
-- Module      : Dinamica
-- Description : El patrón de programación dinámica.
-- License     : Creative Commons
-- Maintainer  : José A. Alonso
-- 
-- = El patrón de programación dinámica
-- 
-- Este módulo contiene la definición del patrón de programación dinámica
-- estudiado en el <http://bit.ly/1LIxi0u tema 15> del curso. 
--
-- Además, en el tema se incluye como de casos de aplicación del patrón 
--
-- * <http://bit.ly/1LIxkWi la sucesión de Fibonacci>,
-- * <http://bit.ly/1LIxlth el producto de cadenas de matrices>,
-- * <http://bit.ly/1IsuUn1 los árboles binarios de búsqueda optimales>,
-- * <http://bit.ly/1IsuYDe los caminos mínimos entre todos los pares de
--   nodos de un grafo> y 
-- * < http://bit.ly/1Isv0 el problema del viajante>.

module I1M.Dinamica (module I1M.Tabla, dinamica)  where

import I1M.Tabla
import Data.Array

-- | (dinamica f r) wa la tabla de cálculo dinámica de la función f en
-- el rango r.
dinamica :: Ix i => (Tabla i v -> i -> v) -> (i,i) -> Tabla i v
dinamica :: forall i v. Ix i => (Tabla i v -> i -> v) -> (i, i) -> Tabla i v
dinamica Tabla i v -> i -> v
calcula (i, i)
cotas = Tabla i v
t
  where t :: Tabla i v
t = [(i, v)] -> Tabla i v
forall i v. Eq i => [(i, v)] -> Tabla i v
tabla [(i
i,Tabla i v -> i -> v
calcula Tabla i v
t i
i) | i
i <- (i, i) -> [i]
forall a. Ix a => (a, a) -> [a]
range (i, i)
cotas]