- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我试图了解如何在此递归示例中使用 add1:
(define (my-length a-list)
(if (empty? a-list)
0
(add1(my-length (rest a-list)))))
如果给定 (my-list '(1 2 3 4))
程序将返回数字 4。
我知道在函数 my-lenght
的每次迭代之后,代码都会拆开列表,直到列表为空。我不明白的是 (add1)
是如何将每次迭代添加到函数中的。
最佳答案
为了另一种解释:
从这里开始
(my-length '(a b c d))
通过将参数填充到函数中,变成
(if (empty? '(a b c d))
0
(add1 (my-length (rest '(a b c d)))))
显然,'(a b c d)
不是空的。因此评估 if 的“else”情况:
(add1 (my-length (rest '(a b c d))))
(add1 (my-length '(b c d)))
现在,(my-length '(b c d))
是什么意思?好吧,如果我们将函数体复制粘贴到最后一行,我们会得到:
(add1 (if (empty? '(b c d))
0
(add1 (my-length (rest '(b c d))))))
继续...
(add1 (add1 (my-length (rest '(b c d)))))
(add1 (add1 (my-length '(c d))))
这一直持续到我们得到一个空列表:
(add1 (add1 (add1 (add1 (if (empty? '())
0
(add1 (my-length (rest '()))))))))
'()
为空,因此 if 语句返回 0:
(add1 (add1 (add1 (add1 0))))
(add1 (add1 (add1 1)))
(add1 (add1 2))
(add1 3)
4
这就像我们越来越深入地研究函数,因为对于我们采取的每一步,我们都需要再走一步来实际评估我们拥有的东西。
这与 (add1 '(a b c d))
有何不同?您可以从评估结果中看出 add1
从未真正应用于 a、b、c 或 d。我们甚至从未检查过列表中的内容。您可以有一个包含四个列表的列表,每个列表都包含列表的列表,并且它会评估所有相同的列表。
具体来说,说 (add1 '(a b c d))
就像在说“1 加草莓是多少?”,而您的函数更像是:
“这个列表里有多少东西?”
“好吧,如果您在顶部 ((first my-list)
) 上没有看到任何东西,那么肯定没有。”
“好吧,好吧……我在上面看到一个“a”!”
“很好!把它拿出来。列表中至少有 1 个。”
“好的,但剩下的有多少?”
“我们再试一次怎么样?继续从列表顶部取出项目,直到列表为空。然后,我们将把它放回去,边走边数。”
“好的,我已经把它们都取出来了。我现在要把它们放回去:d,那是 1;c,那是 2;b,那是 3;a,那是 4!”
“好了,列表中有 4 个!”
关于recursion - 这个 Racket 程序是如何使用 add1 的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24239027/
我意识到“强类型”和“软类型”的定义是松散且易于解释的,但我还没有找到关于无类型 Racket (根据我的理解意味着动态类型)和类型 Racket 的明确定义。 再一次,我确定它不是那么简单和干燥,但
我来自 Java 和 Python,很难理解面向对象代码在 Racket 中的工作方式。 给定 (define food% (class object% (super-new) (i
我安装了 Sublime Text - Racket Package,但没有用。出现此错误。我该怎么办。 [Errno 2] No such file or directory: 'racke
.rkt是“常规”Racket 源代码的常规文件扩展名。在文档中,我还看到了 .rktl 和 .rkts 正在使用。什么是.rktl和 .rkts用于,还有我不知道的更多 Racket 文件扩展名吗?
假设我为具有“中心”的集合定义了一个结构体。 (struct centered-set (center elems)) 我想保证以下条件。 elems是一个集合。 center是 elems 的成员(
我想要一个函数,它接受一个字符串,由一个 python 格式的树组成,就像这样 "[0, [1, 0]]" 并输出一个可用的 Racket 列表,像这样 '(0 (1 0)) 我的第一步是将字符串转换
是否有 Racket 内置函数列表?我正在寻找类似 this one 的列表对于 python 。我似乎无法在文档中找到一个。 最佳答案 这里有一些列表: Racket文档中所有函数的索引: http
虽然 Racket 允许创建 GUI 应用程序(甚至游戏),但我想知道它是否适合与 Things 一样在视觉上发布商业应用程序或 OmniOutliner .这样的应用程序会感觉原生还是看起来像一个不
和node的npm一样,我们使用package.json来解决依赖。 我试过raco pkg,它似乎只是一种开发/发布包的方式,而不是解决外部依赖。 最佳答案 如上所述,Racket 中的 info.
我是 Racket 的新手,尽管到目前为止我已经设法使用 servlet 并让一些东西发挥作用。我现在想做的是验证一个简单的用户名/密码 POST 请求。我已经通过“web-server/formle
我正在为现场编码表演创建一个程序,为此我需要一个基本的 S 表达式代码编辑器(我输入的内容将在适当的语法上下文中评估为 Racket 代码)。 由于 DrRacket 本身是用 Racket 编写的,
和node的npm一样,我们使用package.json来解决依赖。 我试过raco pkg,它似乎只是一种开发/发布包的方式,而不是解决外部依赖。 最佳答案 如上所述,Racket 中的 info.
我正在尝试在 Racket 中编写模块元语言 mylang ,它接受将修改后的主体传递给的第二种语言,例如: (module foo mylang typed/racket body) 相当于: (m
我没有运气找到一种方法来按照我想要的方式进行这项工作,所以如果有人能提供帮助,我将不胜感激。 我想要的是能够在终端上做到这一点: > racket 然后能够输入 Racket 命令并让它们编译。像,
我来自 Java 世界,对 Racket 充满热情。 想知道类似Maven的工具在哪里。如果你不熟悉Maven,还有Scala中的SBT,Android中的gradle,Elixir中的mix等,作为
在 typed/racket 我有一个像 [(? procedure? p ) (apply p xv*)]会导致错误: Type Checker: Function has no cases in:
我是 Lisp-scheme 的新手,对整个函数范式还很陌生,我目前正在做一个任务,要求我重载一个名称相同但参数集不同的函数 racket .下面是我试图实现的一个例子: #lang racket (
有没有办法在 Racket 中获取对象的唯一标识符?例如,当我们使用 Racket 的 eq?运算符来检查两个变量是否指向同一个对象,它使用什么标识符来实现这种比较? 我正在寻找类似 python 的
当我在 Dr. Racket 或从命令行运行我的测试时,失败的测试总是在一行上。 例如, (bad (interp-t-prog (list '(class posn extends object (
我有以下代码: (plot (function sin (- pi) pi #:label "y = sin(x)")) 但是在解决 SICP 时我没有遇到这样的结构:#:label "y = sin
我是一名优秀的程序员,十分优秀!