- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在做一项遍历 DAG 的家庭作业,寻找最短路线。在一些 SO 答案的帮助下,我已经准备好了很多东西。话虽如此,我在获取返回子列表列表的函数时遇到了麻烦,就像我需要进一步处理数据一样。数据文件有一个形式为(node1 node2 weight)的子列表列表
(define (children? node)
(define list '(1))
(map (lambda (x)
(cond
((equal? (car x) node)
(if (equal? list '(1))
(set-car! list x)
(append! list x)))))
data)
(if (equal? list '(1))
#f
list))
(define (append! lst . lsts)
(if (not (null? lsts))
(if (null? (cdr lst))
(begin
(set-cdr! lst (car lsts))
(apply append! (car lsts) (cdr lsts)))
(apply append! (cdr lst) lsts))))
当我运行 (children? 'b3) 时,我得到的结果如下所示:
((b3 b5 57) b3 b4 81 b3 b10 55 b3 b14 61 b3 b13 66)
什么时候它应该看起来像
((b3 b5 57) (b3 b4 81) (b3 b10 55) (b3 b14 61) (b3 b13 66))
任何人都可以在这里阐明我的问题吗?
预先感谢您的帮助。
最佳答案
修复缩进,您的代码变为
(define (children? node)
(define list '(1))
使用头部哨兵技巧。不错嘛...)。但由于它的目的是通过手术改变,它应该是新鲜制作的,而不是引用数据:
(define list (list 1))
等等,什么?两个 list
秒?这不是 Common Lisp,是吗? Scheme 是 Lisp-1,而不是 Lisp-2;函数名和值名在同一个命名空间中;所以;不要。
(define lst (list 1))
(map (lambda (x)
(cond
((equal? (car x) node)
(if (equal? list '(1))
(set-car! list x)
(append! list x)))))
连续两个条件就是一个and
,但更重要的是,head sentinel 技巧意味着您将返回真实结果 (cdr lst)
,因此无需更改其头部的内容。然后代码进行了简化,这就是首先使用 head sentinel 的全部目的:
(map (lambda (x)
(if (equal? (car x) node)
(append! lst x))) ; changed the name
没有替代条款?一般来说,不赞成,但在这里你做 map 是为了它的副作用,所以,只要你不使用 map
结果,你没事。更简单的方法是始终将备用子句作为习惯和良好风格来处理,例如
(map (lambda (x)
(if (equal? (car x) node)
(append! lst x) ; append two lists together... (see below)
#f))
data)
data
?那是什么?它应该作为 children?
的另一个形式参数添加.
(if (equal? lst '(1))
equal?
?为什么?要查看我们是否更改了它,只需
(if (null (cdr lst))
最少行动原则...
#f
(cdr lst))) ; cdr carries the true payload
(基本上,
(define (children? node data)
(let ((res (filter (lambda (x) (equal? (car x) node))
data)))
(if (not (null? res))
res
#f)))
)。好的。是吗?那么,这取决于以下是否正常工作。
(define (append! lst . lsts)
(if (not (null? lsts))
(if (null? (cdr lst))
(begin
(set-cdr! lst (car lsts))
(apply append! (car lsts) (cdr lsts)))
它追加 列表,所以 (append! (list 1) (list 2))
将返回与 (list 1 2)
相同的结果和 (append! (list 1) (list 2 3))
与(list 1 2 3)
相同.要在列表末尾添加一个项目(如 2
),我们必须先将其放入另一个列表中。因此,如果我们添加的项目本身就是一个列表,例如 '(2 3)
, 我们想得到 '(1 (2 3))
后退。为此,一个项目必须在附加之前包含在列表中。因此必须修改您的函数才能做到这一点。
(apply append! (cdr lst) lsts))))
在这里,您扫描(不断增长)的结果列表以找到它的最后一个单元格,再次每次添加的项目。您可以通过自己维护最后一个单元格指针并直接使用它来解决这个问题。那个“指针”是什么?这是lst
,你cdr
每次你append!
对它有所帮助;所以你可以做 (set-cdr! lst (list item))
直接你自己。你当然不能使用 lst
变量(为什么?)。
关于scheme - 以列表形式保存子列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42477325/
我有这个 html 代码: HELLO WORLD! X V HELLO WORLD! X V 我想按 X(类关闭)将父 div 的高度更改为 20px 并显示 V(类打开),但在每个 d
在会计应用程序的许多不同实现中,有两种主要的数据库设计方法来保存日志和分类帐数据。 只保留 Journal 信息,然后 Ledger 只是 Journal 的一个 View (因为 journal 总
我想在另一个子里面有一个子, sub a { sub b { } } 我想为每次调用 sub b 创建一个新的 sub a 实例。有没有办法在 Perl 中做到这一点? 当我运行上面的
我有一些代码正在查找重复项并突出显示单元格: Private Sub cmdDups_Click() Dim Rng As Range Dim cel As Range Set Rng = ThisW
可能有一个简单的解决方案,但我很难过。 我有一个包含一个 ID 字段的主表。在两个可能的字段中有一个具有该 ID 的子表。想象一个由选手 A 和选手 B 组成的 double 队。Master 表将有
假设我有一个包含对象的数组: [ { "id": "5a97e047f826a0111b754beb", "name": "Hogwarts", "parentId": "
我正在尝试对 MySQL 数据库表执行一对父/子模型的批量插入,但似乎无法使用标准的 ActiveRecord 功能来完成。所以,我尝试了 activerecord-import gem,但它也不支持
我有一个带有多个子类的父抽象类。最终,我希望通过 GUI 中的进度条显示子类中完成的进度。 我目前所做的,我意识到这是行不通的,是在父类中声明为每个子类将覆盖的虚拟方法的事件方法定义。所以像: pub
是否可以通过键数组在对象中设置变量?例如我有这个对象: var obj = {'outer': {'inner': 'value'} }; 并希望设置由键数组选择的值: var keys = ['ou
我有一个名为 companies 的 MySQL 表,如下所示: +---------+-----------+-----------+ | id_comp | comp_name | id_pare
我正在尝试使用 sublime text 在 sublime text 上的 ionic 上打开我的第一个应用程序。它给了我一个“找不到命令”的错误。如何修复? 我试过这些命令: sudo rm -r
不好意思问,但我正在使用 webapp2,我正在设计一个解决方案,以便更容易定义路由 based on this google webapp2 route function .但这完全取决于能够在子级
我有代表树的数字字符串(我不知道是否有官方名称): 012323301212 上面的例子代表了 2 棵树。根用 0 表示。根的直接子代为“1”,“1”的直接子代为“2”,依此类推。我需要将它们分组到由
是否可以在当前 Activity 之上添加 Activity 。例如,假设我单击一个按钮,然后它将第二个 Activity 添加到当前 Activity 。而第二个 Activity 只覆盖了我当前
我很难思考如何为子资源建模。 以作者的书籍为例。你可以有 N 本书,每本书只有一位作者。 /books GET /books POST /books/id PUT /books/id DELETE 到
有人可以向我解释以下内容(python 2.7) 来自已解析文件的两个字符串数字: '410.9''410.9 '(注意尾随空格) A_LIST = ['410.9 '] '410.9' in '41
背景 在 PowerShell 中构建 hash table 是很常见的通过特定属性快速访问对象,例如以 LastName 为基础建立索引: $List = ConvertFrom-Csv @' I
我真的很难弄清楚如何调用嵌套 Polymer Web 组件的函数。 这是标记: rise-distribution组件有 canPlay我想从 rise-playlist
我写了一个小工具转储(以 dot 格式)一个项目的依赖关系图,其中所有位于同一目录中的文件都聚集在一个集群中。当我尝试生成包含相应图形的 pdf 时,dot开始哭: 命令 dot -Tpdf trim
给定一个 CODE ref,是否可以: 访问该 CODE ref 的解析树 通过指定 CODE ref 的解析树来创建一个新的 CODE ref,该解析树可以包含在 1 中返回的解析树的元素 通常我们
我是一名优秀的程序员,十分优秀!