首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么这两个Haskell“展开”功能不同?

为什么这两个Haskell“展开”功能不同?
EN

Stack Overflow用户
提问于 2014-03-16 17:14:20
回答 1查看 207关注 0票数 0

我正在学习Haskell,我现在和可能的班级一起做一个练习。我必须创建一个函数,该函数将f(“可能函数”)反复应用于a(及其以下结果),直到f a返回Nothing。例如,f a0 = Just a1,f a1= Just a2,.,f an = Nothing。然后

代码语言:javascript
复制
unfold f a0 = [a0,a1,...,an]

我试着去做,我得到了:

代码语言:javascript
复制
unfold :: (a- > Maybe a) -> a -> [a]
unfold f a = case f a of
                 Just n -> n: unfold f a
                 Nothing -> []

问题是解决办法是:

代码语言:javascript
复制
unfold' :: ( a -> Maybe a) -> a -> [a]
unfold' f a = a : rest ( f a )
     where rest Nothing = []
           rest ( Just x ) = unfold' f x

我的程序不像解决方案那样工作。也许我用错了“案例”,但我不确定。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-03-16 17:22:13

您对case的使用是可以的,但是要查看列表中的新值在哪里,以及解决方案在哪里。

代码语言:javascript
复制
testFunc = const Nothing

unfold  testFunc 1 == []  -- your version prepends only if f a isn't Nothing
unfold' testFunc 1 == [1] -- the solution _always_ prepends the current value

而且,您一直在使用相同的值。

代码语言:javascript
复制
unfold :: (a -> Maybe a) ->a -> [a]
unfold f a = a : case f a of -- cons before the case
    Just n  -> unfold f n    -- use n as parameter for f
    Nothing -> []
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22440092

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档