给定一个列表,我如何选择一个包含原始列表切片的新列表(给定偏移量和元素数量)?
到目前为止的好建议.SRFI的其中一个没有指定的东西吗?这似乎是一个非常基本的事情,所以我很惊讶我需要在用户土地上实现它.
Nat*_*ers 11
奇怪的是,slice不具备SRFI-1 ,但你可以把它缩短了使用SRFI-1的take和drop:
(define (slice l offset n)
(take (drop l offset) n))
Run Code Online (Sandbox Code Playgroud)
我认为我在Scheme中使用的扩展程序之一,如PLT Scheme库或Swindle,会有这种内置功能,但似乎并非如此.它甚至没有在新的R6RS库中定义.
以下代码将执行您想要的操作:
(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)
你可以试试这个功能:
子 序列开始和可选结束
该启动参数的偏移.通过简单地添加start + number-of-elements ,end参数可以很容易地转换为要抓取的元素数.
一个小小的好处是subseq适用于所有序列,这不仅包括列表,还包括字符串和向量.
编辑:似乎并非所有的lisp实现都有subseq,尽管如果你拥有它,它可以正常工作.
| 归档时间: |
|
| 查看次数: |
16478 次 |
| 最近记录: |