Войти в систему

Home
    - Создать дневник
    - Написать в дневник
       - Подробный режим

LJ.Rossia.org
    - Новости сайта
    - Общие настройки
    - Sitemap
    - Оплата
    - ljr-fif

Редактировать...
    - Настройки
    - Список друзей
    - Дневник
    - Картинки
    - Пароль
    - Вид дневника

Сообщества

Настроить S2

Помощь
    - Забыли пароль?
    - FAQ
    - Тех. поддержка



Пишет delamon ([info]delamon) в [info]programming
@ 2006-01-07 02:17:00

Previous Entry  Add to memories!  Tell a Friend!  Next Entry
Переписываем и хаскеля в камл
Тут в http://www.livejournal.com/community/ru_lambda/5507.html написана замечательная программа.
Я попытался переписать ее на камл, получилось почти буква в букву:
let  scanl f i l = 
  let rec aux i = function
      [] -> []
    | x :: xs -> 
        let ir = f i x in
          ir :: (aux ir xs) in
    i :: (aux i l)

let flip f a b = f b a

let rec rmake = function
    0 -> []
  | n -> n :: (rmake (n - 1))

let lmake n =  List.rev (rmake n)

let (^) f g x = f (g x)

let apply f x = f x

(**************)

let move (top::xs, ys, zs) = (xs, top::ys, zs)

let yz (x,y,z) = (x,z,y)
let xz (x,y,z) = (z,y,x)

let twist g f = g ^ f ^ g

let rec moves = function
    0 -> []
  | n -> List.map (twist yz) (moves (n - 1)) @ move :: List.map (twist xz) (moves (n - 1))

let hanoi n =
  scanl (flip apply) ((lmake n), [], []) (moves n)

за тем малым исключением, что пришлось написать часть библиотечных функций.
Что самое забавное, hugs, который в debian/stable, падает по sigv раньше, что ocaml(top) начинает говорить stack overflow. Желающие могут проверить ocamlopt :-)

PS: битик в unboxed values воруется для того что бы всегда можно было знать что это: значение или указатель. Именно из-за этого у камла быстрая арифметика.


(Читать комментарии)

Добавить комментарий:

Как:
Identity URL: 
имя пользователя:    
Вы должны предварительно войти в LiveJournal.com
 
E-mail для ответов: 
Вы сможете оставлять комментарии, даже если не введете e-mail.
Но вы не сможете получать уведомления об ответах на ваши комментарии!
Внимание: на указанный адрес будет выслано подтверждение.
Имя пользователя:
Пароль:
Тема:
HTML нельзя использовать в теме сообщения
Сообщение: