蓝桥杯 研究兔子的土豪 Java 斐波那契数列

斐波那契数列定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)
斐波那契数列对任意值取模都有循环节:
斐波那契数列a[n]对m取模,由于斐波那契数列的特征,只要存在a[j] mod m = a[k] mod m且a[j+1] mod m = a[k+1] mod m (j<k),则a[j] ~ a[k-1]为循环节。
考虑 两两相邻的斐波那契数 mod m的数对 ,最多只有m * (m - 1)种可能(这里没想清楚为什么是m * (m - 1),当然用m*m也可以)。
根据抽屉原理,a[0]~a[m * (m - 1) + 1]中必然存在相邻数对存在重复。因此必然存在循环节。

问题描述

某天,HWD老师开始研究兔子,因为他是个土豪
  ,所以他居然一下子买了一个可以容纳10^18代兔子的巨大笼子(好像比我们伟大的地球母亲大一点点?),并开始研究它们,之后,他了解了兔子的繁衍规律:即fibonacci数列。
  兔子繁殖了n代后,HWD老师很开心。
  但是,HWD老师有密集恐惧症,所以,他只能去卖了兔子,他找到了一个好的雇主,但是这个雇主有强迫症,他只每次收购1007只兔子,HWD老师为了避免自己的密集恐惧症,要尽量多的卖了兔子。
  但是即便是密集恐惧症,也打击不了HWD老师研究兔子的决心,他数着数着自己剩下的兔子……

输入格式

HWD老师让兔子繁衍了几代(一个整数,没有其他字符)。

输出格式

HWD老师剩余(残余?)的兔子(一个整数,忽略行尾回车及空格)。
  
求循环节算法

public static void main(String[] args) {
		int max = 1007*1007+2;
		int[] f = new int[max];
		f[0] = 0;f[1] = 1;f[2] = 1;
		for (int i = 3; i < max; i++) {
			f[i] = (f[i-1]+f[i-2])%1007;
			if(f[i]==1&&f[i-1]==0){//因为f[0] = 0;f[1] = 1;新的循环从f[0]f[1]开始
	            System.out.println("循环节长度:"+(i-1));//f[0]~f[i-2]
	            break;
	        }
		}
	}

题解

public class ADV327 {
	static String[] s;
	static long n;
	public static void main(String[] args) throws IOException {
		BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
		s = in.readLine().split(" ");
		n = Long.valueOf(s[0]);
        if (n == 1 || n == 2) {
            System.out.print(1);
            return;
        }
        int mod = 1007;
        long a = -1;
        long b = -1;
        n %= 108;
        for (int i = 1; i <= n; i++) {
            if (i == 1) {
                a = 1;
                continue;
            } else if (i == 2) {
                b = 1;
                continue;
            }
            long c = (a + b) % mod;
            a = b;
            b = c;
        }
        System.out.print(b);
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值