5

我想在 Racket 中以二进制打印填充到 32 位的字。我知道printf和“~b”,但我希望它每次填充为 32 位长。我该怎么做呢?

例子

(printf "~b" 42) 
=> 101010
Want: 00000000000000000000000000101010
4

3 回答 3

9

这是使用 Racket 5.3.1 及更高版本执行此操作的简洁方法:

Welcome to Racket v5.3.2.3.
-> (require racket/format)
-> (~r 42 #:base 2 #:min-width 32 #:pad-string "0")
"00000000000000000000000000101010"

有关更多详细信息,请参阅球拍/格式

在较旧的球拍版本中,您可以这样做:

Welcome to Racket v5.3.
-> (require srfi/13)
-> (string-pad (number->string 42 2) 32 #\0)
"00000000000000000000000000101010"
于 2013-01-30T04:08:12.477 回答
0

那么这是一个简单,低效的方法:

(define (pad-left length padding the-str)
  (if (> length (string-length the-str))
      (pad-left length padding (string-append padding the-str))
      the-str))

(write (pad-left 32 "0" (format "~b" 42)))
于 2013-01-31T16:45:16.977 回答
0

好吧,我强行提出了一个解决方案:

(define (print-word x)
  (if  (not (<= -2147483648 x 4294967295))
    (error 'print-word "ERROR This number is bigger than a word ~a" x)
    (let* ([positive-x (if (< x 0) (+ #x100000000 x)
                         x)]
           [str (number->string positive-x 2)]
           [padded-str (string-append 
                         (make-string (- 32 (string-length str)) #\0)
                         str)])
      (build-string 39 
        (λ(i) (cond [(= (remainder (+ 1 i) 5) 0) #\space]
                    [else (string-ref padded-str (- i (quotient i 5)))]))))))

这实际上返回了每 4 位之间有空格的字符串,因为实际上很难以另一种方式阅读。

于 2013-01-30T03:56:10.047 回答