0
(define-struct binding
(
let ; a string
num ; a number
)
)
(define Bind-A (make-binding empty 1))
(define Bind-B (make-binding "A" 2))
(define Bind-C (make-binding "F" 1))
(define Bind-D (make-binding "A" 1))
(define Bind-E (make-binding "C" 1))
(define Bind-F (make-binding "E" 3))
(define Bind-All (list Bind-A Bind-B Bind-C Bind-D Bind-E Bind-F))
所以我有一個結構體,我將調用「綁定」和一個列表,它包含了我創建的所有「綁定」。現在提出這個問題:可以說我想創建一個列表,它在每個綁定中都有一個與我調用函數相同的數字。例如:計劃幫助。構造列表和遞歸
;;-----------------------------------------------------------------------------
;; Return a string containing the letters (in alphabetical order, separated by a
;; space) of all bindings with the same number in pool of "bindings".
;; If either letter is unknown or if no bindings have the same number
;; Return the null string ("").
;;-----------------------------------------------------------------------------
(define (same-num ; string
which-binding) ; binding to check
pool ; list of all bindings
)
(cond
[(empty? (binding-let which-binding)) ""]
[(equal? (binding-let which-binding) (binding-let (first pool)) ... ]
[else ... ]
)
)
(check-expect (same-num Bind-E Bind-all) "A F")
(check-expect (same-num Bind-F Bind-all) "")
(check-expect (same-num Bind-A Bind-all) "")
我希望這是有道理的,我解釋的方式。我一直是這樣努力了幾個小時,我覺得這是非常簡單的我只是不明白的語言不夠。
Scheme還具有「字符」數據類型,它被標記爲#\ a,#\ b,#\ c等等。 (list-string'(#\ a#\ b#\ c))給出「abc」。 – erjiang 2010-10-27 17:09:39