recursion - 球拍两个相互引用的方法
问题描述
我正在The Little Schemer做练习,但我在 Racket 中使用 DrRacket 做练习。
其中一个练习有两种相互引用的方法。这可以在球拍中完成吗?如果可以,怎么做?
当尝试在 DrRacket ide 中执行此操作时,我收到一个错误,因为在文件中创建的更高版本无法引用后面的内容。我假设这是因为它正在被解释,但我不确定。
有没有办法解决这个问题?
解决方案
是的,这在 Racket 中是可能的。它被称为“相互递归”,举个例子,我们可以定义过程odd?
并even?
相互定义——这不是最有效的方法,只是为了演示这个概念:
#lang racket
(define (odd? n)
(if (zero? n)
#f
(even? (- n 1))))
(define (even? n)
(if (zero? n)
#t
(odd? (- n 1))))
也许您正在使用一种禁止引用尚未定义的程序的教学语言?单击窗口的左下角并选择“从源代码确定语言”,然后#lang racket
在代码的开头键入。
推荐阅读
- git - Git:如何获得 date 的第二个最新版本?(当被拒绝后缀标签时)
- c# - 在表达式中为重载集合参数使用泛型
- visual-studio-code - 如何在 Visual Studio Code 中使用特定的 Solidity 版本进行编译?
- c# - 通过查找和附加到 64 位进程将 C# 转换为 VB
- node.js - 需要按顺序申请两组,第二组应该会影响第一组的结果
- html - Internet Explorer 11 中未显示 Bootstrap 4.1 轮播
- ckeditor5 - 如何将“target”属性添加到ckeditor5中的`a`标签?
- r - 在R中导入excel文件时日期更改
- php - 使用 create_function php 读取外部变量
- oracle - 重命名索引影响