为什么这不能递归地工作?
下面是 Scala 中的一个程序。
def range(low : Int, high : Int) : List[Int] = {
var result : List[Int] = Nil
result = rangerec(root, result, low, high)
result
}
private def rangerec(r : Node, l : List[Int], low : Int, high :Int) : List[Int] = {
var resultList : List[Int] = List()
if(r.left != null) {
rangerec(r.left, resultList, low, high)
} else if(r.right != null) {
rangerec(r.right, resultList, low, high)
} else {
if(r.key >= low && r.key <= high) {
resultList = resultList ::: List(r.key)
resultList
}
}
resultList
}
我在二叉搜索树中创建了范围方法,实现了中序遍历算法。所以它必须递归地工作,但它不打印任何东西,List()。如何修复我的算法?或编辑我的代码?
Below is a program in Scala.
def range(low : Int, high : Int) : List[Int] = {
var result : List[Int] = Nil
result = rangerec(root, result, low, high)
result
}
private def rangerec(r : Node, l : List[Int], low : Int, high :Int) : List[Int] = {
var resultList : List[Int] = List()
if(r.left != null) {
rangerec(r.left, resultList, low, high)
} else if(r.right != null) {
rangerec(r.right, resultList, low, high)
} else {
if(r.key >= low && r.key <= high) {
resultList = resultList ::: List(r.key)
resultList
}
}
resultList
}
I made range method in my binary search tree, implementing in-order traversal algorithm. So it has to work recursively, but it doesn't print anything, List(). How to fix my algorithm? or edit my code?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我不知道 scala,但您需要使用作为参数传递到递归函数的列表 l 并使用 rangerec 函数的输出。
I don't know scala, but you need to use list
l
passed as a parameter into recursive function and use output fromrangerec
function.在函数外部定义您的 resultList,因为我看到您将结果附加到该变量。顺便说一句,顺序遍历也遵循这个规则。访问左,访问根,最后访问右。然而从代码中(虽然我不懂scala),我可以破译你正在访问左,右,最后是根。
等效的递归按顺序打印 javacode 看起来像这样
所以,scala 可能看起来像这样(语法可能是错误的)
这里 resultList 是一个 List 类型的变量,应该从外部传递。
Define your resultList outside the function as I see you appending result to this variable. By the way, in order traversal follows this rule. Visit Left, Visit Root and finally Visit Right. However from the code (although I don't know scala), I can decipher that you are visiting left, right and finally root.
A equivalent recursive in-order printing javacode would have looked like this
So, the scala may look like this (syntax may be wrong)
Here resultList is a variable of type List which should be passed from outside.