функция zip в Haskell - PullRequest
       26

функция zip в Haskell

5 голосов
/ 25 апреля 2011

реализация функции zip, которая принимает два списка в качестве параметров и возвращает новый список пар. Я получил это до сих пор

myZip [] [] = []
myZip (x:xs) (y:ys) = [(x,y)] ++ myZip xs ys

любая помощь?

1 Ответ

6 голосов
/ 25 апреля 2011

На самом деле есть только один способ написать это для списков, даже для домашней работы:

zip :: [a] -> [b] -> [(a,b)]
zip (a:as) (b:bs) = (a,b) : zip as bs
zip _      _      = []

или, в более общем смысле,

zipWith :: (a -> b -> c) -> [a]->[b]->[c]
zipWith f (a:as) (b:bs) = f a b : zipWith f as bs
zipWith _ _      _      = []

Если вы хотите стать дурацкими поиграйте с Stream Fusion, версией из бумаги Stream Fusion, в автоматном стиле,

zipWith :: (a -> b -> c) -> Stream a -> Stream b -> Stream c
zipWith f (Stream next0 sa0) (Stream next1 sb0) = Stream next (sa0, sb0, Nothing)
  where
    next (sa, sb, Nothing) = case next0 sa of
        Done        -> Done
        Skip    sa' -> Skip (sa', sb, Nothing)
        Yield a sa' -> Skip (sa', sb, Just a)

    next (sa', sb, Just a) = case next1 sb of
        Done        -> Done
        Skip    sb' -> Skip          (sa', sb', Just a)
        Yield b sb' -> Yield (f a b) (sa', sb', Nothing)
...