九度OJ 1081:递推数列 (递归,二分法)
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:6194
解决:864
- 题目描述:
-
给定a0,a1,以及an=p*a(n-1) + q*a(n-2)中的p,q。这里n >= 2。 求第k个数对10000的模。
- 输入:
-
输入包括5个整数:a0、a1、p、q、k。
- 输出:
-
第k个数a(k)对10000的模。
- 样例输入:
-
20 1 1 14 5
- 样例输出:
-
8359
思路:
直接一步一步的递推肯定是要超时的。对这种求第n个数的递推题,有logn的解法。
基本思想是a(n)由a(n/2)得到,逐次循环。
由an=p*a(n-1) + q*a(n-2)
可以得到an=p2*a(n-2) + q2*a(n-4)
其中 p2 = (p*p+2*q),
q2 = -q*q
这种思想是典型二分法,此题重点是学到了一种解题思想。
代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(void)
{
int p, q, p2, q2, k;
long long a0, a1, a2, a3;
while (scanf("%lld%lld%d%d%d", &a0, &a1, &p, &q, &k) != EOF)
{
if (k == 0)
{
printf("%lld\n", a0);
continue;
}
a0 %= 10000;
a1 %= 10000;
p %= 10000;
q %= 10000;
while (k>1)
{
a2 = p*a1+q*a0;
while (a2<0)
a2 += 1000000000;
a2 %= 10000;
if (k%2 == 1)
{
a3 = p*a2+q*a1;
while (a3<0)
a3 += 1000000000;
a3 %= 10000;
a0 = a1;
a1 = a3;
}
else
a1 = a2;
p2 = (p*p+2*q)%10000;
q2 = -q*q;
while (q2<0)
q2 += 1000000000;
q2 %= 10000;
p = p2;
q = q2;
k /= 2;
}
printf("%lld\n", a1);
}
return 0;
}
/**************************************************************
Problem: 1081
User: liangrx06
Language: C
Result: Accepted
Time:10 ms
Memory:912 kb
****************************************************************/
别人的代码,用了另一种递归方式,思想是类似的:
#include<stdio.h>
#define MOD 10000
long long a0,a1,p,q,k;
void matrixpow(long long *data,long long k)
{
long long t1,t2,t3,t4;
long long d1,d2,d3,d4;
d1 = p;
d2 = q;
d3 = 1;
d4 = 0;
if(k == 1 || k == 0)
return;
matrixpow(data,k/2);
t1 = (data[0]*data[0]+data[1]*data[2])%MOD;
t2 = (data[0]*data[1]+data[1]*data[3])%MOD;
t3 = (data[0]*data[2]+data[2]*data[3])%MOD;
t4 = (data[1]*data[2]+data[3]*data[3])%MOD;
data[0] = t1;
data[1] = t2;
data[2] = t3;
data[3] = t4;
if(k&1)
{
t1 = (data[0]*d1+data[1]*d3)%MOD;
t2 = (data[0]*d2+data[1]*d4)%MOD;
t3 = (data[2]*d1+data[3]*d3)%MOD;
t4 = (data[2]*d2+data[3]*d4)%MOD;
data[0] = t1;
data[1] = t2;
data[2] = t3;
data[3] = t4;
}
}
void main()
{
long long data[4];
long long res;
while(scanf("%lld%lld%lld%lld%lld",&a0,&a1,&p,&q,&k)!=EOF)
{
data[0] = p;
data[1] = q;
data[2] = 1;
data[3] = 0;
matrixpow(data,k-2);
if(k == 0)
res = a0%MOD;
else
{
if(k == 1)
res = a1%MOD;
else
{
if(k>2)
res = (data[0]*p*a1+a1*q*data[2]+a0*p*data[1]+a0*q*data[3])%MOD;
else
res = (a1*p+a0*q)%MOD;
}
}
printf("%lld\n",res);
}
}
九度OJ 1081:递推数列 (递归,二分法)的更多相关文章
- 九度OJ 1081 递推数列 -- 矩阵二分乘法
题目地址:http://ac.jobdu.com/problem.php?pid=1081 题目描述: 给定a0,a1,以及an=p*a(n-1) + q*a(n-2)中的p,q.这里n >= ...
- 九度OJ 1073:杨辉三角形 (递归)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3780 解决:1631 题目描述: 输入n值,使用递归函数,求杨辉三角形中各个位置上的值. 输入: 一个大于等于2的整型数n 输出: 题目可 ...
- 九度oj 题目1496:数列区间
题目描述: 有一段长度为n(1<=n<=1000000)的数列,数列中的数字从左至右从1到n编号.初始时数列中的数字都是0. 接下来我们会对其进行m(1<=m<=100000) ...
- 九度OJ 1092:Fibonacci (递归)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:1923 解决:1378 题目描述: The Fibonacci Numbers{0,1,1,2,3,5,8,13,21,34,55...} ...
- 九度OJ 1338:角斗士 (递归、DP)
时间限制:3 秒 内存限制:32 兆 特殊判题:否 提交:213 解决:66 题目描述: 角斗士是古罗马奴隶社会的一种特殊身份的奴隶,他们的职责是在角斗场上进行殊死搏斗,为了人们提供野蛮的娱乐.他们的 ...
- NOIP2013提高问题求解T2(关于递推与递归)
同步发表于我的洛谷博客. NOIP2013提高问题求解2: 现有一只青蛙,初始时在n号荷叶上.当它某一时刻在k号荷叶上时,下一时刻将等概率地随机跳到1,2,--,k号荷叶之一上,直到跳到第1号荷叶为止 ...
- 【九度OJ】题目1205:N阶楼梯上楼问题 解题报告
[九度OJ]题目1205:N阶楼梯上楼问题 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1205 题目描述: N阶楼梯上楼问题:一次 ...
- 【九度OJ】题目1078:二叉树遍历 解题报告
[九度OJ]题目1078:二叉树遍历 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1078 题目描述: 二叉树的前序.中序.后序遍历 ...
- 【九度OJ】题目1175:打牌 解题报告
[九度OJ]题目1175:打牌 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1175 题目描述: 牌只有1到9,手里拿着已经排好序的 ...
随机推荐
- koa2 从入门到进阶之路 (三)
之前的文章我们介绍了一下 koa 路由,get 传值,动态路由,本节我们看一下 koa 中间件 以及 koa 中间件的洋葱图执行流程. 一.什么是 Koa 的中间件 通俗的讲:中间件就是匹配路由之前或 ...
- ActiveMQ 使用spring模板 发布消息过程分析
convertAndSend()方法中获得dstination,即发送信息的目的地dstination可以在spring的配置文件中指定自定义的,在JmsTemplate类中,pubSubDomain ...
- python tcp,udp简单使用
import socket host = '127.0.0.1' port = 9999 #创建一个tcp socket套接字 tcp_server = socket.socket(socket.AF ...
- 正确理解hadoop 2.x 的环形缓冲区: (一) MR环形缓冲区的结构
转载:http://blog.csdn.net/HADOOP_83425744/article/details/49560583 http://bigdatadecode.club/MapReduce ...
- DevExpress控件之LookupEdit,ComboBoxEdit
ComboBoxEdit 1. ComBoxEdit没有DisplayMember 和 ValueMember 属性,只能获取显示的值2.当前选定值comboBoxEdit1.Propertie ...
- Linux下的定时任务Crontab
通过crontab -e写入定时任务的指令,一行为一项任务. 任务模式是时间克龙表达式+命令形式. 如: 2 0,6,12,18 * * * perl /root/restarttomcat.pl p ...
- 【剑指Offer面试题】 九度OJ1368:二叉树中和为某一值的路径
题目链接地址: http://ac.jobdu.com/problem.php? pid=1368 题目1368:二叉树中和为某一值的路径 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2252 ...
- AutoCAD如何输入文字
1 运行文字命令(这里使用单行文字),然后鼠标点击文字的起始点,如图所示 2 鼠标分别向上和向右移动一定距离,表示文字的高度(文字的大小)和文字的旋转角度(一般向右,因为是水平文字) 3 最后 ...
- gray-code——找规律
The gray code is a binary numeral system where two successive values differ in only one bit. Given a ...
- -ROOT-表和.META.表结构详解
在<HBase技术简介>中我们知道,HBase中有两个特殊的表:-ROOT-和.META.. 由于HBase中的表可能非常大,故HBase会将表按行分成多个region,然后分配到多台Re ...