乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 172|回复: 5

基于vl-position的扩展-任意元素在表中所有出现位置、表中各元素所有出现位置

[复制链接]

61

主题

718

帖子

13

银币

中流砥柱

Rank: 25

铜币
960
发表于 2022-7-22 10:52:00 | 显示全部楼层 |阅读模式
nthcdr为隐藏函数
  1. (defun mposition(lst ens / n);;;列出ens表内各个元素的lst中所有出现位置
  2.   (setq n(length lst))
  3.   (mapcar(function(lambda(x / i l l1)
  4.         (setq l lst)
  5.         (while(setq i(vl-position x l))
  6.           (setq l1(cons(+ i n(-(length l)))l1)
  7.           l(nthcdr(1+ i)l)))
  8.         (reverse l1)))ens))

(mposition'(2 5 6.6 5 8.982 7 2.3 7 3.4 6 8.982 5 6 1.6 9 3.4 2 3 7 8.5 8.982 9)'(2 7))
((0 16) (5 7 18))
  1. (defun everyposition(lst / n l2);;;lst表内各元素在表内所有出现位置
  2.   (setq n(length lst)m -1)
  3.   (vl-every(function(lambda(x / i l l1 )
  4.           (or(assoc x l2)
  5.        (progn
  6.          (setq l lst)
  7.          (while(setq i(vl-position x l))
  8.            (setq l1(cons(+ i n(-(length l)))l1)
  9.            l(nthcdr(1+ i)l)))
  10.          (setq l2(cons(cons x(reverse l1))l2))))))lst)
  11.   (reverse l2))

(EVERYPOSITION'(2 5 6.6 5 8.982 7 2.3 7 3.4 6 8.982 5 6 1.6 9 3.4 2 3 7 8.5 8.982 9))
((2 0 16) (5 1 3 11) (6.6 2) (8.982 4 10 20) (7 5 7 18) (2.3 6) (3.4 8 15) (6 9 12) (1.6 13) (9 14 21) (3 17) (8.5 19))
这个返回结果已经包含了去重和频数统计
去重只需要对该函数返回结果进行mapcar'car即可
(mapcar'car(EVERYPOSITION'(2 5 6.6 5 8.982 7 2.3 7 3.4 6 8.982 5 6 1.6 9 3.4 2 3 7 8.5 8.982 9)))
(2 5 6.6 8.982 7 2.3 3.4 6 1.6 9 3 8.5)
频数统计只需要计算各要素的出现位置个数
(mapcar'(lambda(x)(list(car x)(length(cdr x))))(EVERYPOSITION'(2 5 6.6 5 8.982 7 2.3 7 3.4 6 8.982 5 6 1.6 9 3.4 2 3 7 8.5 8.982 9)))
((2 2) (5 3) (6.6 1) (8.982 3) (7 3) (2.3 1) (3.4 2) (6 2) (1.6 1) (9 2) (3 1) (8.5 1))
回复

使用道具 举报

28

主题

327

帖子

21

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
432
发表于 2022-7-22 11:49:00 | 显示全部楼层
感谢分享,学习了,应该能拓展很多实用的功能
回复

使用道具 举报

2

主题

86

帖子

11

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
92
发表于 2022-7-22 15:04:00 | 显示全部楼层
nthcdr 低版本的没有这个函数
回复

使用道具 举报

61

主题

718

帖子

13

银币

中流砥柱

Rank: 25

铜币
960
发表于 2022-7-22 15:42:00 | 显示全部楼层

无版本无关,是一个隐藏函数,它还只能在fas里边加载。。。
激活系统隐藏的函数
(出处: 乐筑天下CAD社区)
请点击此处下载

请先注册会员后在进行下载

已注册会员,请先登录后下载

文件名称:xlug2bykfcx.fas 
下载次数:0  文件大小:118 Bytes  售价:2银币 [记录]
下载权限: 不限 以上或 Vip会员   [开通Vip]   [签到领银币]  [免费赚银币]



tryhi-大海的
回复

使用道具 举报

9

主题

82

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
118
发表于 2022-7-25 15:17:00 | 显示全部楼层

60阅读权太高了,小弟看不到.......
回复

使用道具 举报

2

主题

86

帖子

11

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
92
发表于 2022-7-28 16:17:00 | 显示全部楼层

学习了,谢谢你了。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-4 01:51 , Processed in 0.501014 second(s), 69 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表