明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1289|回复: 13

[提问] 表提重复

[复制链接]
发表于 2024-7-2 20:27:07 来自手机 | 显示全部楼层 |阅读模式
分析lst表中y坐标相同,保留一组移除其它y相同,该如何写函数?
((10 20) (5 40) (10 30) (20 40) (10 40))
因为y坐标40相同,返回
((10 20) (5 40) (10 30))
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2024-7-15 16:35:44 | 显示全部楼层
本帖最后由 yoyoho 于 2024-7-15 19:21 编辑

啵浪鼓 发表于 2024-7-13 21:15
((10 20 2) (20 30 3) (10 20 5) (20 30 1) (20 30 2))
满足x和y坐标相同条件,求xy相同组成一块返回

;|                                                                                                                                                           
满足x和y坐标相同条件,求xy相同组成一块返回                                                                                                                  
(setq qq '((10 20 2) (20 30 3) (10 20 5) (20 30 1) (20 30 2) (10 500 4) (90 500 10) (100 500 400)))                                                   
(reverse (SORT-SAME-XY qq))                                                                                                                           
(((10 20 2) (10 20 5)) ((20 30 3) (20 30 1) (20 30 2)) ((10 500 4)) ((90 500 10)) ((100 500 400)))        
                                                                                                                                                            
|;                                                                                                                                                           
(defun sort-same-xy (l / lst l1 a)                                                                                                                           
   (while l                                                                                                                                                  
     (setq a   (car l)                                                                                                                                       
     l   (cdr l)                                                                                                                                             
           l1  (vl-remove-if '(lambda (e) (or (/= (car e)(car a)) (/= (cadr e)(cadr a))) ) l)                                                               
     lst (cons (cons a l1) lst)                                                                                                                              
     l1 nil                                                                                                                                                  
     l  (vl-remove-if '(lambda (e) (and (= (car e)(car a)) (= (cadr e)(cadr a)) ) ) l)                                                                       
     ))                                                                                                                                                      
  lst)                                                                                                                                                      
发表于 2024-7-2 21:51:45 | 显示全部楼层
  1. (defun RemoveY (lst /  y  result dict)  
  2.   (setq result '())  
  3.   (setq dict nil)  
  4.   (foreach pt lst  
  5.     (setq y (cadr pt))
  6.     (if (not (assoc y dict))  
  7.       (progn  
  8.         (setq result (cons pt result))
  9.         (setq dict (cons (cons y pt) dict))
  10.       )  
  11.     )  
  12.   )  
  13.   (reverse result)  
  14. )
发表于 2024-7-2 22:35:05 | 显示全部楼层
凑热闹,来个递归
  1. (defun c:tt ()
  2.         (setq lst '((10 20) (5 40) (10 30) (20 40) (10 40)))
  3.         (list-delsamey lst)
  4. )

  5. (defun list-delsamey (lst)
  6.   (if Lst
  7.                 (cons (car Lst) (list-delsamey (vl-remove-if '(lambda (x) (equal (cadar lst) (cadr x))) (cdr lst))))
  8.         )
  9. )
发表于 2024-7-2 21:48:12 | 显示全部楼层
  1. (defun c:gg()
  2.   (setq lst '((10 20) (5 40) (10 30) (20 40) (10 40)))
  3.   (setq newlst nil)
  4.   (while
  5.     (setq e(car lst))
  6.     (setq newlst(cons e newlst))
  7.     (setq lst(vl-remove-if '(lambda(x)(=(cadr x)(cadr e)))lst))
  8.   )
  9.   (setq newlst(reverse newlst))
  10.   (princ newlst)
  11.   (princ)
  12. )


发表于 2024-7-2 22:44:52 | 显示全部楼层
大佬云集,收藏了
发表于 2024-7-2 22:45:01 | 显示全部楼层
一两句代码的事。
发表于 2024-7-3 07:35:45 | 显示全部楼层
  1. (SETQ LL '((10 20) (5 40) (10 30) (20 40) (10 40)))
  2. (SETQ L (MAPCAR '(LAMBDA(X) (IF (MEMBER (CADR X) L) NIL(PROGN (SETQ L (CONS (CADR X) L)) X))) LL))
  3. (VL-REMOVE NIL L)
 楼主| 发表于 2024-7-3 08:29:29 来自手机 | 显示全部楼层
以上测试均OK,感谢╰(*︶`*)╯
发表于 2024-7-3 09:14:23 | 显示全部楼层
  1. (SETQ LL '((10 20) (5 40) (10 30) (20 40) (10 40)) l nil)
  2. (VL-REMOVE-IF-not '(lambda(x) (if (not (member (cadr x) l)) (setq l (cons (cadr x) l)))) ll)

评分

参与人数 1明经币 +1 收起 理由
自贡黄明儒 + 1

查看全部评分

发表于 2024-7-3 09:15:39 | 显示全部楼层
666,好像有点用,之前也想编个类似的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 11:59 , Processed in 0.176927 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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