免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3516 | 回复: 4
打印 上一主题 下一主题

Haskell 中 until 函数怎么用呀 ? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-22 12:15 |只看该作者 |倒序浏览

  1. Prelude> :t until
  2. until :: (a -> Bool) -> (a -> a) -> a -> a
  3. Prelude> until (>4) (+2) 0
  4. 6
  5. Prelude> until (>5) (+2) 0
  6. 6
  7. Prelude> until (>6) (+2) 0
  8. 8
  9. Prelude> until (>7) (+2) 0
  10. 8
  11. Prelude> until (>8) (+2) 0
  12. 10
复制代码

只知 until 是一个循环函数
试验了一把,还是看不出怎么用,不知其计算流程
它等同的 c 语言代码是什么呀?

论坛徽章:
0
2 [报告]
发表于 2009-04-22 13:28 |只看该作者
知道了
找到代码了

until          :: (a -> Bool) -> (a -> a) -> a -> a
until p f x     = if p x then x else until p f (f x)

原来是这样
和 iterate 有点相似,只是加了一个条件

iterate          :: (a -> a) -> a -> [a]
iterate f x       = x : iterate f (f x)

[ 本帖最后由 izhier 于 2009-4-22 13:34 编辑 ]

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
3 [报告]
发表于 2009-04-22 17:36 |只看该作者
原帖由 izhier 于 2009-4-22 13:28 发表
知道了
找到代码了

until          :: (a -> Bool) -> (a -> a) -> a -> a
until p f x     = if p x then x else until p f (f x)

原来是这样
和 iterate 有点相似,只是加了一个条件

返回值完全不同了,而且 p 本身也可以是个很复杂的条件判断。

论坛徽章:
0
4 [报告]
发表于 2009-04-22 18:42 |只看该作者

回复 #3 MMMIX 的帖子

嗯,我表达的不准确

其实我想说的是:两者都有 f (f x) 部分

[ 本帖最后由 izhier 于 2009-4-22 18:43 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2009-04-22 22:30 |只看该作者
interate 类似 mathematica 中的 NestList,但后者需指定次数

NestList[f, x, 3]

{x, f[x], f[f[x]], f[f[f[x]]]}

而 until 则类似 mathematica 中的 NestWhile 或 FixedPoint

NestWhile[# + 2 & , 0, # <= 8 &]

10

FixedPoint[# + 2 &, 0, SameTest -> (#2 > 8 &)]

10
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP