【问题标题】:Scheme Binary List to Decimal Sum方案二进制列表到小数和
【发布时间】:2020-03-25 14:16:53
【问题描述】:

一个接受二进制数列表并返回其十进制和的函数。

Call: (addBinary '(1101 111 10 101))

(define (addBinary binaryList))

returns 27

【问题讨论】:

  • 请发布您目前编写的代码,以便我们为您提供帮助。还要确保您发布的内容是可编译的有效代码,而不是您发布的代码。不要忘记添加示例输入和预期输出。
  • 您的代码无效,因为您需要在 lambda 列表之后至少有一个表达式。 '(1101 111 10 101) 也不是二进制 '(#b1101 #b111 #b10 #b101) 是。 (+ #b1101 #b111 #b10 #b101) ; ==> 27 当您评估它时。整数实际上没有底,但它的可视化有。

标签: list binary scheme decimal converters


【解决方案1】:

在 Racket 和 Guile 中测试:

(define (addBinary binaryList)
  (foldl ; or fold, depending on dialect
   (lambda (n r)
     (+ r (string->number (number->string n) 2)))
   0 binaryList))

【讨论】:

    猜你喜欢
    • 2012-09-26
    • 2018-01-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-04-17
    • 1970-01-01
    • 2017-07-06
    • 1970-01-01
    相关资源
    最近更新 更多