如何在方案中获取一个列表(A子列表)?

tro*_*skn 14 lisp scheme

给定一个列表,我如何选择一个包含原始列表切片的新列表(给定偏移量和元素数量)?

编辑:

到目前为止的好建议.SRFI的其中一个没有指定的东西吗?这似乎是一个非常基本的事情,所以我很惊讶我需要在用户土地上实现它.

Nat*_*ers 11

奇怪的是,slice不具备SRFI-1 ,但你可以把它缩短了使用SRFI-1的takedrop:

(define (slice l offset n)
  (take (drop l offset) n))
Run Code Online (Sandbox Code Playgroud)

我认为我在Scheme中使用的扩展程序之一,如PLT Scheme库或Swindle,会有这种内置功能,但似乎并非如此.它甚至没有在新的R6RS库中定义.


dsm*_*dsm 8

以下代码将执行您想要的操作:

(define get-n-items
    (lambda (lst num)
        (if (> num 0)
            (cons (car lst) (get-n-items (cdr lst) (- num 1)))
            '()))) ;'

(define slice
    (lambda (lst start count)
        (if (> start 1)
            (slice (cdr lst) (- start 1) count)
            (get-n-items lst count))))
Run Code Online (Sandbox Code Playgroud)

例:

> (define l '(2 3 4 5 6 7 8 9)) ;'
()
> l
(2 3 4 5 6 7 8 9)
> (slice l 2 4)
(3 4 5 6)
> 
Run Code Online (Sandbox Code Playgroud)


Jos*_*non 6

你可以试试这个功能:

序列开始和可选结束

启动参数的偏移.通过简单地添加start + number-of-elements ,end参数可以很容易地转换为要抓取的元素数.

一个小小的好处是subseq适用于所有序列,这不仅包括列表,还包括字符串和向量.

编辑:似乎并非所有的lisp实现都有subseq,尽管如果你拥有它,它可以正常工作.