[英]Merge two “list in list” in scheme
我不知道如何用語言准確表達我的問題。 原諒我模棱兩可的標題
我的問題是:
如果你有
a = [[1,2],[3,4],[5,6] ....],b = [[1,3],[4,8],....]
如何像合並a和b
[[1,2], [3, 4], [5, 6], [1, 3], [4, 8]....]
在計划中?
我已經嘗試使用汽車或自己編寫函數來解決它,但是都失敗了。 我本來打算使用(cons ab),但是它會給我[[[1,2],[3,4] ...],[[1,3],[4,8] ...] ],這不是我想要的。 我試圖編寫一個遞歸函數,但仍然會遇到與(cons ab)類似的麻煩
謝謝!
正如評論中指出的那樣,您正在尋找append
。 這是問題中的代碼在Scheme中的樣子:
(define a '((1 2) (3 4) (5 6)))
(define b '((1 3) (4 8)))
(append a b)
=> '((1 2) (3 4) (5 6) (1 3) (4 8))
如果要實現自己的append
版本,它就很簡單:
(define (my-append lst1 lst2)
(if (null? lst1)
lst2
(cons (car lst1)
(my-append (cdr lst1) lst2))))
(my-append a b)
=> '((1 2) (3 4) (5 6) (1 3) (4 8))
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.