蓝桥杯 入门训练 Fibonacci数列 (Java)

简介: 蓝桥杯 入门训练 Fibonacci数列 (Java)

问题描述


Fibonacci数列的递推公式为:Fn=Fn-1+Fn-2,其中F1=F2=1。

当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少。


输入格式


输入包含一个整数n。


输出格式


输出一行,包含一个整数,表示Fn除以10007的余数。

说明:在本题中,答案是要求Fn除以10007的余数,因此我们只要能算出这个余数即可,而不需要先计算出Fn的准确值,再将计算的结果除以10007取余数,直接计算余数往往比先算出原数再取余简单。


样例输入

10

样例输出

55

样例输入

22

样例输出

7704


因为是一个递推,然后我们可以用一个数组然后来计算,让我们求Fn除以10007的余数是多少,然后我们数组是我们输入一个值来求这个值的Fn,所以我们也可以把这个值作为我们数组的下标来使用,然后我们打印这个数组的n-1项并除以10007的余数,我在最后打印是除以10007,最后得了30分,我估计这30分得输入值最后计算的Fn都是小于10007的,所以我们最后余上10007还是这个数,然后看到说明,我们可以直接计算余数,因为我们Fn是从F1F2加上去的所以我们在进行赋值是就余上10007

import java.util.Scanner;
public class Main {
public static void main(String[] args) {
  Scanner sc = new Scanner(System.in);
  while(sc.hasNext()) {
  int b = sc.nextInt();//输入值并且赋给b
  int[] a = new int[b];//定义一个数组a
  if(b>=1&&b<=1000000)//b的条件是大于等于1并且小于等于1000000,所以我们判断一下,其实输入的值肯定在这个范围内所以不写这个也行
  {
        for(int i=2;i<b;i++) {//我们从下标为2开始,因为下标为0是1为1也是1,我们在下面直接赋值
          a[0] = 1;
          a[1] = 1;
          a[i] = (a[i-1] + a[i-2])%10007 ;//因为Fn就是从这样加上去的,所以我们直接就余上10007
        }
  }
  System.out.println(a[b-1]);//最后打印b-1项,因为我们是从0开始的所以是b-1项
  }
  sc.close();
  }
}


目录
相关文章
|
10月前
|
数据采集 机器学习/深度学习 Java
Java 大视界 -- Java 大数据在智能体育赛事运动员体能监测与训练计划调整中的应用(200)
本篇文章聚焦 Java 大数据在智能体育赛事中对运动员体能监测与训练计划的智能化应用。通过构建实时数据采集与分析系统,结合机器学习模型,实现对运动员体能状态的精准评估与训练方案的动态优化,推动体育训练迈向科学化、个性化新高度。
|
存储 机器学习/深度学习 算法
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
蓝桥杯Python编程练习题的集合,涵盖了从基础到提高的多个算法题目及其解答。
887 3
蓝桥杯练习题(三):Python组之算法训练提高综合五十题
|
Python
蓝桥杯练习题(一):Python组之入门训练题
这篇文章是关于蓝桥杯Python组的入门训练题,包括Fibonacci数列、圆的面积、序列求和和A+B问题的具体代码实现和样例输出。
474 0
|
机器学习/深度学习 人工智能 分布式计算
Java中的机器学习模型集成与训练
Java中的机器学习模型集成与训练
|
机器学习/深度学习 分布式计算 算法
Java中的机器学习模型集成与训练实践
Java中的机器学习模型集成与训练实践
|
机器学习/深度学习 算法 Java
Java中的机器学习模型集成与训练策略
Java中的机器学习模型集成与训练策略
|
存储 算法 前端开发
2019蓝桥杯大赛省赛Java大学B组 数列求值
2019蓝桥杯大赛省赛Java大学B组 数列求值
163 0
P9242 [蓝桥杯 2023 省 B] 接龙数列JAVA,边权为1的最短路问题,洛谷P9242 [蓝桥杯 2023 省 B] 接龙数列​编辑力扣1926.迷宫离入口最近的出口力扣433.
P9242 [蓝桥杯 2023 省 B] 接龙数列JAVA,边权为1的最短路问题,洛谷P9242 [蓝桥杯 2023 省 B] 接龙数列​编辑力扣1926.迷宫离入口最近的出口力扣433.
|
7月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
397 1
|
7月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
373 1

热门文章

最新文章