蓝桥杯c语言试题斐波那契,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) 取模。

公式如下

2331f4fa0b52449beccb53115ecb1610.png

但这个数字依然很大,所以需要再对 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));

}

}

算法笔记&lowbar;173&colon;历届试题 斐波那契&lpar;Java&rpar;

目录 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,它们就有了统一的 ...

随机推荐

【转载】JMeter学习(三十六)发送HTTPS请求

Jmeter一般来说是压力测试的利器,最近想尝试jmeter和BeanShell进行接口测试.由于在云阅读接口测试的过程中需要进行登录操作,而登录请求是HTTPS协议.这就需要对jmeter进行设置. ...

使用自定义标签模拟jstl的&lt&semi;c&colon;for each&gt&semi;标签

一.自定义标签的基本编写 下面编写一个自定义标签,它可以输出当前的时间. 1.编写标签类 类可以通过继承SimpleTagSupport类实现一个标签类编写.父类为我们提供了一些编写自定义标签的快捷的 ...

ADO&period;net操作数据库

今天整理硬盘,发现2年前开始着手开始学习C#的学习日记.陆续整理,一是自己的知识梳理梳理,二是希望与大家多多交流,能给初学者带来一定帮助,当然是更高兴的啦. 断线对象 另一类是与数据源无关的断线对象, ...

Spring事务管理者与Spring事务注解--声明式事务

1.在Spring的applicationContext.xml中配置事务管理者 PS:具体的说明请看代码中的注释 Xml代码:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值