亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
123下一頁
最近訪問板塊 發(fā)新帖
查看: 8776 | 回復(fù): 27
打印 上一主題 下一主題

haskell如何實現(xiàn)首尾相連的“環(huán)” [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2009-04-27 01:30 |只看該作者 |倒序瀏覽
haskell如何實現(xiàn)“環(huán)”——首尾相連

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

想要實現(xiàn):next  Monday = Tuesday,next Tuesday = Wednesday...next Sunday應(yīng)該是Monday,如此循環(huán)。

succ Sunday和pred Monday都是非法的
現(xiàn)在只能如下表達(dá)

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

能否有更一般更抽象的實現(xiàn)呢?

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

論壇徽章:
0
2 [報告]
發(fā)表于 2009-04-27 09:49 |只看該作者
這一個可以嗎?
用cycle實現(xiàn)首尾相連

  1. week = [Mon, Tue, Wed, Thu, Fri, Sat, Sun]

  2. last.take n.cycle $ week
復(fù)制代碼

論壇徽章:
0
3 [報告]
發(fā)表于 2009-04-27 10:03 |只看該作者
這個也可以

next :: Week -> Week
next x = toEnum $ mod (fromEnum x + 1) 7

論壇徽章:
0
4 [報告]
發(fā)表于 2009-04-27 10:45 |只看該作者
原帖由 izhier 于 2009-4-27 10:03 發(fā)表
這個也可以

next :: Week -> Week
next x = toEnum $ mod (fromEnum x + 1) 7



這個很棒。只需確定循環(huán)周期。

上例中的n是個問題。

論壇徽章:
0
5 [報告]
發(fā)表于 2009-04-27 11:09 |只看該作者
原帖由 bengshi 于 2009-4-27 10:45 發(fā)表
上例中的n是個問題。


效率太低了

論壇徽章:
0
6 [報告]
發(fā)表于 2009-04-27 16:28 |只看該作者
謝謝各位的回復(fù)。
用mod的確夠一般化,只是看起來像用的數(shù)組下標(biāo)概念,少了FP的意味。

[ 本帖最后由 pass12163com 于 2009-4-27 16:33 編輯 ]

論壇徽章:
95
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
7 [報告]
發(fā)表于 2009-04-27 17:43 |只看該作者
原帖由 pass12163com 于 2009-4-27 01:30 發(fā)表
data Week = Monday | Tuesday | Wednesday | Thursday | Friday | Saturday | Sunday
        deriving (Show,Enum,Eq)

想要實現(xiàn):next  Monday = Tuesday,next Tuesday = Wednesday...next Sunday應(yīng)該是Monday,如此循環(huán)。

succ Sunday和pred Monday都是非法的

你不應(yīng)該 deriving Enum,而應(yīng)該自己 instance Enum。

論壇徽章:
0
8 [報告]
發(fā)表于 2009-04-28 09:23 |只看該作者
原帖由 MMMIX 于 2009-4-27 17:43 發(fā)表
應(yīng)該自己 instance Enum。

難道是:

  1. data Week = Mon | Tue | Wed | Thu | Fri | Sat | Sun
  2.         deriving (Show, Eq)

  3. instance Enum Week where
  4.   fromEnum day = case day of
  5.                                Mon -> 0
  6.                                Tue -> 1
  7.                                Wed -> 2
  8.                                Thu -> 3
  9.                                Fri -> 4
  10.                                Sat -> 5
  11.                                Sun -> 6
  12.                                 _   -> error "invalid value constructor"
  13.    
  14.   toEnum n = case n of
  15.                          -1 -> Sun
  16.                          0  -> Mon
  17.                          1  -> Tue
  18.                          2  -> Wed
  19.                          3  -> Thu
  20.                          4  -> Fri
  21.                          5  -> Sat
  22.                          6  -> Sun
  23.                          7  -> Mon
  24.                          _  -> error "invalid number"
復(fù)制代碼

run

  1. *Main> succ Sun
  2. Mon
  3. *Main> pred Mon
  4. Sun
復(fù)制代碼

[ 本帖最后由 izhier 于 2009-4-28 09:36 編輯 ]

論壇徽章:
95
程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-05 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-17 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-09-18 06:20:002015亞冠之阿爾艾因
日期:2015-09-18 10:35:08月度論壇發(fā)貼之星
日期:2015-09-30 22:25:002015亞冠之阿爾沙巴布
日期:2015-10-03 08:57:39程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-05 06:20:00每日論壇發(fā)貼之星
日期:2015-10-05 06:20:002015年亞冠紀(jì)念徽章
日期:2015-10-06 10:06:482015亞冠之塔什干棉農(nóng)
日期:2015-10-19 19:43:35程序設(shè)計版塊每日發(fā)帖之星
日期:2015-10-21 06:20:00每日論壇發(fā)貼之星
日期:2015-09-14 06:20:00
9 [報告]
發(fā)表于 2009-04-28 13:05 |只看該作者
原帖由 izhier 于 2009-4-28 09:23 發(fā)表

難道是:

data Week = Mon | Tue | Wed | Thu | Fri | Sat | Sun
        deriving (Show, Eq)


實現(xiàn) toEnum 的時候?qū)ζ鋮?shù)先取模。

論壇徽章:
0
10 [報告]
發(fā)表于 2009-04-28 13:15 |只看該作者
原帖由 MMMIX 于 2009-4-28 13:05 發(fā)表
實現(xiàn) toEnum 的時候?qū)ζ鋮?shù)先取模。


應(yīng)該是
toEnum n = case n `mod` 7 of
這樣寫
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP