找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1115|回复: 2

[求助] [求助]:老问题----坐标排序?

[复制链接]
发表于 2006-2-16 15:50:30 | 显示全部楼层 |阅读模式

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

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

×
和以往排序要求稍有不同
当y坐标差大于某一数时,按y排序,如果其中几个坐标点的y相差小于某一数时某一数时,则忽落y,按x排序
例如(1 1)(1 6)(3 5)(2 7)(1 10)
首先按y排序后结果是(1 1)(3 5)(1 6)(2 7)(1 10),但中间三个数的y坐标相差小于2,所以重新排中间三个数,按x,忽略y,最后结果为(1 1)(1 6)(2 7)(3 5)(1 10)
求最简洁代码和思路。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 2个

财富等级: 恭喜发财

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

使用道具 举报

发表于 2006-2-22 17:08:19 | 显示全部楼层
;其中,重新排中间三个数的那段实在是不够简洁,望高手指点一二
(defun c:zz (/ plist plist2 n sn tt p1 p2 e1 e2)
    (setq plist '((1 1)(1 6)(3 5)(2 7)(1 10)))
    (setq plist
             (vl-sort plist '(lambda (e1 e2) (< (cadr e1) (cadr e2))))
    )
    (setq n  1
          sn 1
          tt "(("
    )
    (setq p1 (nth 0 plist))
    (repeat (1- (length plist))
        (setq p2 (nth n plist))
        (if (< (- (cadr p2) (cadr p1)) 2)
            (progn
                (if (= sn 0)
                    (progn
                        (setq tt (strcat tt "("))
                        (setq sn 1)
                    )
                )
                (setq tt (strcat tt (vl-prin1-to-string p1)))
            )
            (progn
                (setq tt (strcat tt (vl-prin1-to-string p1)))
                (if (= sn 1)
                    (progn
                        (setq tt (strcat tt ")"))
                        (setq sn 0)
                    )
                )
            )
        )
        (setq p1 p2)
        (setq n (1+ n))
    )
    (if        (= sn 1)
        (setq tt (strcat tt (vl-prin1-to-string p2) "))"))
        (setq tt (strcat tt "(" (vl-prin1-to-string p2) "))"))
    )
    (setq plist (read tt))
    (setq n 0
          plist2 nil
    )
    (repeat (length plist)
        (setq plist2
                 (append
                     plist2
                     (vl-sort (nth n plist)
                              '(lambda (e1 e2) (< (car e1) (car e2)))
                     )
                 )
        )
        (setq n (1+ n))
    )
    (setq plist plist2)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-29 04:00 , Processed in 0.288027 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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