乐筑天下

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

[编程交流] 多排序列表

[复制链接]

42

主题

173

帖子

132

银币

后起之秀

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

铜币
220
发表于 2022-7-5 16:18:14 | 显示全部楼层 |阅读模式
大家好
我有一个由子列表组成的列表
每个子列表在图形“itm”中包含一个实体名称,其中
itm=(setq itm(ssname i ss1))和距离
假设子列表如下所示:
 
(()(x1))
 
 
因此,如何先按entityname对包含多个子列表的较大列表进行排序,然后再按距离(x1,x2,…)对列表进行排序
 
最后一个列表如下所示
(()(x1))
(()(x2))
(()(x3))
(()(x4))
(()(x5))
(()(x6))
 
 
谢谢
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-5 16:31:14 | 显示全部楼层
itm=(setq itm(ssname ss1 i))
 
  1. (defun _sort_byenames_bydists ( lst / l a g gg r )
  2. (setq l (vl-sort lst (function (lambda ( a b ) (< (vl-prin1-to-string (caar a)) (vl-prin1-to-string (caar b)))))))
  3. (while (setq a (car l))
  4.    (setq l (cdr l))
  5.    (if (null g)
  6.      (setq g (cons a g))
  7.    )
  8.    (if (eq (caar a) (caaar l))
  9.      (setq g (cons (car l) g))
  10.      (setq gg (cons g gg) g nil)
  11.    )
  12. )
  13. (foreach g gg
  14.    (setq r (cons (vl-sort g (function (lambda ( a b ) (< (caadr a) (caadr b))))) r))
  15. )
  16. (apply (function append) r)
  17. )
M.R。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 16:31:48 | 显示全部楼层
我建议:
然而,您的列表似乎不必要地嵌套了一个额外的级别-为什么不呢:
  1. (
  2.    (<Entity name: name1> x1)
  3.    (<Entity name: name1> x2)
  4.    (<Entity name: name1> x3)
  5.    (<Entity name: name2> x4)
  6.    (<Entity name: name2> x5)
  7.    (<Entity name: name2> x6)
  8. )
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-5 16:39:23 | 显示全部楼层
@李,如果列表包含完全相等的元素,两个代码都可能失败。。。
 
这是修订版。。。
 
  1. (defun _s_b_b ( lst / l a g gg r )
  2. (setq l (mapcar (function (lambda ( x ) (nth x lst))) (vl-sort-i lst (function (lambda ( a b ) (< (vl-prin1-to-string (caar a)) (vl-prin1-to-string (caar b))))))))
  3. (while (setq a (car l))
  4.    (setq l (cdr l))
  5.    (if (null g)
  6.      (setq g (cons a g))
  7.    )
  8.    (if (eq (caar a) (caaar l))
  9.      (setq g (cons (car l) g))
  10.      (setq gg (cons g gg) g nil)
  11.    )
  12. )
  13. (foreach g gg
  14.    (setq r (cons (mapcar (function (lambda ( x ) (nth x g))) (vl-sort-i g (function (lambda ( a b ) (< (caadr a) (caadr b)))))) r))
  15. )
  16. (apply (function append) r)
  17. )

 
和李的变体:
 
  1. (defun mysort ( l )
  2. (mapcar
  3.    (function
  4.      (lambda ( x )
  5.        (nth x l)
  6.      )
  7.    )
  8.    (vl-sort-i l
  9.      (function
  10.        (lambda ( a b )
  11.          (if (eq (caar a) (caar  b))
  12.            (< (caadr a) (caadr b))
  13.            (< (vl-prin1-to-string (caar a)) (vl-prin1-to-string (caar b)))
  14.          )
  15.        )
  16.      )
  17.    )
  18. )
  19. )
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 16:48:50 | 显示全部楼层
 
为什么呢vl sort仅删除重复整数。
  1. _$ (vl-sort '("a" "c" "f" "a" "h" "b" "e" "d" "g" "h") '<)
  2. ("a" "a" "b" "c" "d" "e" "f" "g" "h" "h")
  3. _$ (vl-sort '(3.5 1.5 6.5 1.5 4.5 3.5) '<)
  4. (1.5 1.5 3.5 3.5 4.5 6.5)
  5. _$ (vl-sort '((2 1) (1 1) (1 2) (2 1) (1 1) (4 5) (5 4)) '(lambda ( a b ) (if (= (car a) (car b)) (< (cadr a) (cadr b)) (< (car a) (car b)))))
  6. ((1 1) (1 1) (1 2) (2 1) (2 1) (4 5) (5 4))
  7. _$ (vl-sort '(4 5 3 2 1 6 4 2 1 1 2) '<)
  8. (1 2 3 4 5 6)
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-5 16:54:10 | 显示全部楼层
此外,如果我可以得出结论-如果元素是列表类型,那么它们的行为就像整数,而(vl排序)。。。
 
以下是点列表示例。。。当我们绘制点时,我们很少选择完全相同的坐标,所以(vl排序)通常效果很好。。。
 
  1. Command: (setq l '(((1.0) (1.0)) ((1.0) (2.0)) ((3.0) (1.0)) ((3.0) (0.5))))
  2. (((1.0) (1.0)) ((1.0) (2.0)) ((3.0) (1.0)) ((3.0) (0.5)))
  3. Command: (setq l (cons (car l) l))
  4. (((1.0) (1.0)) ((1.0) (1.0)) ((1.0) (2.0)) ((3.0) (1.0)) ((3.0) (0.5)))
  5. Command: (setq l (cons (car l) l))
  6. (((1.0) (1.0)) ((1.0) (1.0)) ((1.0) (1.0)) ((1.0) (2.0)) ((3.0) (1.0)) ((3.0) (0.5)))
  7. Command: (vl-sort l '(lambda ( a b ) (< (caadr a) (caadr b))))
  8. (((3.0) (0.5)) ((1.0) (1.0)) ((3.0) (1.0)) ((1.0) (2.0)))

 
希望这能解释一切。。。
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-5 17:02:42 | 显示全部楼层
两者都很好。。。谢谢Marko先生,谢谢lee先生
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-5 17:11:12 | 显示全部楼层
如果vl sort有删除重复元素的风险,为什么不确保其安全:
 
  1. 7

 
通过使用上述经典方法。
至少我偏执于只使用(vl排序)而不测试其在某些项目类型上的返回。
回复

使用道具 举报

42

主题

173

帖子

132

银币

后起之秀

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

铜币
220
发表于 2022-7-5 17:16:05 | 显示全部楼层
回复

使用道具 举报

66

主题

1552

帖子

1514

银币

后起之秀

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

铜币
325
发表于 2022-7-5 17:22:53 | 显示全部楼层
if theres a risk that vl-sort removes duplicate elements, why not keep it safe:
 
  1. (defun mysort ( f L ) (mapcar (function (lambda (x) (nth x L))) (vl-sort-i L (function f))) )_$ (mysort  (lambda (a b) (< (cadr a) (cadr b)))  '((0.0 1.0 2.0) (0.0 1.0 2.0) (0.0 1.0 2.0) (1.0 2.0 3.0) (2.0 3.0 4.0)) )((0.0 1.0 2.0) (0.0 1.0 2.0) (0.0 1.0 2.0) (1.0 2.0 3.0) (2.0 3.0 4.0))_$
 
by using the above classical approach.
Atleast I'm paranoid on just using (vl-sort) without testing its return on certain item types.
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-14 21:09 , Processed in 0.660717 second(s), 72 queries .

© 2020-2025 乐筑天下

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