题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6050

题意:题目很短自己看吧,

    就是这个递推式子,说的很清楚了,让你求F(m,1)。题解里面分什么奇偶性分别去算,有些人找规律找出来了,题解是非常严谨的用数学推出来了(反正没有看懂),虽然也用到了矩阵快速幂。

思路:拿到这个题,我第一反应也是矩阵快速幂,然后手推了第二行,我发现第二行依旧满足上面F(2,i)=F(2,i-1)+2*F(2,i-2)这个性质。所以我就萌生一个想法,我先把一行算出来,然后把他转换成下一行。问题是如何在行与行之间转换,我们发现每一行的第一个等于上一个行1到n每一项之和,每一行的第二个,需要2到n+1每一项之和。那么我直接算出前n+1项的和Sn+1,Sn+1-Fn+1=N1,Sn+1-F1=N2。如此我们就得到了下一行的前两个。然后我们有可以同理求出再下一行。这个矩阵比较难构造,具体的矩阵是4*4的,为了说明方便,我在代码直接每一项赋值,可以把他们抄出来看看是否是这么一个回事,构造矩阵可能是一个难点,我做了挺多矩阵快速幂的题,有一些小经验,以后可能会写出来分享一下。

代码:

 //Author: xiaowuga
#include <iostream>
#include <algorithm>
#include <set>
#include <vector>
#include <queue>
#include <cmath>
#include <cstring>
#include <cstdio>
#include <ctime>
#include <map>
#include <bitset>
#include <cctype>
#define maxx INT_MAX
#define minn INT_MIN
#define inf 0x3f3f3f3f
#define mem(s,ch) memset(s,ch,sizeof(s))
#define da cout<<da<<endl
#define uoutput(a,i,l,r) for(int i=l;i<r;i++) if(i==l) cout<<a[i];else cout<<" "<<a[i];cout<<endl;
#define doutput(a,i,l,r) for(int i=r-1;i>=0;i--) if(i==r-1) cout<<a[i];else cout<<" "<<a[i];cout<<endl;
const long long N=;
const long long mod=1e9+;
using namespace std;
typedef long long LL;
struct Matrix{
LL mat[N][N] = {{}};
void clear(){
memset(mat,,sizeof(mat));
}
Matrix operator * (const Matrix & m) const{
Matrix tmp;
for(int i=;i<N;i++)
for(int k=;k<N;k++){
if (mat[i][k]) {
for(int j=;j<N;j++){
tmp.mat[i][j]+=mat[i][k]*m.mat[k][j]%mod;
tmp.mat[i][j]%=mod;
}
}
}
return tmp;
}
};
Matrix POW(Matrix m,LL k){
Matrix ans;
ans.clear();
for(int i=;i<N;i++) ans.mat[i][i]=;
while(k){
if(k&) ans=ans*m;
k/=;
m=m*m;
}
return ans;
}
Matrix xx,yy;
void init(){
xx.mat[][]=; xx.mat[][]=; xx.mat[][]=; xx.mat[][]=;
xx.mat[][]=; xx.mat[][]=; xx.mat[][]=; xx.mat[][]=;
xx.mat[][]=; xx.mat[][]=; xx.mat[][]=; xx.mat[][]=;
xx.mat[][]=; xx.mat[][]=; xx.mat[][]=; xx.mat[][]=; yy.mat[][]=; yy.mat[][]=; yy.mat[][]=; yy.mat[][]=mod-;
yy.mat[][]=mod-; yy.mat[][]=; yy.mat[][]=; yy.mat[][]=;
yy.mat[][]=mod-; yy.mat[][]=; yy.mat[][]=; yy.mat[][]=mod-;
yy.mat[][]=mod-; yy.mat[][]=; yy.mat[][]=; yy.mat[][]=;
}
LL n,mm;
int main() {
init();
int T;
scanf("%lld",&T);
while(T--){
scanf("%lld%lld",&n,&mm);
if(n==||mm==) {cout<<<<"\n";continue;}
Matrix ans1=POW(xx,n-);
Matrix ans2=ans1*yy;
Matrix ans3=POW(ans2,mm);
LL f[]={,,,};
LL a[]={};
for(int i=;i<;i++){
for(int j=;j<;j++){
a[i]+=ans3.mat[i][j]*f[j]%mod;
a[i]%=mod;
}
}
cout<<a[]<<"\n";
}
return ;
}

2017 Multi-University Training Contest - Team 2——HDU6050 Funny Function的更多相关文章

  1. 2017 Multi-University Training Contest - Team 9 1005&&HDU 6165 FFF at Valentine【强联通缩点+拓扑排序】

    FFF at Valentine Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  2. 2017 Multi-University Training Contest - Team 9 1004&&HDU 6164 Dying Light【数学+模拟】

    Dying Light Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Tot ...

  3. 2017 Multi-University Training Contest - Team 9 1003&&HDU 6163 CSGO【计算几何】

    CSGO Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  4. 2017 Multi-University Training Contest - Team 9 1002&&HDU 6162 Ch’s gift【树链部分+线段树】

    Ch’s gift Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total S ...

  5. 2017 Multi-University Training Contest - Team 9 1001&&HDU 6161 Big binary tree【树形dp+hash】

    Big binary tree Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  6. 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】

    Colorful Tree Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  7. 2017 Multi-University Training Contest - Team 1 1006&&HDU 6038 Function【DFS+数论】

    Function Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total ...

  8. 2017 Multi-University Training Contest - Team 1 1002&&HDU 6034 Balala Power!【字符串,贪心+排序】

    Balala Power! Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  9. 2017 Multi-University Training Contest - Team 1 1011&&HDU 6043 KazaQ's Socks【规律题,数学,水】

    KazaQ's Socks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

随机推荐

  1. android.animation(4) - ObjectAnimator的ofInt(), ofFloat()(转)

    一.概述 1.引入 上几篇给大家讲了ValueAnimator,但ValueAnimator有个缺点,就是只能对数值对动画计算.我们要想对哪个控件操作,需要监听动画过程,在监听中对控件操作.这样使用起 ...

  2. Node.js用fs.renameSync报cross-device link not permitted错

    转自: http://blog.csdn.net/starrexstar/article/details/8048722 今天把 Manuel Kiessling 的[The Node Beginne ...

  3. iOS开发-iOS 10 由于权限问题导致崩溃的那些坑

     iOS开发-iOS 10 由于权限问题导致崩溃的那些坑 6月份的WWDC大会结束有一段时间了,相信很多开发者也是在努力工作的闲时用着Xcode8 Beta版学习着新的特性吧. 使用Xcode8写自己 ...

  4. vue-tree

    vue-tree vue 编写的树形菜单,小巧实用,支持vue1.0,vue2.0 v1.0 功能: 1.支持多级树目录 2.支持高亮点击的节点 3.支持展开点击节点 4.支持点击收缩节点时收缩所有子 ...

  5. 华农校赛--G,用set比较大小,缩短时间复杂度

    Array C Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 581  Solved: 101[Submit][Status][Web Board] D ...

  6. poj2559单调栈

    题意:给出连续的矩形的高....求最大面积 #include<iostream> #include<stack> #include<stdio.h> using n ...

  7. eclipse导入svn中的web工程,部署到tomcat时候,只有WEB-INF目录问题

     eclipse版本不同,上传工程svn中的settings文件,容易导致别的版本的eclipse,tomcat启动失败 

  8. Unix系统编程()文件描述符和打开文件之间的关系

    目前学习到的是一个文件描述符对应着一个打开的文件,似乎是对应的关系.但是实际上并不是这样的.多个文件描述符指向同一个打开的文件,是可能的也是必要的.这些文件描述符可以在相同或者不同的进程中打开. 要理 ...

  9. linux 链接的使用 创建和删除符号连接(软、硬链接)

    1 . 使用方式 :ln [option] source_file dist_file   (source_file是待建立链接文件的文件,dist_file是新创建的链接文件)            ...

  10. c libghttp ghttp 库使用指南

    libghttp是一个很好用的 http 库,能够轻松地实现同步和异步的HTTP请求 目录 [隐藏]  1 安装 2 GET示例 3 POST示例 4 相关函数 5 艺搜参考 安装 库文件下载: 在6 ...