Java实现 蓝桥杯 历届试题 斐波那契
试题 历届试题 斐波那契
资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
斐波那契数列大家都非常熟悉。它的定义是:
f(x) = 1 … (x=1,2)
f(x) = f(x-1) + f(x-2) … (x>2)
对于给定的整数 n 和 m,我们希望求出:
f(1) + f(2) + … + f(n) 的值。但这个值可能非常大,所以我们把它对 f(m) 取模。
公式如下

但这个数字依然很大,所以需要再对 p 求模。
输入格式
输入为一行用空格分开的整数 n m p (0 < n, m, p < 10^18)
输出格式
输出为1个整数,表示答案
样例输入
2 3 5
样例输出
0
样例输入
15 11 29
样例输出
25
import java.math.BigInteger;
import java.util.Scanner;
public class 斐波那契 {
static BigInteger[][] cal_fm = { { new BigInteger("1"), new BigInteger("1") },
{ new BigInteger("1"), new BigInteger("0") } };
static BigInteger[][] cal_sum = { { new BigInteger("2"), new BigInteger("0"), new BigInteger("-1") },
{ new BigInteger("1"), new BigInteger("0"), new BigInteger("0") },
{ new BigInteger("0"), new BigInteger("1"), new BigInteger("0") } };
static BigInteger[][] MOD = { { new BigInteger("1") }, { new BigInteger("1") } };
static BigInteger[][] SUM = { { new BigInteger("4") }, { new BigInteger("2") }, { new BigInteger("1") } };
private static BigInteger[][] mult(BigInteger[][] cal_fm2, BigInteger[][] mOD2, BigInteger p, boolean flag) {
int i_max = cal_fm2.length;
int j_max = mOD2[0].length;
int k_max = cal_fm2[0].length;
if (k_max != mOD2.length) {
return null;
}
BigInteger[][] ans = new BigInteger[i_max][j_max];
for (int i = 0; i < i_max; i++) {
for (int j = 0; j < j_max; j++) {
BigInteger sum = new BigInteger("0");
for (int k = 0; k < k_max; k++) {
if (flag) {
sum = (sum.mod(p)).
add(cal_fm2[i][k].multiply(mOD2[k][j]).
mod(p)).
mod(p);
} else {
sum = (sum.add(cal_fm2[i][k].multiply(mOD2[k][j])));
}
}
if (flag) {
ans[i][j] = sum.mod(p);
} else {
ans[i][j] = sum;
}
}
}
return ans;
}
public static String fib(long n, long m, long p) {
BigInteger mod = new BigInteger("0");
BigInteger sum = new BigInteger("0");
if (m > n + 2) {
if (n == 1) {
sum = new BigInteger("1");
} else {
n = n - 1;
while (n != 0) {
// System.out.println(n);
if ((n & 1) == 1) {
SUM = mult(cal_sum, SUM, new BigInteger(String.valueOf(p)), true);
}
n = n >> 1;
cal_sum = mult(cal_sum, cal_sum, new BigInteger(String.valueOf(p)), true);
}
sum = SUM[2][0];
}
// System.out.println(sum);
return sum.mod(new BigInteger(String.valueOf(p))).toString();
} else {
if (m == 1 || m == 2) {
mod = new BigInteger("1");
} else {
m = m - 1;
while (m != 0) {
if ((m & 1) == 1) {
MOD = mult(cal_fm, MOD, new BigInteger(String.valueOf(p)), false);
}
m = m >> 1;
cal_fm = mult(cal_fm, cal_fm, new BigInteger(String.valueOf(p)), false);
}
mod = MOD[1][0];
}
if (n == 1) {
sum = new BigInteger("1");
} else {
n = n - 1;
while (n != 0) {
if ((n & 1) == 1) {
SUM = mult(cal_sum, SUM, mod, true);
}
n = n >> 1;
cal_sum = mult(cal_sum, cal_sum, mod, true);
}
sum = SUM[2][0];
}
return sum.mod(new BigInteger(String.valueOf(p))).toString();
}
}
public static void main(String[] args) {
long n, m, p;
Scanner scanner = new Scanner(System.in);
n = scanner.nextLong();
m = scanner.nextLong();
p = scanner.nextLong();
System.out.println(fib(n, m, p));
}
}
Java实现 蓝桥杯 历届试题 斐波那契的更多相关文章
- 算法笔记_173:历届试题 斐波那契(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 斐波那契数列大家都非常熟悉.它的定义是: f(x) = 1 .... (x=1,2) f(x) = f(x-1) + f(x-2) ... ...
- Java实现蓝桥杯历届试题分考场
历届试题 分考场 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 n个人参加某项特殊考试. 为了公平,要求任何两个认识的人不能分在同一个考场. 求是少需要分几个考场才能满足条件. 输 ...
- Java实现蓝桥杯历届试题兰顿蚂蚁
历届试题 兰顿蚂蚁 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 兰顿蚂蚁,是于1986年,由克里斯·兰顿提出来的,属于细胞自动机的一种. 平面上的正方形格子被填上黑色或白色.在其 ...
- Java实现蓝桥杯历届试题回文数字
历届试题 回文数字 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 观察数字:12321,123321 都有一个共同的特征,无论从左到右读还是从右向左读,都是相同的.这样的数字叫做: ...
- Java实现蓝桥杯历届试题高僧斗法
历届试题 高僧斗法 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 问题描述 古时丧葬活动中经常请高僧做法事.仪式结束后,有时会有"高僧斗法"的趣味节目,以 ...
- Java实现蓝桥杯历届试题买不到的数目
历届试题 买不到的数目 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 问题描述 小明开了一家糖果店.他别出心裁:把水果糖包成4颗一包和7颗一包的两种.糖果不能拆包卖. 小朋友 ...
- Java实现 蓝桥杯 历届试题 小计算器
历届试题 小计算器 时间限制:1.0s 内存限制:256.0MB 问题描述 模拟程序型计算器,依次输入指令,可能包含的指令有 1. 数字:'NUM X',X为一个只包含大写字母和数字的字符串,表示一个 ...
- Java实现蓝桥杯 历届试题 k倍区间
历届试题 k倍区间 时间限制:2.0s 内存限制:256.0MB 问题描述 给定一个长度为N的数列,A1, A2, - AN,如果其中一段连续的子序列Ai, Ai+1, - Aj(i <= j) ...
- Java实现 蓝桥杯 历届试题 小数第n位
历届试题 小数第n位 时间限制:1.0s 内存限制:256.0MB 问题描述 我们知道,整数做除法时,有时得到有限小数,有时得到无限循环小数. 如果我们把有限小数的末尾加上无限多个0,它们就有了统一的 ...
随机推荐
- Day_11【集合】扩展案例5_对list集合对象中的元素进行反转,求最大值最小值,求元素i在list集合中首次出现的索引,将oldvalue替换为newvalue
分析以下需求,并用代码实现 定义MyArrays工具类,该工具类中有以下方法,方法描述如下: 1.public static void reverse(ArrayList<Integer> ...
- DP之石子堆合并问题
相邻 环形 总结 (1)相邻:在一个圆形操场的四周摆放着n堆石子(n<= 100),现要将石子有次序地合并成一堆.规定每次只能选取相邻的两堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得 ...
- Python 的缩进是不是反人类的设计?
前些天,我写了<Python为什么使用缩进来划分代码块?>,文中详细梳理了 Python 采用缩进语法的 8 大原因.我极其喜欢这种简洁优雅的风格,所以对它赞美有加. 然而文章发出去后,非 ...
- Python --函数学习2
一.函数参数和返回值 --参数:负责给函数传递一些必要的数据或者信息 -形参(形式参数):在函数定义的时候用到的参数,没有具体值,只是一个占位符号 -实参(实际参数):在调用函数的时候输入的值 exa ...
- 记一次Oracle分区表全局索引重建的过程
1.查询数据库各个表空间利用率: SELECT Upper(F.TABLESPACE_NAME) "表空间名", D.TOT_GROOTTE_MB "表空间大小(M)&q ...
- 如何通过VMware安装Linux CentOS 7.7系统
如何在Vmware安装Linux CentOS 7.7系统,并且是最小化安装.之后进行必要的配置修改,并实现基础优化.最后做一个快照. 安装Linux CentOS 7.7 安装要求:安装后的虚拟机用 ...
- 最短路径——dijkstra算法代码(c语言)
最短路径问题 看了王道的视频,感觉云里雾里的,所以写这个博客来加深理解.(希望能在12点以前写完) 一.总体思想 dijkstra算法的主要思想就是基于贪心,找出从v开始的顶点到各个点的最短路径,做法 ...
- docker 容器核心技术
容器的数据卷(volume)也是占用磁盘空间,可以通过以下命令删除失效的volume: [root@localhost]# sudo docker volume rm $(docker volume ...
- .Net基础之3——运算符
(3)Convert类型转换 1.类型如果相兼容的两个变量,可以使用自动类型转换或者显示类型转换. 但是如果两个类型的变量不兼容,这个时候可以使用一个叫做Convert的转换工厂进行转换. 注意:使用 ...
- SecureCRT 简单运用
1.想要从本地电脑将文件通过secureCRT传输到远程服务器如下目录 2.在SecureCRT界面中使用快捷键[Alt+P] 打开了SFTP的界面 3.找到你要传的文件的地址[E:\a.zip] 4 ...