博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
斐波那契数列找循环节
阅读量:3954 次
发布时间:2019-05-24

本文共 1350 字,大约阅读时间需要 4 分钟。

首先贴一个大佬的广义方法,,数学真的diao。。

暴力求法, 

一般情况下这样求long long 范围内的也就够了。

#include
#define ll long longusing namespace std;const int maxn=1e5+10;// 自调ll f[maxn];int main(){ int mod; cin>>mod; f[0]=0; f[1]=1; f[2]=1; for(int i=3;i<=maxn;i++) { f[i]=(f[i-1]+f[i-2])%mod; if(f[i]==1&&f[i-1]==0) { printf("循环节为 %d\n",i-1);// 循环节 i-1; break; } } return 0;}

来一道题:

问题描述

  某天,HWD老师开始研究兔子,因为他是个土豪

  ,所以他居然一下子买了一个可以容纳10^18代兔子的巨大笼子(好像比我们伟大的地球母亲大一点点?),并开始研究它们,之后,他了解了兔子的繁衍规律:即fibonacci数列。

  兔子繁殖了n代后,HWD老师很开心。

  但是,HWD老师有密集恐惧症,所以,他只能去卖了兔子,他找到了一个好的雇主,但是这个雇主有强迫症,他只每次收购1007只兔子,HWD老师为了避免自己的密集恐惧症,要尽量多的卖了兔子。

  但是即便是密集恐惧症,也打击不了HWD老师研究兔子的决心,他数着数着自己剩下的兔子……

输入格式

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

输出格式

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

样例输入

1

样例输出

1

数据规模和约定

  兔子的总量最大时小于HWD老师笼子的大小。

  f[1]=1,f[2]=1,f[3]=2 ……

因为10^18,所以随便开了一个循环节。

#include 
using namespace std;typedef long long ll;int main(){ ios::sync_with_stdio(false); ll n; cin>>n; if(n==1||n==2) { puts("1"); return 0; } int mod=1007; int q=108; ll a,b,c; n%=q; for(int i=1;i<=n;i++) { if(i==1) { a=1; continue; } if(i==2) { b=1; continue; } c=(a+b)%mod; a=b; b=c; } cout<
<

转载地址:http://vxyzi.baihongyu.com/

你可能感兴趣的文章
大数据技术之Hadoop(HDFS)第2章 HFDS的Shell操作
查看>>
大数据技术之HBase第3章 HBase数据结构
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java 之23种设计模式解析
查看>>
Java常用英语汇总(更新升级版)
查看>>
Java常用英语汇总(更新升级版)
查看>>
Java常用英语汇总(更新升级版)
查看>>
Java常用英语汇总(更新升级版)
查看>>
Java常用英语汇总(更新升级版)
查看>>
Java常用英语汇总(更新升级版)
查看>>