HDU 5015 233 Matrix
题意:给定一个矩阵的第0列的第1到n个数,第一行第1个数开始每个数分别为233, 2333........,求第n行的第m个数。
分析:
其实也没那么难,自己想了半天还没往对的方向想,m最大1e9,应该立即想到要用到快速幂,关键在于递推矩阵。
递推矩阵的作用是依次算出每一列,第1列第一个数233是前一列的23*10+3,将前一列增加一个元素[3, 23, a1, a2,....an],然后第一列第一个数为3,对应向量[1, 0, 0, 0.....0],233对应向量[1, 10, 0, .....0],下一个的数对应[1, 10, 1.....0], 接下来每个数对应的向量是上一个数的向量最后一个1元素后面增加1个1,这样将n+2个向量构成一个(n+2)*(n+2)的矩阵,需要求m次该矩阵,然后和[3, 23, a1, a2, .....an]相乘。
代码:
- #include <cstdio>
- #include <iostream>
- #include <vector>
- #include <algorithm>
- #define inf 0x0f0f0f0f
- #define pb push_back
- #define bug(x) printf("line %d: >>>>>>>>>>>>>>>\n", (x));
- #define in freopen("F:\\code\\data\\data.txt", "r", stdin);
- #define out freopen("F:\\code\\data\\data_out.txt", "w", stdout);
- #define SZ(x) ((int)x.size())
- #define lson rt<<1, l, m
- #define rson rt<<1|1, m+1, r
- using namespace std;
- typedef long long LL;
- const int maxn = ;
- const int M = ;
- struct Matrix
- {
- int n, m;
- LL a[maxn][maxn];
- Matrix(int n, int m)
- {
- this->n = n;
- this->m = m;
- for(int i = ; i < maxn; i++)
- for(int j = ; j < maxn; j++)
- a[i][j] = ;
- }
- Matrix operator * (const Matrix &o)const
- {
- Matrix c(n, o.m);
- for(int i = ; i < n; i++)
- for(int j = ; j < o.m; j++)
- {
- for(int k = ; k < m; k++)
- c.a[i][j] = (c.a[i][j]+a[i][k]*o.a[k][j]%M)%M;
- }
- return c;
- }
- };
- int n, m;
- int main()
- {
- while(scanf("%d%d", &n, &m) == )
- {
- Matrix f(n+, n+), res(n+, n+), tmp(n+, );
- tmp.a[][] = ;
- tmp.a[][] = ;
- for(int i = ; i <= n+; i++)
- scanf("%I64d", &tmp.a[i][]);
- for(int i = ; i <= n+; i++)
- for(int j = ; j <= n+; j++)
- {
- if(i == )
- {
- f.a[i][] = ;
- break;
- }
- else if(i == )
- {
- f.a[i][] = ;
- f.a[i][] = ;
- break;
- }
- else
- {
- if(j < i)
- f.a[i][j] = f.a[i-][j];
- else if(j == i) f.a[i][j] = ;
- }
- }
- for(int i = ; i < n+; i++)
- for(int j = ; j < n+; j++)
- if(i == j)
- res.a[i][j] = ;
- while(m)
- {
- if(m&)
- res = res*f;
- f = f*f;
- m >>= ;
- }
- tmp = res*tmp;
- printf("%I64d\n", tmp.a[n+][]);
- }
- return ;
- }
HDU 5015 233 Matrix的更多相关文章
- HDU - 5015 233 Matrix(杨辉三角/前缀+矩阵快速幂)
233 Matrix In our daily life we often use 233 to express our feelings. Actually, we may say 2333, 23 ...
- HDU 5015 233 Matrix(网络赛1009) 矩阵快速幂
先贴四份矩阵快速幂的模板:http://www.cnblogs.com/shangyu/p/3620803.html http://www.cppblog.com/acronix/archive/20 ...
- hdu 5015 233 Matrix (矩阵高速幂)
233 Matrix Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Tota ...
- HDU - 5015 233 Matrix (矩阵快速幂)
In our daily life we often use 233 to express our feelings. Actually, we may say 2333, 23333, or 233 ...
- hdu 5015 233 Matrix(构造矩阵)
http://acm.hdu.edu.cn/showproblem.php?pid=5015 由于是个二维的递推式,当时没有想到能够这样构造矩阵.从列上看,当前这一列都是由前一列递推得到.依据这一点来 ...
- HDU 5015 233 Matrix --矩阵快速幂
题意:给出矩阵的第0行(233,2333,23333,...)和第0列a1,a2,...an(n<=10,m<=10^9),给出式子: A[i][j] = A[i-1][j] + A[i] ...
- hdu 5015 233矩阵快速幂
http://acm.hdu.edu.cn/showproblem.php?pid=5015 需要构造一个 n+2 维的矩阵. 就是要增加一维去维护2333这样的序列. 可以发现 2333 = 233 ...
- HDU [P5015] 233 Matrix
矩阵快速幂 按列递推 #include <iostream> #include <cstdio> #include <cstdlib> #include <a ...
- Spring-1-I 233 Matrix(HDU 5015)解题报告及测试数据
233 Matrix Time Limit:5000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Descript ...
随机推荐
- Java编写的文本编辑器(菜鸟作品)
//这是主窗体文件 Wordwin.java import javax.swing.*; import javax.swing.event.DocumentEvent; import javax.sw ...
- Android寒假实训云笔记总结——欢迎页
欢迎页使用的是viewpager,需要适配器. 注意点: 1.判断是否是第一次进入这个app. 2.欢迎页小圆点的逻辑. 实现原理: 首先在activity_welcome放入viewpager和固定 ...
- .bak文件在英文版的sqlserver2014如何生成和恢复
生成bak备份文件 1.选择数据库 2.右击选择task 3.选择backup 4.
- Appium Android 屏幕滑动
- RabbitMQ远程访问配置
1 首先创建一个新的账户 并给上Administrator标签 2然后给这个新账户添加虚拟主机访问权限 3在windows 下的 rabbitmq安装文件下的etc文件下的配置文件添加以下 [ ...
- JS中undefined和null的区别
在写JS脚本的时候,经常会碰到“为空”的判断,其中主要有null和undefined的判断.这两个为空判断的主要区别是: 1) null是JS的关键字,是语法特性.undefined是全局对象的属性, ...
- PYTHON代码摘录
文件处理 #典型的读取文件代码 row_data = {} with open('PaceData.csv') as paces: column_heading = paces.readline(). ...
- j2ee中如何拦截jsp页面?
加filter: public class RightFilter implements Filter { public void init(FilterConfig filterConfig) th ...
- python学习笔记——列表生成式与生成器
1.列表生成式(List Comprehensions) python中,列表生成式是用来创建列表的,相较于用循环实现更为简洁.举个例子,生成[1*1, 2*2, ... , 10*10],循环用三行 ...
- [Python][flask][flask-wtf]关于flask-wtf中API使用实例教程
简介:简单的集成flask,WTForms,包括跨站请求伪造(CSRF),文件上传和验证码. 一.安装(Install) 此文仍然是Windows操作系统下的教程,但是和linux操作系统下的运行环境 ...