题意:求S=(A+A^2+A^3+...+A^k)%m的和

方法一:二分求解
S=A+A^2+...+A^k
若k为奇数:
S=(A+A^2+...+A^(k/2))+A^(k/2)*(A+A^2+...+A^(k/2))+A^k
若k为偶数:
S=(A+A^2+...+A^(k/2))+A^(k/2)*(A+A^2+...+A^(k/2))

也可以这么二分(其实和前面的差不多):
S(2n)=A+A^2+...+A^2n=(1+A^n)*(A+A^2+...+A^n)=(1+A^n)*S(n)
S(2n+1)=A+A^2+...+A^(2n+1)=A(1+A+..+A^2n)=A+(A+A^(n+1))*S(n)

一开始1900+ms,优化了下1500ms...还是太慢了。。。
本来在递归的时候,用快速幂计算A^(k/2)
后来改用直接递归的同时,计算A^(k/2),直接变成200ms左右。。。瞬间提升了10倍。。。

#include <iostream>
#include <cstdio>
#include <string.h> using namespace std;
const int maxn=;
int mod;
int n,k,m;
struct Matrix{
int m[maxn][maxn];
void init(){
memset(m,,sizeof(m));
}
void initE(){
memset(m,,sizeof(m));
for(int i=;i<n;i++)
m[i][i]=;
}
}A;
//重载+运算符
Matrix operator+(Matrix a,Matrix b){
Matrix c;
for(int i=;i<n;i++){
for(int j=;j<n;j++)
c.m[i][j]=(a.m[i][j]+b.m[i][j])%mod;
}
return c;
}
//重载*运算符
Matrix operator*(Matrix a,Matrix b){
Matrix c;
for(int i=;i<n;i++){
for(int j=;j<n;j++){
c.m[i][j]=;
for(int k=;k<n;k++){
c.m[i][j]=(c.m[i][j]+a.m[i][k]*b.m[k][j]%mod)%mod;
}
}
}
return c;
}
//矩阵快速幂
Matrix MquickPow(Matrix A,int b){
Matrix ret;
ret.initE();
while(b){
if(b&)
ret=ret*A;
A=A*A;
b=b>>;
}
return ret;
}
Matrix p;
Matrix dfs(Matrix A,int k){
if(k==){
p=A;
return A;
}
Matrix ret,ans;
ret=dfs(A,k/);
//Matrix p=MquickPow(A,k/2);如果用快速幂计算p=A^(k/2),则要1500ms,而直接在递归的时候同时计算p,则只要188ms。
if(k&){
//return ret+ret*p+p*p*A;
ans=ret+ret*p+p*p*A;
p=p*p*A;
}
else{
//return ret+ret*p;
ans=ret+ret*p;
p=p*p;
}
return ans;
}
int main()
{
scanf("%d%d%d",&n,&k,&m);
mod=m;
for(int i=;i<n;i++){
for(int j=;j<n;j++){
scanf("%d",&A.m[i][j]);
}
}
Matrix ans;
ans=dfs(A,k);
for(int i=;i<n;i++){
for(int j=;j<n;j++){
printf("%d ",ans.m[i][j]);
}
printf("\n");
}
return ;
}

方法二:

688ms

http://blog.sina.com.cn/s/blog_9d5278a301015mbd.html
http://blog.csdn.net/wangjian8006/article/details/7868864
S=A(E+A(E+A(E+...A(E+A))))
这样就可以想,不妨构造一个矩阵T使得T*T,这样乘下去每次可以得到A*(A+E)+E

  A  0          A^2  0         A^3         0
B=       B^2=        B^3=
  E  E        A+E  E           A^2+A+E   E

不难得出:  A^(k+1)   0
B^(k+1)=
       S(k)       E

#include <iostream>
#include <iostream>
#include <cstdio>
#include <string.h> using namespace std;
const int maxn=;
int mod;
int n,k,m;
struct Matrix{
int m[maxn][maxn];
void init(){
memset(m,,sizeof(m));
}
void initE(){
memset(m,,sizeof(m));
for(int i=;i<n;i++)
m[i][i]=;
}
}A;
//重载+运算符
Matrix operator+(Matrix a,Matrix b){
Matrix c;
for(int i=;i<n;i++){
for(int j=;j<n;j++)
c.m[i][j]=(a.m[i][j]+b.m[i][j])%mod;
}
return c;
}
//重载*运算符
Matrix operator*(Matrix a,Matrix b){
Matrix c;
for(int i=;i<n;i++){
for(int j=;j<n;j++){
c.m[i][j]=;
for(int k=;k<n;k++){
c.m[i][j]=(c.m[i][j]+a.m[i][k]*b.m[k][j]%mod)%mod;
}
}
}
return c;
}
//矩阵快速幂
Matrix MquickPow(Matrix A,int b){
Matrix ret;
ret.initE();
while(b){
if(b&)
ret=ret*A;
A=A*A;
b=b>>;
}
return ret;
}
int main()
{
Matrix B;
B.init();
scanf("%d%d%d",&n,&k,&m);
mod=m;
for(int i=;i<n;i++){
for(int j=;j<n;j++){
scanf("%d",&B.m[i][j]);
}
B.m[i+n][i]=;
B.m[i+n][i+n]=;
}
n=n*;
Matrix ans=MquickPow(B,k+);
for(int i=n/;i<n;i++){
for(int j=;j<n/;j++){
if(i==j+n/)
ans.m[i][j]=(ans.m[i][j]-+mod)%mod; //对角线还要减去单位矩阵的1
printf("%d ",ans.m[i][j]);
}
printf("\n");
}
return ;
}

POJ 3233 Matrix Power Series (矩阵快速幂+二分求解)的更多相关文章

  1. POJ 3233 Matrix Power Series 矩阵快速幂+二分求和

    矩阵快速幂,请参照模板 http://www.cnblogs.com/pach/p/5978475.html 直接sum=A+A2+A3...+Ak这样累加肯定会超时,但是 sum=A+A2+...+ ...

  2. POJ 3233 Matrix Power Series 矩阵快速幂

    设S[k] = A + A^2 +````+A^k. 设矩阵T = A[1] 0 E E 这里的E为n*n单位方阵,0为n*n方阵 令A[k] = A ^ k 矩阵B[k] = A[k+1] S[k] ...

  3. POJ3233:Matrix Power Series(矩阵快速幂+二分)

    http://poj.org/problem?id=3233 题目大意:给定矩阵A,求A + A^2 + A^3 + … + A^k的结果(两个矩阵相加就是对应位置分别相加).输出的数据mod m.k ...

  4. poj 3233 Matrix Power Series 矩阵求和

    http://poj.org/problem?id=3233 题解 矩阵快速幂+二分等比数列求和 AC代码 #include <stdio.h> #include <math.h&g ...

  5. POJ 3233:Matrix Power Series 矩阵快速幂 乘积

    Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 18450   Accepted:  ...

  6. poj 3233 Matrix Power Series(矩阵二分,高速幂)

    Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 15739   Accepted:  ...

  7. POJ3233 Matrix Power Series 矩阵快速幂 矩阵中的矩阵

    Matrix Power Series Time Limit: 3000MS   Memory Limit: 131072K Total Submissions: 27277   Accepted:  ...

  8. Poj 3233 Matrix Power Series(矩阵乘法)

    Matrix Power Series Time Limit: 3000MS Memory Limit: 131072K Description Given a n × n matrix A and ...

  9. POJ 3233 Matrix Power Series(矩阵高速功率+二分法)

    职务地址:POJ 3233 题目大意:给定矩阵A,求A + A^2 + A^3 + - + A^k的结果(两个矩阵相加就是相应位置分别相加).输出的数据mod m. k<=10^9.     这 ...

  10. POJ3233:Matrix Power Series(矩阵快速幂+递推式)

    传送门 题意 给出n,m,k,求 \[\sum_{i=1}^kA^i\] A是矩阵 分析 我们首先会想到等比公式,然后得到这样一个式子: \[\frac{A^{k+1}-E}{A-E}\] 发现要用矩 ...

随机推荐

  1. 【Inno Setup】 Inno Setup 64位安装程序默认安装路径

    在脚本中加入: ArchitecturesInstallIn64BitMode=x64 ArchitecturesAllowed=x64

  2. Github上LeakCanary编译报错CreateProcess error=2的解决方法

    现象说明: 从github上拉下LeakCanary编译时报错 CreateProcess error=2, ϵͳÕҲ»µ½ָ¶ 原因分析: 该现象是由于Windows中Gradle调用命令未加cmd ...

  3. Redbean:入门(一) - 增删改查

    <?php require_once 'rb.php'; $tableName = "link"; //链接数据库 R::setup("mysql:host=loc ...

  4. Android-----第三方 ImageLoader 的简单配置和使用

    ImageLoader 的简单使用配置,最好是将配置信息放到application里面,这样我们就不需要每次使用都需要配置了 1.首先我们得有一个包 2.简单的配置信息 //显示图片的配置 Displ ...

  5. hud 2586 How far away ?

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2586 How far away ? Description There are n houses in ...

  6. hdu 1880 魔咒词典

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1880 魔咒词典 Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有10 ...

  7. 在JAVA中使用JSONObject生成json

    JSON是一种轻量级的数据交换格式,在现在的web开发中,是非常常见的.在没有方便的工具之前,我们或许会使用拼字符串的形式来生成json数组,今天我们使用一个json-lib.jar包来为我们实现生成 ...

  8. asp.net实现手机号码归属地查询

    protected void Button1_Click(object sender, EventArgs e)        {            if (Regex.IsMatch(TextB ...

  9. VS2012 常用web.config配置解析之自定义配置节点

    在web.config文件中拥有一个用户自定义配置节点configSections,这个节点可以方便用户在web.config中随意的添加配置节点,让程序更加灵活(主要用于第三方插件的配置使用) 自定 ...

  10. 主要从架构上来做优化,负载均衡、CDN、静态化、数据库的水平切割和纵向切割、读写分离、分布式缓存着手

    语言知识一种工具,甚至技术本身也只是一种工具,本身并不值钱,关键在于用于何种行业,产生了什么价值. 但从语言来看,我个人更喜欢php,然后是C#,然后是java从框架而言,先是java,然后C#,再次 ...