找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2290|回复: 9

[LISP函数]:在表中第n项增加一元素,n自0开始。

[复制链接]
发表于 2008-11-3 18:48:53 | 显示全部楼层 |阅读模式

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

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

×
是不是要回复才能看的到?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2008-11-12 23:45:10 | 显示全部楼层
(defun delnlist( listent nn / key list1 list2 num listaa nn2 rtn);;;删除指定的第几个元素;;;如果nn为空,或者nn大于表的长度,则返回原表
  (if (null nn)
    (setq rtn listent)
    (progn
(if (< nn (length listent))
  (progn
    (setq nn2 (- (length listent) nn))
  (setq key (nth nn listent))
  (setq list1  (cdr (member key (reverse listent))))
  (while (> (length list1) nn)
    (setq list1 (cdr list1))
   
    )
  (setq list1 (reverse list1))
  (setq list2  (member key listent))
  (while (>= (length list2) nn2)
    (setq list2 (cdr list2))
    )
  (setq num   (- (length list1) 1) )
  (setq listaa list2)
  (repeat (length list1)   
   
    (setq listaa (cons (nth num list1) listaa))
    (setq num (- num 1))
    )
  (setq rtn listaa)
  )
  (setq rtn listent)
  )
)
    )
  rtn
  )



(defun ins_n_lst (atom1 nn lst openif / lst1 lst2 rtn)
  ;;在lst的nn处后插入atom1
  ;;假如atom1是一个表,用openif来控制是否打开openif = t or nil

  (if (>= nn (length lst))
         (progn
           (setq lst1 lst)
           (setq lst2 '())
           )
    (progn
      (setq lst1 (Fnlst nn lst))
      (setq lst2 (Bnlst (- (length lst) nn) lst))
      )
    )
  (if (and openif (= (type atom1) 'LIST) )
    (progn
      (setq rtn (joinlst atom1 lst2))
      (setq rtn (joinlst lst1 rtn))
      )
    (progn
      (setq rtn (cons atom1 lst2))
      (setq rtn (joinlst lst1 rtn))
      )
    )
  rtn
  )


(defun Fnlst(nn lst / n rtn)
  ;;;取lst的前nn部分
  (setq rtn '())
  (if (>= nn (length lst))
    (setq rtn lst)
    (progn
      (setq n 0)
      (repeat nn
        (setq rtn (cons (nth n lst) rtn))
        (setq n (1+ n))
        )
      (setq rtn (reverse rtn))
      )
    )
  rtn
  )

(defun Bnlst (nn lst / rtn)
  ;;;取lst的后nn部分
  (setq lst (reverse lst))
  (setq rtn (fnlst nn lst))
  (setq rtn (reverse rtn))
  rtn
  )

(defun Joinlst(lst1 lst2 / n  rtn)
;;;联接两个表
  (setq lst1 (reverse lst1))
  (setq rtn lst2)
  (setq n 0)
  (repeat (length lst1)
    (setq rtn ( cons (nth n lst1) rtn ))
    (setq n (1+ n))
    )
  rtn
  )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

已领礼包: 3191个

财富等级: 富可敌国

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

使用道具 举报

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

使用道具 举报

发表于 2015-4-16 20:08:19 | 显示全部楼层
本帖最后由 77077 于 2015-4-16 20:26 编辑

代码太长了

  1. ;表的第N位置插入新表
  2. ;|
  3. (setq lst '(1 2 3 4 5 6 7 8 9))
  4. (list-insertitem '("A" "B" "C") 5 lst)=>(1 2 3 4 5 "A" "B" "C" 6 7 8 9)
  5. (list-insertitem '("A" "B" "C") 1 lst)=>(1 "A" "B" "C" 2 3 4 5 6 7 8 9)
  6. (list-insertitem '("A" "B" "C") 15 lst)=>(1 2 3 4 5 6 7 8 9 "A" "B" "C")
  7. |;
  8. (defun list-insertitem (item nnn lst / lout )
  9.   (if (< nnn (length lst))
  10.     (progn
  11.       (setq lout '())
  12.       (repeat nnn
  13.               (setq lout (cons (car lst) lout) lst (cdr lst))
  14.             )
  15.       (append (reverse lout) (append item lst))
  16.     )
  17.     (append lst item)
  18.   )
  19. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 396个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 396个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 6056个

财富等级: 富甲天下

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

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 01:15 , Processed in 0.473117 second(s), 49 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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