找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 952|回复: 1

[LISP函数]:保留表前面N个元素

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2007-12-27 13:25:28 | 显示全部楼层 |阅读模式

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

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

×

  1.   [FONT=courier new]
  2. ;;; tt-lst-head - list l with the first n elements
  3. (defun tt-lst-head (l n)
  4.   (setq n (1+ n))
  5.   (apply
  6.     'append
  7.     (mapcar
  8.       (function (lambda (x)
  9.                   (if (> (setq n (1- n))
  10.                           0
  11.                       )
  12.                     (list x)
  13.                     nil
  14.                   )
  15.                 )
  16.       )
  17.       l
  18.     )
  19.   )
  20. )
  21. ;;;命令: !lst
  22. ;;;(0 1 2 3 4 5 6 7 8 9)
  23. ;;;命令: (tt-lst-head lst 5)
  24. ;;;(0 1 2 3 4)
  25.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2008-1-1 06:55:55 | 显示全部楼层
  1. (defun fr-lst-head (lst n / l)
  2.   (if (<= n (length lst))
  3.       (repeat n
  4.         (setq l          (cons (car lst) l)
  5.               lst (cdr lst)
  6.         )
  7.       )
  8.   )
  9.   (reverse l)
  10. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 05:18 , Processed in 0.202434 second(s), 34 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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