乐筑天下

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

[编程交流] 将列表分成两个子列表

[复制链接]

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 19:32:54 | 显示全部楼层
还有一个:
  1. (defun div ( d l / m r )
  2.    (foreach x l
  3.        (if (= x d)
  4.            (if   m (setq r (cons (reverse m) r) m nil))
  5.            (setq m (cons x m))
  6.        )
  7.    )
  8.    (reverse (if m (cons (reverse m) r) r))
  9. )
  1. _$ (div "sep" '("a" "b" "c" "sep" "d" "e" "f"))
  2. (("a" "b" "c") ("d" "e" "f"))
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 19:35:48 | 显示全部楼层
另一种递归解决方案:
  1. (defun div ( d l / r )
  2.    (cond
  3.        (   (= (car l) d) (div d (cdr l)))
  4.        (   (setq l (vl-member-if '(lambda ( x ) (setq r (cons x r)) (= x d)) l))
  5.            (cons (reverse (cdr r)) (div d (cdr l)))
  6.        )
  7.        (   r (list (reverse r)))
  8.    )
  9. )
回复

使用道具 举报

46

主题

161

帖子

104

银币

后起之秀

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

铜币
242
发表于 2022-7-5 19:43:41 | 显示全部楼层
我的版本
  1. (defun div ( d l / m r )
  2.    (foreach x l
  3.        (if (wcmatch x (strcat d "*"))
  4.            (if   m (setq r (cons (reverse m) r) m nil))
  5.            (setq m (cons x m))
  6.        )
  7.    )
  8.    (reverse (if m (cons (reverse m) r) r))
  9. )
  1. 19
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

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

铜币
358
发表于 2022-7-5 19:48:17 | 显示全部楼层
 
 
我看到你在第一次之后还要求了别的东西!无论如何,只要在我的上一个程序中用wcmatch函数替换/=即可,正如在上面的引号中修改的那样。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-12 13:43 , Processed in 0.946307 second(s), 58 queries .

© 2020-2025 乐筑天下

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