3 回答

TA貢獻1911條經驗 獲得超7個贊
語法[e1, e2 .. e3]實際上是語法糖enumFromThenTo e1 e2 e3,它是Enum類型類中的一個函數。
Haskell標準定義了它的語義如下:
對于類型Int和Integer,枚舉函數具有以下含義:
序列enumFrom e1是列表[e1,e1 + 1,e1 + 2,…]。
序列enumFromThen e1 e2是列表[e1,e1 + i,e1 + 2i,…],其中增量i為e2 ? e1。增量可以是零或負數。如果增量為零,則所有列表元素都相同。
序列enumFromTo e1 e3是列表[e1,e1 + 1,e1 + 2,…e3]。如果列表是空的e1 > e3。
序列enumFromThenTo e1 e2 e3是列表[e1,e1 + i,e1 +
2i,…e3],其中增量i為e2 ? e1。如果增量為正或零,則列表在下一個元素大于時終止e3; 如果列表是空的e1 > e3。如果增量為負,則列表在下一個元素小于時終止 e3; 如果列表是空的e1 < e3。
這幾乎是您所期望的,但是Float和Double實例的定義不同:
對于Float和Double,系列的語義enumFrom由Int上面的規則給出,除了當元素變得大于e3 + i∕2正增量時i,或者當它們變得小于e3 + i∕2負數時,列表終止i。
我不確定這是什么理由,所以我能給你的唯一答案就是這樣,因為它在標準中就是這樣定義的。
您可以通過使用整數枚舉并轉換為之Float后來解決此問題。
Prelude> map fromIntegral [1, 3 .. 10] :: [Float]
[1.0,3.0,5.0,7.0,9.0]

TA貢獻1824條經驗 獲得超8個贊
這樣的總和通常也會在省略最后一項時給出錯誤的結果; 只有在特殊情況下sqrt (1 - 1)
才會這樣。我再次爭辯說明顯錯誤的 NaN比一個聽起來不錯的訂單0不準確的浮點數更不好。 - 要確定這樣的東西,使用可能觸及域邊界的浮動只是從根本上說是錯誤的方法; 一個應該計算單元格中點,或者僅使用范圍語法用于單元間邊界,但是分別添加精確的外部邊界。
添加回答
舉報