Почему этот Haskell, который я перевел на Python, не работает должным образом? - PullRequest
5 голосов
/ 25 августа 2011

Haskell:

average x y = (x + y) / 2

sqrt' :: (Ord a, Fractional a) => a -> Int -> a
sqrt' 0 _ = 0.0
sqrt' 1 _ = 1.0
sqrt' s approximations = (infsqr' s) !! approximations

infsqr' n = unfoldr acc 1 where
    acc guess | guess < 0 = Nothing
              | otherwise = Just (newguess', newguess') where
                newguess' = average guess (n / guess)

Python:

def unfold(f, x):
    while True:
        w, x = f(x)
        yield w

def average(x, y):
    return float((x + y) / 2)

def acc(guess):
    if guess < 1:
        return None
    else:
        newguess = average(guess, (float(n/guess)))
        return (newguess, newguess) 
n = 9
print unfold(acc, 1).next()
print unfold(acc, 1).next()

Должны быть выведены следующие два значения списка, например, 5,0, 3,4

Но он выдает 5.0 дважды, почему?

1 Ответ

11 голосов
/ 25 августа 2011

Если вы снова вызвали unold, ваш генератор снова сгенерируется, поэтому вам нужно присвоить его переменной.

>>> res = unfold(acc, 1)
>>> print res.next()
5.0
>>> print res.next()
3.4
>>>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...