POJ 3070 矩阵快速幂
题意:求菲波那切数列的第n项。
分析:矩阵快速幂。

右边的矩阵为a0 ,a1,,,
然后求乘一次,就进一位,求第n项,就是矩阵的n次方后,再乘以b矩阵后的第一行的第一列。
#include <cstdio>
#include <cstring> using namespace std; typedef long long ll; const int maxn = ;
const int maxm = ; struct Matrix {
int n,m;
int a[maxn][maxm]; void clear() {
n = m = ;
memset(a,,sizeof(a));
} Matrix operator + (const Matrix &b) const {
Matrix tmp;
tmp.n = n;
tmp.m = m; for(int i=;i<n;++i)
for(int j=;j<m;++j)
tmp.a[i][j] = a[i][j] + b.a[i][j]; return tmp;
} Matrix operator - (const Matrix &b) const {
Matrix tmp;
tmp.n = n;
tmp.m = m; for(int i=;i<n;++i)
for(int j=;j<m;++j)
tmp.a[i][j] = a[i][j] - b.a[i][j]; return tmp;
} Matrix operator * (const Matrix & b) const {
Matrix tmp;
tmp.clear();
tmp.n = n;
tmp.m = b.m; for(int i=;i<n;++i)
for(int j=;j<b.m;++j)
for(int k=;k<m;++k)
tmp.a[i][j] +=(a[i][k]*b.a[k][j])%; return tmp;
} Matrix operator ^ (const int& k) const {
Matrix tmp,t = *this; int p = k;
tmp.clear(); tmp.m = tmp.n = this->n; for(int i=;i<n;++i)
tmp.a[i][i] = ; while(p) {
if(p&) tmp = tmp*t;
p>>=;
t = t*t;
}
return tmp;
}
}; int main(int argc, char const *argv[])
{
int n;
while(true) {
scanf("%d",&n);
if(n==-) break;
Matrix f;
f.clear();
f.n = f.m = ;
f.a[][] = ;
f.a[][] = ;
f.a[][] = ;
f.a[][] = ; f = f^n;
Matrix x;
x.clear();
x.n = ;
x.m = ;
x.a[][] = ;
x.a[][] = ;
f = f*x; printf("%d\n", f.a[][]); }
return ;
}
POJ 3070 矩阵快速幂的更多相关文章
- POJ 3070 矩阵快速幂解决fib问题
矩阵快速幂:http://www.cnblogs.com/atmacmer/p/5184736.html 题目链接 #include<iostream> #include<cstdi ...
- 解题报告:poj 3070 - 矩阵快速幂简单应用
2017-09-13 19:22:01 writer:pprp 题意很简单,就是通过矩阵快速幂进行运算,得到斐波那契数列靠后的位数 . 这是原理,实现部分就是矩阵的快速幂,也就是二分来做 矩阵快速幂可 ...
- poj 3070 矩阵快速幂模板
题意:求fibonacci数列第n项 #include "iostream" #include "vector" #include "cstring& ...
- poj 3233 矩阵快速幂
地址 http://poj.org/problem?id=3233 大意是n维数组 最多k次方 结果模m的相加和是多少 Given a n × n matrix A and a positive i ...
- poj 3734 矩阵快速幂+YY
题目原意:N个方块排成一列,每个方块可涂成红.蓝.绿.黄.问红方块和绿方块都是偶数的方案的个数. sol:找规律列递推式+矩阵快速幂 设已经染完了i个方块将要染第i+1个方块. a[i]=1-i方块中 ...
- POJ 3233 矩阵快速幂&二分
题意: 给你一个n*n的矩阵 让你求S: 思路: 只知道矩阵快速幂 然后nlogn递推是会TLE的. 所以呢 要把那个n换成log 那这个怎么搞呢 二分! 当k为偶数时: 当k为奇数时: 就按照这么搞 ...
- poj 3744 矩阵快速幂+概率dp
题目大意: 输入n,代表一位童子兵要穿过一条路,路上有些地方放着n个地雷(1<=n<=10).再输入p,代表这位童子兵非常好玩,走路一蹦一跳的.每次他在 i 位置有 p 的概率走一步到 i ...
- Blocks(POJ 3734 矩阵快速幂)
Blocks Input The first line of the input contains an integer T(1≤T≤100), the number of test cases. E ...
- Poj 3233 矩阵快速幂,暑假训练专题中的某一道题目,矩阵快速幂的模板
题目链接 请猛戳~ Description Given a n × n matrix A and a positive integer k, find the sum S = A + A2 + A3 ...
随机推荐
- windows同时安装python2和python3两个版本
1.安装python2 下载地址: https://www.python.org/downloads/windows/ 进入页面,下拉,64位系统要选择这个. 下载完成后,一直点击下一步,直到安装完毕 ...
- 学习javscript函数笔记(二)
定义: 函数包含一组语句,他们是JavaScript的基础模块单元,用于代码复用.信息隐藏和组合调用.函数用于指定对象的行为. 1.函数对象 JavaScript中的函数就是对象,函数对象连接到Fun ...
- easyUI--datagrid 实现按键控制( enter tab 方向键 )
1.表格定义时加上 onClickCell: onClickCell,2.定义列时加入编辑器3.引入 key.js 即可使用 enter 键 或者向下箭头 选中单元格下移 选中单元格上移 tab键 选 ...
- zookeeper JAVA API 简单操作
package org.admln.program.Zoo_Test; import java.io.IOException; import java.security.NoSuchAlgorithm ...
- 使用pygame开发一个弹幕射击游戏(一)
本文作为开发过程记录用. 目前游戏画面: 下一个添加的功能:敌机可以进行射击. 弹幕类 from pygame.sprite import Sprite from pygame import tran ...
- jQuery 文本插入和标签移动方法
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- ubuntu系统操作
给ubuntu配置解析主机名 vim /etc/hosts 192.168.23.44 Evelyn
- Hashtable元素的删除
2中方法 Remove(); Clear(); static void Main(string[] args) { Hashtable ht = new Hashtable(); ht.Add(1,& ...
- Java虚拟机之栈帧
写在前面的话:Java虚拟机是一门学问,是众多Java大神们的杰作,由于我个人水平有限,精力有限,不能保证所有的东西都是正确的,这里内容都是经过深思熟虑的,部分引用原著的内容,讲的已经很好了,不在累述 ...
- webpack起步
为什么要使用webpack 很牛逼的样子 https://www.webpackjs.com/comparison/ 基本概念 1. 入口(entry) module.exports = { entr ...