找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

楼主: 1121443108qaz

[求助] 重开贴:关于消除相邻重复点,理论上这两种方式哪种更快

[复制链接]

已领礼包: 5583个

财富等级: 富甲天下

发表于 2018-4-21 20:13:52 | 显示全部楼层
1121443108qaz 发表于 2018-4-21 19:09
(setq plist '((1 8)(1 8)(1 7)(1 6)(1 6)(1 6)(1 5)(1 8)(1 8))) 如果首尾两元素一样,你的函数就不起作 ...

将函数中的:  (cons tmp plist)
改为:   (append (cdr plist) (list (car plist)))


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

使用道具 举报

已领礼包: 5583个

财富等级: 富甲天下

发表于 2018-4-21 20:51:11 | 显示全部楼层
本帖最后由 HLCAD 于 2018-4-21 23:18 编辑
newer 发表于 2018-4-21 18:21
相邻的重复删除应用的太窄了吧。

  1. ;;; 仅保留表中的非重复点:
  2. ;;; by HLCAD
  3. (defun HL:TMP (plist / tmp rtn)
  4.   (while (vl-remove nil plist)
  5.     (setq tmp (car plist))
  6.     (setq rtn (cons tmp rtn))
  7.     (setq plist (vl-remove-if '(lambda(x) (equal tmp x 0.001)) (cdr plist)))
  8.     )
  9.   (reverse rtn)
  10.   )






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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-19 07:01 , Processed in 0.323749 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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