找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1374|回复: 1

[] (XD::List:Nth++)返回表指定位置开始,长度n的子表

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2017-6-11 21:38:37 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::List:Nth++
调用格式: (XD::List:Nth++ lst s n)
参数说明: lst ----- 表
s ----- 起始位置(0开始)
n ----- 长度 ( nil 到最后)
返回值:
函数简介: 返回表指定位置开始,长度n的子表
函数来源: 原创
函数作者: marting
适用版本: 不限 
最后更新时间: 2017-06-11
备注: -
演示图片: -

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
本帖最后由 marting 于 2017-6-11 22:00 编辑

  1. (defun XD::List:Nth++ (l s n)
  2.     (repeat (/ s 4) (setq l (cddddr l)))
  3.     (repeat (rem s 4) (setq l (cdr l)))
  4.     (setq s nil)
  5.     (if (and l n)
  6.         (cond ((>= n (length l)) l)
  7.               ((< n (- (length l) n))
  8.                (repeat (/ n 4)
  9.                    (setq s (cons (cadddr l)
  10.                                  (cons (caddr l) (cons (cadr l) (cons (car l) s)))
  11.                            )
  12.                          l (cddddr l)
  13.                    )
  14.                )
  15.                (repeat (rem n 4)
  16.                    (setq s (cons (car l) s)
  17.                          l (cdr l)
  18.                    )
  19.                )
  20.                (reverse s)
  21.               )
  22.               (t
  23.                (setq l (reverse l)
  24.                      s (- (length l) n)
  25.                )
  26.                (repeat (/ s 4) (setq l (cddddr l)))
  27.                (repeat (rem s 4) (setq l (cdr l)))
  28.                (reverse l)
  29.               )
  30.         )
  31.         l
  32.     )
  33. )


评分

参与人数 2D豆 +10 收起 理由
/db_自贡黄明儒_ + 5
炫翔 + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 604个

财富等级: 财运亨通

发表于 2018-2-23 09:41:17 | 显示全部楼层
;;(XD::List:RemoveS '(1 2 3 4 5 6 7) 5)=>(6 7)
(defun XD::List:RemoveS (l s)
  (repeat (/ s 4) (setq l (cddddr l)))
  (repeat (rem s 4) (setq l (cdr l)))
)
(defun XD::List:Nth++ (l s n)
  (setq L (XD::List:RemoveS l s))
  (if L
    (reverse (XD::List:Nth++ (reverse l) (- (length l) n)))
  )
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-22 06:14 , Processed in 0.365451 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表