明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: lzy9788

[讨论]这下怎么做了,请帮忙lisp

  [复制链接]
发表于 2004-3-21 11:45:00 | 显示全部楼层
;(xl-sort '((5 12) (21 3) (0 2)) '(lambda (x y)(< (car x)(car y)))) ->((0 2) (5 12) (21 3))
;(xl-sort '(2 9 3 -1 6) '<) -> (-1 2 3 6 9)
;(xl-sort '(-1 3 -1 3 3 9) '<) -> (-1 -1 3 3 3 9)
  1. ;(xl-sort lst fun) = 以取代vl-sort函数,用法相同(lsp)---------------by 无痕(defun xl-sort (lst fun / nlst)
  2.    (foreach n lst (setq nlst (xl-isort n nlst fun)))
  3. )
  4. (defun xl-isort (item lst fun / k nlst)
  5.    (setq k T
  6.   nlst (apply 'append (mapcar '(lambda (x)
  7.                    (if (and K ((eval fun) item x)) (progn (setq k nil) (list item x)) (list x))
  8.                ) lst))
  9.    )
  10.    (if k (append lst (list item)) nlst)
  11. )
发表于 2004-4-2 20:48:00 | 显示全部楼层
xl-isort 怎么调用?
发表于 2004-4-2 20:55:00 | 显示全部楼层
(defun xl_sort (lst fun / k nlst lst2)
(foreach n lst (setq k T lst2 (apply 'append (mapcar '(lambda (x)
(if (and K ((eval fun) n x))(progn (setq k nil) (list n x))
(list x))) nlst)) nlst (if K (append lst2 (list n)) lst2)))
) 是不是能更精简调用(xl_sort '(2 5 -5 3 9 1 5 0) '>)
发表于 2004-4-2 20:57:00 | 显示全部楼层
谁能把上面的程序修改一下,变为能对二维表排序?
发表于 2004-4-2 21:05:00 | 显示全部楼层
不用改,,,,查看帮助文件中的vl-sort的用法,没看见作者说的,仅以取代vl-sort,用法相同吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-10-1 17:24 , Processed in 0.227650 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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