在桌面编写一个 scala 文件 Test2.scala,从键盘输入一个正整数 n,计算 n 的阶乘,并输出最终结果。例如输入 4,4 的阶乘为 4*3*2*1. 分别用以下三种方法实现 方法一 递归:多次调用同一方法 factorial(),直到不满足条件为止。(A 调用 A) 方法二 迭代:定义一个方法 factorial(),重复反馈过程的活动,每一次迭代的 结果会作为下一次迭代的初始值。(A 重复调用 B) 方法三 Range 和 Reduce:创建一个 1 到 n 的等差序列,对序列使用 reduce 方 法实现累乘
时间: 2024-02-20 10:01:46 浏览: 18
好的,以下是对你的问题的回答:
对于这个问题,我们可以分别使用三种方法来实现计算一个正整数的阶乘。下面是三种方法的具体实现:
方法一 递归:
```scala
object Test2 {
def main(args: Array[String]): Unit = {
print("请输入一个正整数n:")
val n = scala.io.StdIn.readInt()
println(s"$n 的阶乘结果为:${factorial(n)}")
}
def factorial(n: Int): Int = {
if(n == 1) 1
else n * factorial(n-1)
}
}
```
方法二 迭代:
```scala
object Test2 {
def main(args: Array[String]): Unit = {
print("请输入一个正整数n:")
val n = scala.io.StdIn.readInt()
println(s"$n 的阶乘结果为:${factorial(n)}")
}
def factorial(n: Int): Int = {
var res = 1
for(i <- 1 to n) res *= i
res
}
}
```
方法三 Range 和 Reduce:
```scala
object Test2 {
def main(args: Array[String]): Unit = {
print("请输入一个正整数n:")
val n = scala.io.StdIn.readInt()
println(s"$n 的阶乘结果为:${factorial(n)}")
}
def factorial(n: Int): Int = {
(1 to n).reduce(_ * _)
}
}
```
希望我的回答可以帮到你!
阅读全文