在逗号分隔的字符串中合并字符串列表

Asl*_*986 2 scheme higher-order-functions racket

我需要编写一个软件,给定一个字符串列表,该软件返回一个由输入列表元素的逗号分隔串联而成的新颖字符串。

(comma-con (list "a" "b" "c"))  ;=> "a,b,c"
Run Code Online (Sandbox Code Playgroud)

我很想编写Scheme惯用代码。

到目前为止,我写道:

(define (comma-con l)
   (foldr
         (? (x y) (if (string? y) (string-append x "," y) x))
         '()
         l))
Run Code Online (Sandbox Code Playgroud)

可以,但是似乎有点脏。有没有一种更好的方法来编写它,例如避免使用“ if”?

Ósc*_*pez 5

尝试使用string-join,它完全可以满足您的需求,并且非常惯用:

(string-join '("a" "b" "c") ",")
=> "a,b,c"
Run Code Online (Sandbox Code Playgroud)

无论如何,如果您想使用fold解决问题,这是一种更简洁的解决方案(假设输入列表为非空):

(define (comma-con lst)
  (foldl (? (e acc) (string-append acc "," e))
         (first lst)
         (rest  lst)))
Run Code Online (Sandbox Code Playgroud)