目前正在使用一个我以前从未使用过Scala的类,所以语法本身就是新的。
我正在研究一个简单的除法函数,但遇到了一些错误。
首先,我使用var sub = m对吗?在我的代码中,我只想做m = m-n,但是你不能改变变量,我不确定最好的选择是什么。 然后我唯一的另一个问题是编译器对我的打印线咆哮..
<console>:14: error: reassignment to val
m = m-n
/////////////////////////////////////////////// ////////////////////////////////
<console>:16: error: type mismatch;
found : Unit
required: Int
println(x)
/////////////////////////////////////////////// ////////////////////////////////
def div(m: Int, n: Int): Int = {
var x = 0
var sub = m
if (n > m)
print("Can't perform that.")
while (sub >= n) {
x+=1
sub = sub-n
}
println(x)
}
答案 0 :(得分:7)
问题实际上是你的回报价值。您声明div
返回Int
并且编译器(在您的情况下)假设您的最后一个语句是您的返回值。由于println
返回Unit
(它是void
函数),编译器会感到困惑。
您可以通过在函数中的任何位置说return x
来显式返回值,也可以将x
作为函数中的最后一个语句(或该函数中的一个特定执行路径)。例如:
def what(b:Boolean):Int = {
if(b) 1
else 0
}
(Scala允许我写def what(b:Boolean) = if(b) 1 else 0
,它与上面的功能完全相同,但除此之外。)
为方便起见,这是您的功能,我所描述的修改:
def div(m: Int, n: Int): Int = {
var x = 0
var sub = m
if (n > m)
print("Can't perform that.")
while (sub >= n) {
x+=1
sub = sub-n
}
println(x)
x // <--- return value
}
答案 1 :(得分:3)
为了完整性,请在此处添加更多惯用的递归定义:
def div(m: Int, n: Int): Int = {
@annotation.tailrec
def loop(count: Int, sub: Int): Int =
if (sub < n) count
else loop(count + 1, sub - n)
loop(0, m)
}