scala斐波那契数列
时间: 2024-03-27 11:34:20 浏览: 125
Scala是一种运行在Java虚拟机上的编程语言,它结合了面向对象编程和函数式编程的特性。斐波那契数列是一个经典的数学问题,定义如下:第一个和第二个数都是1,从第三个数开始,每个数都是前两个数的和。在Scala中,可以使用递归或循环来实现斐波那契数列。
递归实现斐波那契数列的代码如下:
```scala
def fibonacci(n: Int): Int = {
if (n <= 2) 1
else fibonacci(n - 1) + fibonacci(n - 2)
}
val n = 10
val result = fibonacci(n)
println(s"The $n-th Fibonacci number is: $result")
```
循环实现斐波那契数列的代码如下:
```scala
def fibonacci(n: Int): Int = {
var a = 0
var b = 1
var i = 0
while (i < n) {
val temp = a
a = b
b = temp + b
i += 1
}
a
}
val n = 10
val result = fibonacci(n)
println(s"The $n-th Fibonacci number is: $result")
```
相关问题
scala实现斐波那契数列
以下是一种在 Scala 中实现斐波那契数列的方法:
```
def fib(n: Int): Int = {
if (n <= 1) return n
return fib(n-1) + fib(n-2)
}
```
这里使用了递归的方法实现斐波那契数列,如果 `n` 小于等于 1,则直接返回 `n`;否则递归调用 `fib` 函数,求出 `fib(n-1) + fib(n-2)` 的值。
使用scala求斐波那契数列前3项和,要求有输入
在Scala中,可以通过递归或迭代的方式来计算斐波那契数列。下面是一个简单的迭代方法来计算前3项和的示例:
```scala
import scala.io.StdIn
object FibonacciSum {
def main(args: Array[String]): Unit = {
println("请输入想要计算的斐波那契数列项数:")
val n = StdIn.readInt()
if (n >= 1) {
println(s"斐波那契数列前$n项的和为:${fibSum(n)}")
} else {
println("输入的项数应该大于等于1")
}
}
// 计算斐波那契数列前n项的和
def fibSum(n: Int): Int = {
var sum = 0
var a = 0
var b = 1
for (i <- 1 to n) {
sum += a
val next = a + b
a = b
b = next
}
sum
}
}
```
这段代码首先通过`StdIn.readInt()`接收用户输入,然后调用`fibSum`函数计算斐波那契数列的前n项和。`fibSum`函数通过迭代的方式计算数列的和,使用两个变量`a`和`b`来保存连续的两个斐波那契数,然后在循环中累加到`sum`变量。
阅读全文