微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在 Haskell 中转换为二进制表示法

如何解决在 Haskell 中转换为二进制表示法

有没有更好的方法来检查这段代码中的 nc,也许是模式匹配或者更像 Haskell 的东西?

toBin :: Int -> Int -> [Int]
toBin n c
    | n < 0 = []
    | c <= 0 = []
toBin n c = toBin (n `div` 2) (c - 1) ++ [n `mod` 2]

解决方法

好吧,它们都是布尔表达式,因此您可以将它们与 ||

结合使用
toBin n c | n < 0 || c <= 0 = []
,

这里最好使用累加器,这样可以防止 O(n) 追加导致 O(n2) 代码中的算法:

toBin :: Int -> Int -> [Int]
toBin = go []
  where go rs n c
          | n < 0 || c <= 0 = rs
          | otherwise = go (r:rs) q (c-1)
          where (q,r) = quotRem n 2

因此,我们从一个空列表开始,每次在列表前面加上下一个余数,直到数字为零,或位数为 0。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。