乐筑天下

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

[编程交流] 合并两个列表

[复制链接]

46

主题

92

帖子

45

银币

后起之秀

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

铜币
235
发表于 2022-7-5 22:20:50 | 显示全部楼层 |阅读模式
你好
如何将两个列表合并为一个?
第一个列表是一个条目,生成的列表等于元素的数量。
 
第一个列表:
  1. ‘(10.3403 10.3417 10.3431 …)

 
第二个列表
  1. ‘((10.3406333333333 22.2839283048)
  2. (10.3407111111111 22.2900230856)
  3. (10.3407888888889 22.3601283048)
  4. (10.3409444444444 22.3936563048)
  5. (10.3408666666667 22.3997513904)
  6. (10.3410222222222 22.457664)
  7. (10.3411 22.457664)
  8. (10.3413333333333 22.4149923048)
  9. (10.3412555555556 22.424136)
  10. (10.3411777777778 22.4515692192)
  11. (10.3414888888889 22.2991692192)
  12. (10.3415666666667 22.3205049144)
  13. (10.3416444444444 22.3235513904)
  14. (10.3414111111111 22.3448873904)
  15. (10.3418 22.3144076952)
  16. (10.3417222222222 22.3205049144)
  17. (10.3418777777778 22.4058486096)
  18. (10.3421888888889 22.4088950856)
  19. (10.3421111111111 22.4485206096)
  20. (10.3419555555556 22.4515692192)
  21. (10.3420333333333 22.479)
  22. (10.3423444444444 22.3418409144)
  23. (10.3422666666667 22.3784153904)
  24. (10.3424222222222 22.3997513904)
  25. (10.3427333333333 22.1711513904)
  26. (10.3426555555556 22.2138230856)
  27. (10.3425777777778 22.305264)
  28. (10.3425 22.3601283048)
  29. (10.3430444444444 22.0096076952))

 
结果列表:
  1. ‘((10.3403 10.3406333333333 22.2839283048)
  2. (10.3417 10.3416444444444 22.3235513904)
  3. (10.3431 10.3430444444444 22.0096076952))

 
算法:
从第一个列表中选择一个项目:
  1. (mapcar '(lambda (a) (…) lst1))

减去每个元素子列表的值:
  1. (mapcar '(lambda (e) (abs (- a (car e)))) lst2)

我们选择最小值(间隔):
  1. (apply 'min (mapcar '(lambda (e) (- a (car e))) lst2))

这个怎么说?
对不起我的英语。
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-5 22:40:46 | 显示全部楼层
  1. (defun mininterval ( lst1 lst2 )
  2. (car (vl-sort (mapcar '(lambda ( a b ) (abs (- a (car b)))) lst1 lst2) '(lambda ( a b ) (< a b))))
  3. )
回复

使用道具 举报

5

主题

956

帖子

963

银币

初来乍到

Rank: 1

铜币
35
发表于 2022-7-5 22:47:27 | 显示全部楼层
尝试道格·威尔逊大师的著名方法
  1. (vl-sort
  2. (apply 'mapcar (cons 'cons (list lst1 lst2))); just did a tweak
  3. ''(( a b ) (< (car a) (car b))))
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 22:58:05 | 显示全部楼层
 
hanhphuc,注意:
  1. (apply 'mapcar (cons 'cons (list lst1 lst2)))
与:
  1. (mapcar 'cons lst1 lst2)
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 23:02:39 | 显示全部楼层
我可能错了,但我明白OP在寻找这样的东西:
  1. (defun f ( l1 l2 )
  2.    (setq l1 (vl-sort l1 '<)
  3.          l2 (vl-sort l2 '(lambda ( a b ) (< (car a) (car b))))
  4.    )
  5.    (mapcar
  6.       '(lambda ( a )
  7.            (cons a
  8.                (cond
  9.                    (   (vl-some
  10.                           '(lambda ( b c )
  11.                                (if (< a (car c))
  12.                                    (if (< (abs (- a (car c))) (abs (- a (car b)))) c b)
  13.                                )
  14.                            )
  15.                            l2 (cdr l2)
  16.                        )
  17.                    )
  18.                    (   (last l2))
  19.                )
  20.            )
  21.        )
  22.        l1
  23.    )
  24. )

你也激励了我
回复

使用道具 举报

5

主题

956

帖子

963

银币

初来乍到

Rank: 1

铜币
35
发表于 2022-7-5 23:15:30 | 显示全部楼层
 
谢谢hanhphuc
 
我的观点是,在这种情况下不需要使用list/apply,因为本例中list函数的唯一目的是启用apply函数。
 
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 23:26:11 | 显示全部楼层
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-11 06:29 , Processed in 1.081578 second(s), 66 queries .

© 2020-2025 乐筑天下

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