找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1623|回复: 12

[研讨] 一个效率低下的整数排序算法

[复制链接]

已领礼包: 1883个

财富等级: 堆金积玉

发表于 2014-12-28 20:05:36 | 显示全部楼层 |阅读模式

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

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

×
1、以表lst中最小值,最大值构造逐步增1的有序表lst0;
2、对表lst0中每个元素e进行判断,若e在lst中,则输出e。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-28 20:26:06 | 显示全部楼层
lst 元素都在 lst0

点评

是啊,但是是对构造表lst0中的元素进行判断啊。比如lst=(9 3 7 2 8 1)则lst0=(1 2 3 4 5 6 7 8 9) ,进行操作后就得到(1 2 3 7 8 9),当然若lst中有重复的就整数就剃掉了。  详情 回复 发表于 2014-12-28 20:33
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2014-12-28 20:33:22 | 显示全部楼层
本帖最后由 aimisiyou 于 2014-12-28 20:38 编辑

是啊,但是是对构造表lst0中的元素进行判断啊。比如lst=(9 3 7 2 8 1)则lst0=(1 2 3 4 5 6 7 8 9) ,进行操作后就得到(1 2 3 7 8 9),当然若lst中有重复的整数就剃掉了。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-28 20:38:55 | 显示全部楼层
aimisiyou 发表于 2014-12-28 20:33
是啊,但是是对构造表lst0中的元素进行判断啊。比如lst=(9 3 7 2 8 1)则lst0=(1 2 3 4 5 6 7 8 9) ,进 ...

对 Lst 直接 (vl-sort lst '<)

点评

知道啊,vl-sort也会对重复的整数也会剔除。对判断条件怎么写?  详情 回复 发表于 2014-12-28 20:44
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2014-12-28 20:44:25 | 显示全部楼层
本帖最后由 aimisiyou 于 2014-12-28 20:45 编辑
st788796 发表于 2014-12-28 20:38
对 Lst 直接 (vl-sort lst '

知道啊,vl-sort也会对重复的整数也会剔除。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-28 20:53:31 | 显示全部楼层
aimisiyou 发表于 2014-12-28 20:44
知道啊,vl-sort也会对重复的整数也会剔除。

学会变通
  1. (mapcar        'cadr
  2.         (vl-sort (mapcar '(lambda (x)
  3.                             (list (float x) x)
  4.                           )
  5.                          '(1 2 1 3 4 9 8 7)
  6.                  )
  7.                  '(lambda (x1 x2)
  8.                     (< (car x1) (car x2))
  9.                   )
  10.         )
  11. )

(1 1 2 3 4 7 8 9)

_$ (mapcar 'cadr
(vl-sort (mapcar '(lambda (x)
       (list (float x) x)
     )
    '(1 2 1 3 4 9 8 7 3.0)
   )
   '(lambda (x1 x2)
      (< (car x1) (car x2))
    )
)
)
(1 1 2 3 3.0 4 7 8 9)
_$

点评

哦,原来如此啊……  详情 回复 发表于 2014-12-28 20:59
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2014-12-28 20:59:24 | 显示全部楼层
st788796 发表于 2014-12-28 20:53
学会变通

(1 1 2 3 4 7 8 9)

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-12-28 21:04:18 | 显示全部楼层
aimisiyou 发表于 2014-12-28 20:59
哦,原来如此啊……


当然你也可以用 vl-sort-i + nth

点评

还是你的这种构造法比较好使些,多谢指教。  详情 回复 发表于 2014-12-28 21:08
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2014-12-28 21:08:38 | 显示全部楼层
st788796 发表于 2014-12-28 21:04
当然你也可以用 vl-sort-i + nth

还是你的这种构造法比较好使些,多谢指教。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2015-1-28 10:32:57 | 显示全部楼层
(mapcar
  'cdr
  (vl-sort (mapcar '(lambda (x)
                      (list x 2)
                      )
                   '(1 2 1 3 4 9 8 7)
                   )
           '(lambda (x1 x2)
              (< (car x1) (car x2))
              )
           ))
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-22 10:18 , Processed in 0.424840 second(s), 48 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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