蓝桥杯——Fibonacci数列

蓝桥杯——Fibonacci数列

解决方法一,递归解决


  
  
import java.util.Scanner;
public class BEGIN4 {
 static int n;    public static void main(String[] args) {      Scanner scanner = new Scanner(System.in);   n = scanner.nextInt();   if(n==1||n==2) System.out.println(1);   else    System.out.println(f(1,1,3));
 }    static int f(int a, int b, int i){   a = a%10007;   b = b%10007;   if(i==n) return (a+b)%10007;   i++;      return f(b%10007, (a+b)%10007, i);     }
}

问题:代码不够简洁,而且测试数据 999999 通不过

解决方法二,递归的优化

import java.util.Scanner;
public class Main{

	
	public static void main(String[] args) {
		
		Scanner scanner = new Scanner(System.in);
		int n = scanner.nextInt();
		System.out.println(f(n));
		
	}
	
	public static int f(int n) {
		if(n==1||n==2) return 1;
		else {
			return f(n-1)%10007+f(n-2)%10007;
		}
	}
	
	
}

问题:代码简洁了不少,这才是 递归应有的状态!,但测试数据 999999 还是报错,我怀疑是递归的问题

解决方法三,循环

import java.util.Scanner;

public class Main{

	
	public static void main(String[] args) {
		
		Scanner scanner = new Scanner(System.in);
		int n = scanner.nextInt();
		int sum = 1;
		int a = 1;
		int b = 1;
		for(int i = 3; i <= n; i++){
			sum = (a+b)%10007;
			a = b%10007;
			b = sum%10007;
		}
		System.out.println(sum);
		
	}
	
	
}

附:这次没有问题了。


结语:

循环的时间复杂度和空间复杂度都优于用 递归实现。
递归的优越性在于条理清晰,可读性强,比较适宜于问题本身是递归性质的、用循环难于解决的问题。在二者都不难的情况下,一般都是优先选用循环来解决问题的。
优先用 循环!,而不是 递归!




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值