2017ACM/ICPC广西邀请赛-重现赛 1004.Covering
Problem Description
Bob's school has a big playground, boys and girls always play games here after school.
To protect boys and girls from getting hurt when playing happily on the playground, rich boy Bob decided to cover the playground using his carpets.
Meanwhile, Bob is a mean boy, so he acquired that his carpets can not overlap one cell twice or more.
He has infinite carpets with sizes of 1×2 and 2×1, and the size of the playground is 4×n.
Can you tell Bob the total number of schemes where the carpets can cover the playground completely without overlapping?
Input
There are no more than 5000 test cases.
Each test case only contains one positive integer n in a line.
1≤n≤1018
Output
For each test cases, output the answer mod 1000000007 in a line.
Sample Input
1
2
Sample Output
1
5
题目大意:用1×2和2×1的矩形填满N×4的方格,求方案数
解题报告:打表发现规律:\(f_n=f_{n-1}+5*f_{n-2}+f_{n-3}-f_{n-4}\)
然后矩阵快速幂求解即可:
#include <algorithm>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#define RG register
#define il inline
#define iter iterator
#define Max(a,b) ((a)>(b)?(a):(b))
#define Min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long long ll;
const int N=5,mod=1000000007;
struct mat{
	ll a[N][N];
	mat(){memset(a,0,sizeof(a));}
  mat operator *(const mat p)const{
		mat tmp;
		for(int i=1;i<N;i++)
			for(int j=1;j<N;j++)
				for(int k=1;k<N;k++){
					tmp.a[i][j]+=(a[i][k]*p.a[k][j])%mod;
					tmp.a[i][j]=((tmp.a[i][j]%mod)+mod)%mod;
				}
		return tmp;
	}
};
ll n;int f[5];
void work()
{
	if(n<=4){
		printf("%d\n",f[n]);
		return ;
	}
	mat S,T;
	for(int i=1;i<=4;i++)S.a[1][i]=f[5-i];
	T.a[1][1]=1;T.a[2][1]=5;T.a[3][1]=1;T.a[4][1]=-1;
	for(int i=2;i<=4;i++)T.a[i-1][i]=1;
	n-=4;
	while(n){
		if(n&1)S=S*T;
		T=T*T;n>>=1;
	}
	printf("%lld\n",S.a[1][1]);
}
int main()
{
	f[1]=1;f[2]=5;f[3]=11;f[4]=36;
	while(~scanf("%lld",&n))work();
	return 0;
}
2017ACM/ICPC广西邀请赛-重现赛 1004.Covering的更多相关文章
- 2017ACM/ICPC广西邀请赛-重现赛(感谢广西大学)
		上一场CF打到心态爆炸,这几天也没啥想干的 A Math Problem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ... 
- 2017ACM/ICPC广西邀请赛-重现赛 1007.Duizi and Shunzi
		Problem Description Nike likes playing cards and makes a problem of it. Now give you n integers, ai( ... 
- 2017ACM/ICPC广西邀请赛-重现赛 1010.Query on A Tree
		Problem Description Monkey A lives on a tree, he always plays on this tree. One day, monkey A learne ... 
- 2017ACM/ICPC广西邀请赛-重现赛
		HDU 6188 Duizi and Shunzi 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6188 思路: 签到题,以前写的. 实现代码: #inc ... 
- 2017ACM/ICPC广西邀请赛-重现赛 1001 A Math Problem
		2017-08-31 16:48:00 writer:pprp 这个题比较容易,我用的是快速幂 写了一次就过了 题目如下: A Math Problem Time Limit: 2000/1000 M ... 
- 2017ACM/ICPC广西邀请赛-重现赛1005 CS course
		2017-08-31 16:19:30 writer:pprp 这道题快要卡死我了,队友已经告诉我思路了,但是做题速度很缓慢,很费力,想必是因为之前 的训练都是面向题解编程的缘故吧,以后不能这样了,另 ... 
- 2017ACM/ICPC广西邀请赛  1004 Covering
		Covering Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ... 
- HDU 6191 2017ACM/ICPC广西邀请赛 J Query on A Tree 可持久化01字典树+dfs序
		题意 给一颗\(n\)个节点的带点权的树,以\(1\)为根节点,\(q\)次询问,每次询问给出2个数\(u\),\(x\),求\(u\)的子树中的点上的值与\(x\)异或的值最大为多少 分析 先dfs ... 
- 2017ACM/ICPC广西邀请赛
		A.A Math Problem #include <bits/stdc++.h> using namespace std; typedef long long ll; inline ll ... 
随机推荐
- slf4j 与 log4j2 实战讲解与日志分割
			这两天搭建项目的时候用到log4j2在这里把自己的问题与了解拿出来与大家分享一下. 1.为什我要用 因为,使用slf4j可以很好的保证我们的日志系统具有良好的兼容性,兼容当前常见几种日志系统,而使用l ... 
- 初学深度学习(TensorFlow框架的心得and经验总结)自用环境的总结
			初学者的时间大部分浪费在了环境上了: 建议直接上Linux系统,我推荐国产的深度系统,deepin这几年一直在不断的发展,现在15.4已经很不错了 1,图形化界面很漂亮,内置正版crossover,并 ... 
- 写一个vue组件
			写一个vue组件 我下面写的是以.vue结尾的单文件组件的写法,是基于webpack构建的项目.如果还不知道怎么用webpack构建一个vue的工程的,可以移步到vue-cli. 一个完整的vue组件 ... 
- 零基础大数据入门教程:Java调用阿里云短信通道服务
			这里我们使用SpringBoot 来调用阿里通信的服务. 阿里通信,双11.收到短信,日发送达6亿条.保障力度非常高. 使用的步骤: 1.1. 第一步:需要开通账户 1.2. 第二步:阅读接口文档 1 ... 
- 阿里云API网关(5)用户指南(调用 API)
			网关指南: https://help.aliyun.com/document_detail/29487.html?spm=5176.doc48835.6.550.23Oqbl 网关控制台: https ... 
- Ionic 2 开发(一)_安装与目录结构
			由于公司开始使用后ionic 进行前段开发,现在需要学习下ionic,虽然是后台开发,但是还是有必要了解下的 安装Node.js 官网:http://nodejs.cn/ 自行下载安装 安装Ionic ... 
- Python3 面向对象编程之程序设计思想发展
			概述 1940年以前:面向机器 1940年以前:面向机器 最早的程序设计都是采用机器语言来编写的,直接使用二进制码来表示机器能够识别和执行的指令和数 据.简单来说,就是直接编写 和 的序列来代表程序语 ... 
- c#代码输入图片
			Image bgimage = Image.FromFile(flieUrl + bgImg); if (bgimage != null) { Bitmap bmp1 = new Bitmap(bgi ... 
- java---interrupt、interrupted和isInterrupted的区别
			1.interrupt() interrupt方法用于中断线程.调用该方法的线程的状态为将被置为"中断"状态. 注意:线程中断仅仅是置线程的中断状态位,不会停止线程.需要用户自己 ... 
- java基本数据类型的包装类
			基本类型对应的包装类 byte(Byte).short(Short).int(Integer).long(Long).float(Float).double(Double).char(Characte ... 
