[英]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.