找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2580|回复: 4

[] 返回表第N个元素之前的所有元素(包括N)

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2013-6-12 22:17:06 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::List:N-
调用格式: (XD::List:N- lst n)
参数说明: LST ---- 表
N ---- 序号(从1开始)
返回值:
函数简介: 返回表第N个元素之前的所有元素(包括N)
函数来源: 原创
函数作者: Lispboy
适用版本: 不限 
最后更新时间: 2013-06-12
备注: 命令: !b
(2334 556 33 44 66 77 22)

命令: (xd::list:n- b 3)
(2334 556 33)
演示图片: -

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

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

×
  1. ;|
  2.     返回表第N个元素之前的所有元素(包括N)

  3.    参数:
  4.        LST ---- 表
  5.        N   ---- 序号(从1开始)
  6. |;
  7. (defun XD::List:N- (lst n / lst1 i l)
  8.   (if (and (> l 1)
  9.            (<= n (setq l (length lst)))
  10.       )
  11.     (progn
  12.       (setq i 0)
  13.       (if (< n (/ l 2.0))
  14.         (progn
  15.           (while (and
  16.                    (setq a (car lst))
  17.                    (< i n)
  18.                  )
  19.             (setq lst1 (cons a lst1)
  20.                   lst (cdr lst)
  21.                   i (1+ i)
  22.             )
  23.           )
  24.           (reverse lst1)
  25.         )
  26.         (progn
  27.           (setq lst (reverse lst))
  28.           (while (and
  29.                    (setq a (car lst))
  30.                    (< i (- l n))
  31.                  )
  32.             (setq lst (cdr lst)
  33.                   i (1+ i)
  34.             )
  35.           )
  36.           (reverse lst)
  37.         )
  38.       )
  39.     )
  40.   )
  41. )


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2013-6-12 22:28:26 | 显示全部楼层
本帖最后由 wowan1314 于 2013-6-12 22:38 编辑

我又来支持你了! 哈哈。。莫非算法优越? 请测试以下函数,让俺死个明白。
咋不用VL函数呢?
  1. ;;=============={ 返回表第N个元素之前的所有元素 }===================
  2. ;;测试: (T2 3 '(2334 556 33 44 66 77 22))==> (2334 556 33)
  3. (DEFUN T2 (n lst / m NEW)
  4. (setq m 0)
  5. (WHILE (< M N)
  6.   (SETQ NEW (CONS (CAR LST) NEW) LST (CDR LST) m (1+ m))
  7. )
  8. (REverse NEW)
  9. )
  1. ;;=============={ 返回表第N个元素之前的所有元素 }===================
  2. ;;测试: (T1 3 '(2334 556 33 44 66 77 22))==> (2334 556 33)
  3. (DEFUN T1 (n lst / m)
  4. (setq m 0)
  5. (vl-remove-if '(lambda(x)(setq m (1+ m))(< n m) ) lst)
  6. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2013-6-12 22:38:11 | 显示全部楼层
[pcode=lisp,true](defun XD::List:N- (lst n / l ll)
  (setq l (length lst))
  (if (> n (/ l 2.))
    (progn (setq lst (reverse lst));_取前面
           (repeat (- l n)
             (setq lst (cdr lst));_直接丢掉原表后面的
           )
           (setq ll (reverse lst))
    )
    (progn (repeat n
             (setq ll  (cons (car lst) ll);_取靠前的要保留
                   lst (cdr lst)
             )
           )
           (setq ll (reverse ll))
    )
  )
  ll
)[/pcode]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-23 22:05:34 | 显示全部楼层
  1. (defun XD::List:N- (lst n / lst1 l)
  2.   (if (and (<= n (setq l (length lst)))
  3.            (> l 1)
  4.       )
  5.     (if        (< n (/ l 2.0))
  6.       (progn
  7.         (repeat        n
  8.           (setq        lst1 (cons (car lst) lst1)
  9.                 lst  (cdr lst)
  10.           )
  11.         )
  12.         (reverse lst1)
  13.       )
  14.       (progn
  15.         (setq lst (reverse lst))
  16.         (repeat        (- l n)
  17.           (setq lst (cdr lst))
  18.         )
  19.         (reverse lst)
  20.       )
  21.     )
  22.   )
  23. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2015-2-15 07:40:19 | 显示全部楼层
请测试以下函数;P;P
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 12:12 , Processed in 0.205325 second(s), 43 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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