写一个程序打印斐波拉契 (Fibonacci) 数列,数列的长度可以由输入指定。 斐波拉契 (Fibonacci) 数列是的前两项分别是1和1,后续各项分别是前面两项的和。 1 1 2 3 5 8 13 21 34………… 至少用2种方式实现。
时间: 2023-06-17 19:08:08 浏览: 119
方法一:使用递归方式实现斐波那契数列
```
def Fibonacci(n):
if n <= 0:
return None
elif n == 1 or n == 2:
return 1
else:
return Fibonacci(n-1) + Fibonacci(n-2)
# 输入斐波那契数列长度
n = int(input("请输入斐波那契数列长度:"))
# 打印斐波那契数列
for i in range(1, n+1):
print(Fibonacci(i), end=" ")
```
方法二:使用循环方式实现斐波那契数列
```
n = int(input("请输入斐波那契数列长度:"))
if n <= 0:
print("输入有误")
elif n == 1:
print("1")
elif n == 2:
print("1 1")
else:
a, b = 1, 1
print("1 1", end=" ")
for i in range(3, n+1):
c = a + b
print(c, end=" ")
a, b = b, c
```
相关问题
用java写一个程序打印斐波拉契 (Fibonacci) 数列,数列的长度可以由输入指定。 斐波拉契 (Fibonacci) 数列是的前两项分别是1和1,后续各项分别是前面两项的和。 1 1 2 3 5 8 13 21 34…………
好的,以下是Java程序代码实现:
```
import java.util.Scanner;
public class Fibonacci {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入斐波拉契数列的长度:");
int length = input.nextInt();
int num1 = 1, num2 = 1;
System.out.print(num1 + " " + num2 + " ");
for (int i = 3; i <= length; i++) {
int num3 = num1 + num2;
System.out.print(num3 + " ");
num1 = num2;
num2 = num3;
}
}
}
```
运行程序,输入数列的长度即可打印出对应长度的斐波拉契数列。
JAVA写一个程序打印斐波拉契 (Fibonacci) 数列,数列的长度可以由输入指定。 斐波拉契 (Fibonacci) 数列是的前两项分别是1和1,后续各项分别是前面两项的和。 1 1 2 3 5 8 13 21 34………… 至少用2种方式实现。
### 回答1:
第一种方式:使用递归实现斐波那契数列
```
import java.util.Scanner;
public class Fibonacci {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入斐波那契数列的长度:");
int n = input.nextInt();
for (int i = 1; i <= n; i++) {
System.out.print(fibonacci(i) + " ");
}
}
public static int fibonacci(int n) {
if (n == 1 || n == 2) {
return 1;
} else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
}
```
第二种方式:使用循环实现斐波那契数列
```
import java.util.Scanner;
public class Fibonacci {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入斐波那契数列的长度:");
int n = input.nextInt();
int[] fib = new int[n];
fib[0] = 1;
fib[1] = 1;
for (int i = 2; i < n; i++) {
fib[i] = fib[i - 1] + fib[i - 2];
}
for (int i = 0; i < n; i++) {
System.out.print(fib[i] + " ");
}
}
}
```
### 回答2:
第一种方式:
```java
import java.util.Scanner;
public class FibonacciExample {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入斐波拉契数列的长度:");
int n = scanner.nextInt();
// 初始化前两个数
int first = 1;
int second = 1;
System.out.print("斐波拉契数列前 " + n + " 项为:");
System.out.print(first + " " + second + " ");
for (int i = 3; i <= n; i++) {
int curr = first + second;
System.out.print(curr + " ");
// 更新前两个数
first = second;
second = curr;
}
}
}
```
第二种方式:
```java
import java.util.Scanner;
public class FibonacciExample {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入斐波拉契数列的长度:");
int n = scanner.nextInt();
System.out.print("斐波拉契数列前 " + n + " 项为:");
for (int i = 1; i <= n; i++) {
System.out.print(fibonacci(i) + " ");
}
}
public static int fibonacci(int n) {
if (n == 1 || n == 2) {
return 1;
} else {
return fibonacci(n-1) + fibonacci(n-2);
}
}
}
```
以上两种方式都可以打印出指定长度的斐波拉契数列。第一种方式使用循环来逐个计算并打印数列中的每一项,而第二种方式使用递归来计算数列中的每一项并打印。
### 回答3:
方式一:
public class Fibonacci {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入要打印的斐波拉契数列的长度:");
int length = scanner.nextInt();
int[] fibonacci = new int[length];
fibonacci[0] = 1;
fibonacci[1] = 1;
for (int i = 2; i < length; i++) {
fibonacci[i] = fibonacci[i-1] + fibonacci[i-2];
}
for (int i = 0; i < length; i++) {
System.out.print(fibonacci[i] + " ");
}
}
}
方式二:
public class Fibonacci {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入要打印的斐波拉契数列的长度:");
int length = scanner.nextInt();
int firstNum = 1;
int secondNum = 1;
System.out.print(firstNum + " " + secondNum + " ");
for (int i = 3; i <= length; i++) {
int currentNum = firstNum + secondNum;
System.out.print(currentNum + " ");
firstNum = secondNum;
secondNum = currentNum;
}
}
}
以上是两种方式实现打印斐波拉契数列的程序,通过输入指定数列的长度,程序将计算并打印出相应长度的斐波拉契数列。方式一使用数组存储数列中的数字,并通过循环计算每一项的值;方式二则直接打印出每一项的值,通过变量保存前两项的值用于计算后续的项。
阅读全文