蓝桥杯 入门训练 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();
  }
}


目录
相关文章
|
5天前
|
JSON NoSQL Java
Redis入门到通关之Java客户端SpringDataRedis(RedisTemplate)
Redis入门到通关之Java客户端SpringDataRedis(RedisTemplate)
14 0
|
6天前
|
Java 开发工具 Windows
Java入门及环境变量
Java入门及环境变量
12 1
|
6天前
|
Java API 调度
[AIGC] 深入理解Java并发编程:从入门到进阶
[AIGC] 深入理解Java并发编程:从入门到进阶
|
6天前
|
负载均衡 Java 数据库连接
Java从入门到精通:4.2.2学习新技术与框架——不断扩展自己的知识面,跟上技术的发展趋势
Java从入门到精通:4.2.2学习新技术与框架——不断扩展自己的知识面,跟上技术的发展趋势
|
6天前
|
Java Nacos 开发者
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
|
6天前
|
监控 前端开发 Java
Java从入门到精通:4.1.2参与实际项目——学习与团队成员协作,了解项目开发的流程和规范
Java从入门到精通:4.1.2参与实际项目——学习与团队成员协作,了解项目开发的流程和规范
|
6天前
|
前端开发 Java 测试技术
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
|
3天前
|
设计模式 安全 Java
【JAVA】Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式
【JAVA】Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式
|
1天前
|
消息中间件 监控 安全
【JAVAEE学习】探究Java中多线程的使用和重点及考点
【JAVAEE学习】探究Java中多线程的使用和重点及考点
|
1天前
|
安全 Java 开发者
构建高效微服务架构:后端开发的新范式Java中的多线程并发编程实践
【4月更文挑战第29天】在数字化转型的浪潮中,微服务架构已成为软件开发的一大趋势。它通过解耦复杂系统、提升可伸缩性和促进敏捷开发来满足现代企业不断变化的业务需求。本文将深入探讨微服务的核心概念、设计原则以及如何利用最新的后端技术栈构建和部署高效的微服务架构。我们将分析微服务带来的挑战,包括服务治理、数据一致性和网络延迟问题,并讨论相应的解决方案。通过实际案例分析和最佳实践的分享,旨在为后端开发者提供一套实施微服务的全面指导。 【4月更文挑战第29天】在现代软件开发中,多线程技术是提高程序性能和响应能力的重要手段。本文通过介绍Java语言的多线程机制,探讨了如何有效地实现线程同步和通信,以及如