免费注册 查看新帖 |

Chinaunix

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

haskell如何实现首尾相连的“环” [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-04-27 01:30 |只看该作者 |正序浏览
haskell如何实现“环”——首尾相连

data Week = Monday | Tuesday | Wednesday | Thursday | Friday | Saturday | Sunday
        deriving (Show,Enum,Eq)

想要实现:next  Monday = Tuesday,next Tuesday = Wednesday...next Sunday应该是Monday,如此循环。

succ Sunday和pred Monday都是非法的
现在只能如下表达

next :: Week->Week
next x |x==Sunday = Monday
         |otherwise = succ x

能否有更一般更抽象的实现呢?

[ 本帖最后由 pass12163com 于 2009-4-27 01:33 编辑 ]

论坛徽章:
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
28 [报告]
发表于 2009-04-30 14:32 |只看该作者
原帖由 pass12163com 于 2009-4-30 14:00 发表


多谢指点。

不过在数据元素很多的情况下,instance Enum重新定义函数集非常单调乏味而繁重,如果再考虑函数的多态性,那会更糟糕。您说呢?

我说的最好的方法是针对顶楼的情况,不是说在所有情况下它都是最好的。

论坛徽章:
0
27 [报告]
发表于 2009-04-30 14:00 |只看该作者
最好的办法就是直接 instance Enum


多谢指点。

不过在数据元素很多的情况下,instance Enum重新定义函数集非常单调乏味而繁重,如果再考虑函数的多态性,那会更糟糕。您说呢?

论坛徽章:
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
26 [报告]
发表于 2009-04-30 08:09 |只看该作者
原帖由 pass12163com 于 2009-4-29 22:04 发表
这个算是haskell风格的吧

最好的办法就是直接 instance Enum

论坛徽章:
0
25 [报告]
发表于 2009-04-29 22:04 |只看该作者
这个算是haskell风格的吧:一个list头部的next就是其尾部的head,剩下的交给递归解决。当然还要定义好边界。

next :: (Eq a)=>a->[a]->a
next x xs
        |(x `elem` xs) == False = error "error"
        |x==last xs = head xs
        |x==head xs = head $ tail xs
        |otherwise = next x (tail xs)

论坛徽章:
0
24 [报告]
发表于 2009-04-29 09:19 |只看该作者
原帖由 izhier 于 2009-4-28 14:55 发表
想问一下: deriving (Class) 是不是语法糖 ?

论坛徽章:
0
23 [报告]
发表于 2009-04-28 17:57 |只看该作者
原帖由 MMMIX 于 2009-4-28 16:38 发表
这个实际和 FP 一点关系都没有,是 Haskell 的 type class 在起作用。

嗯,应该是 haskellic

论坛徽章:
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
22 [报告]
发表于 2009-04-28 16:47 |只看该作者
原帖由 pass12163com 于 2009-4-28 15:59 发表
呵呵,只是单纯从构建next的代码规模来说的,并无它意。

有些时候,最好的方法并不一定是最省力(也即代码量最小)的方法。

论坛徽章:
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
21 [报告]
发表于 2009-04-28 16:38 |只看该作者
原帖由 izhier 于 2009-4-28 16:03 发表
感觉 instance 实现更优雅一些,更具 FP 特色

这个实际和 FP 一点关系都没有,是 Haskell 的 type class 在起作用。

论坛徽章:
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
20 [报告]
发表于 2009-04-28 16:36 |只看该作者
原帖由 izhier 于 2009-4-28 14:55 发表
想问一下: deriving (Class) 是不是语法糖 ?

不是。如果是的话,deriving 也就不会有那么多限制了。

[ 本帖最后由 MMMIX 于 2009-4-28 16:38 编辑 ]
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP