试题 历届试题 斐波那契

资源限制

时间限制: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实现 蓝桥杯 历届试题 斐波那契的更多相关文章

  1. 算法笔记_173:历届试题 斐波那契(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 斐波那契数列大家都非常熟悉.它的定义是: f(x) = 1 .... (x=1,2) f(x) = f(x-1) + f(x-2) ... ...

  2. Java实现蓝桥杯历届试题分考场

    历届试题 分考场 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 n个人参加某项特殊考试. 为了公平,要求任何两个认识的人不能分在同一个考场. 求是少需要分几个考场才能满足条件. 输 ...

  3. Java实现蓝桥杯历届试题兰顿蚂蚁

    历届试题 兰顿蚂蚁 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 兰顿蚂蚁,是于1986年,由克里斯·兰顿提出来的,属于细胞自动机的一种. 平面上的正方形格子被填上黑色或白色.在其 ...

  4. Java实现蓝桥杯历届试题回文数字

    历届试题 回文数字 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 观察数字:12321,123321 都有一个共同的特征,无论从左到右读还是从右向左读,都是相同的.这样的数字叫做: ...

  5. Java实现蓝桥杯历届试题高僧斗法

    历届试题 高僧斗法 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 问题描述 古时丧葬活动中经常请高僧做法事.仪式结束后,有时会有"高僧斗法"的趣味节目,以 ...

  6. Java实现蓝桥杯历届试题买不到的数目

    历届试题 买不到的数目 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 问题描述 小明开了一家糖果店.他别出心裁:把水果糖包成4颗一包和7颗一包的两种.糖果不能拆包卖. 小朋友 ...

  7. Java实现 蓝桥杯 历届试题 小计算器

    历届试题 小计算器 时间限制:1.0s 内存限制:256.0MB 问题描述 模拟程序型计算器,依次输入指令,可能包含的指令有 1. 数字:'NUM X',X为一个只包含大写字母和数字的字符串,表示一个 ...

  8. Java实现蓝桥杯 历届试题 k倍区间

    历届试题 k倍区间 时间限制:2.0s 内存限制:256.0MB 问题描述 给定一个长度为N的数列,A1, A2, - AN,如果其中一段连续的子序列Ai, Ai+1, - Aj(i <= j) ...

  9. Java实现 蓝桥杯 历届试题 小数第n位

    历届试题 小数第n位 时间限制:1.0s 内存限制:256.0MB 问题描述 我们知道,整数做除法时,有时得到有限小数,有时得到无限循环小数. 如果我们把有限小数的末尾加上无限多个0,它们就有了统一的 ...

随机推荐

  1. 【基础】excel如何根据数据内容显示不同颜色。

    需求: 店柜完成率排名相比上阶段升降,升显示绿色“↑“,降显示红色“↓”,持平显示黑色“-”. 步骤: 第一步 先计算两次排名的差值(本次排名-上次排名). 第二步 对差值列设置单元格格式,设置格式如 ...

  2. 关于Fragment的点击切换数据滞留问题

    场景再现:当我使用tabLayout + Fragment 切换不同的fragment时,出现了数据重复显示的问题: 思考逻辑: - 每次切换fragment都会重新获取数据,但是list集合是全局的 ...

  3. [hdu5375 Gray code]DP

    题意:给一个二进制码,其中有一些位上为'?',对每个问号确定是'0'还是'1',最后以它对应的格雷码来取数,第i位为1则取第i个数,求取得的数的和的最大值. 思路:二进制码B转换成格雷码G的方法是,G ...

  4. [hdu5266]区间LCA

    题意:给一棵树,求节点L,L+1,...R的最近公共祖先 思路:先对树dfs一下,从根1出发,经过每条边时记录一下终点和到达这个点的时间截,令r[u]表示到达u这个节点的最早时间截,t[x]表示在时间 ...

  5. Nginx下的location,upstream,rewrite 和 proxy_pass使用总计大全

    一 . location: 顾名思义-->地址,也叫路由. nginx服务器非常核心的配置,一般nginx运维人员在修改nginx配置时,大部分也是围绕着location这个配置进行修改. 下面 ...

  6. CompletableFuture的使用例子

    1. CompletableFuture的介绍 在Java8时被引入,在包java.util.concurrent下,是Java多线程编程中的一个类,扩展了Future中很多功能,Completabl ...

  7. vue.use()方法从源码到使用

    在做 vue 开发的时候大家一定经常接触 Vue.use() 方法,官网给出的解释是: 通过全局方法 Vue.use() 使用插件:我觉得把使用理解成注册更合适一些,首先看下面常见的注册场景. 1 2 ...

  8. css3 常用。

    CSS3 边框 通过 CSS3,您能够创建圆角边框,向矩形添加阴影,使用图片来绘制边框 - 并且不需使用设计软件,比如 PhotoShop. 在本章中,您将学到以下边框属性: border-radiu ...

  9. 复变函数-MINDMAPS-continuous updating

  10. windows假死原因调查

    0. 现象 windows假死了,键盘功能正常,就是画面卡住不动了. 1. 看log linux下面很容易通过命令dmesg和/var/log/message来看日志. 但是windows就懵逼了,不 ...