“玲珑杯”ACM比赛 Round #12 (D) 【矩阵快速幂的时间优化】
//首先,感谢Q巨
定义状态向量b[6]
b[0]:三面临红色的蓝色三角形个数
b[1]:两面临红色且一面临空的蓝色三角形个数
b[2]:一面临红色且两面临空的蓝色三角形个数
b[3]:三面临红色的黄色三角形个数
b[4]:两面临红色且一面临绿+的黄色三角形个数
b[5]:一面临红色且两面临绿+的黄色三角形个数
转移矩阵:
[3 1 0 0 0 0;
0 2 2 0 0 0;
0 1 3 0 0 0;
3 2 1 0 0 0;
0 0 0 6 3 0;
0 0 0 0 2 4]
最朴素的TLE代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
;
;
LL b[N]= {,,,,,}; //此处初始化列向量
LL hh[N][N]={{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,}
};
struct Mat
{
LL mat[N][N];
} A;
Mat Mut(Mat a,Mat b)
{
Mat c;
memset(c.mat,,sizeof(c.mat));
; k<N; k++)
; i<N; i++)
if(a.mat[i][k])
; j<N; j++)
{
c.mat[i][j]+=a.mat[i][k]*b.mat[k][j]%mod;
c.mat[i][j]=c.mat[i][j]%mod;
}
return c;
}
Mat Qpow(Mat a,LL n)
{
Mat c;
; i<N; ++i)
; j<N; ++j)
c.mat[i][j]=(i==j);
)
{
) c=Mut(c,a);
a=Mut(a,a);
}
return c;
}
void cal(Mat A,LL n,LL b[],LL& Fn,LL& Gn)
{
Mat A_=Qpow(A,n-);
Fn=Gn=;
LL c[N]={};
;i<N;i++)
;j<N;j++)
c[i]=(c[i]+A_.mat[i][j]*b[j])%mod;
Fn=(c[]+c[]+c[])%mod;
Gn=(c[]+c[]+c[])%mod;
}
void init_A()
{
;i<N;i++)
;j<N;j++)
A.mat[i][j]=hh[i][j];
}
int main()
{
LL n,Fn,Gn;
init_A();
while(cin>>n)
{
)
{
puts("1 0");
continue;
}
n--;
cal(A,n,b,Fn,Gn);
cout<<Fn<<' '<<Gn<<endl;
}
}
貌似(只是貌似)被优化但仍然TLE的代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
;
;
LL b[N]= {,,,,,}; //此处初始化列向量
LL hh[N][N]={{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,}
};
struct Mat
{
LL mat[N][N];
} A,F[];
void printM(Mat x)
{
puts("=================================================================");
;i<N;i++)
{
;j<N;j++)
printf("%10lld",x.mat[i][j]);
puts("");
}
}
Mat Mut(Mat a,Mat b)
{
Mat c;
memset(c.mat,,sizeof(c.mat));
; k<N; k++)
; i<N; i++)
if(a.mat[i][k])
; j<N; j++)
{
c.mat[i][j]+=a.mat[i][k]*b.mat[k][j]%mod;
c.mat[i][j]=c.mat[i][j]%mod;
}
return c;
}
Mat Qpow(Mat a,LL n)
{
Mat c;
; i<N; ++i)
; j<N; ++j)
c.mat[i][j]=(i==j);
)
{
) c=Mut(c,a);
a=Mut(a,a);
}
return c;
}
void cal(Mat A,LL n,LL b[],LL& Fn,LL& Gn)
{
Mat A_;
; i<N; ++i)
; j<N; ++j)
A_.mat[i][j]=(i==j);
;i<&&n;i++,n>>=)
) A_=Mut(A_,F[i]);
//printM(A_);
Fn=Gn=;
LL c[N]={};
;i<N;i++)
;j<N;j++)
c[i]=(c[i]+A_.mat[i][j]*b[j])%mod;
Fn=(c[]+c[]+c[])%mod;
Gn=(c[]+c[]+c[])%mod;
}
void init_A()
{
;i<N;i++)
;j<N;j++)
A.mat[i][j]=hh[i][j];
F[]=A;
;i<;i++)
F[i]=Mut(F[i-],F[i-]);
}
int main()
{
LL n,Fn,Gn;
init_A();
int T;
// cin>>T;
scanf("%lld",&T);
while(T--)
{
// cin>>n;
scanf("%lld",&n);
)
{
puts("1 0");
continue;
}
n-=;
cal(A,n,b,Fn,Gn); // cout<<Fn<<' '<<Gn<<endl;
printf("%lld %lld\n",Fn,Gn);
}
}
矩阵相乘一次的复杂度是O(N^3)的,不过预处理2^i(i:0~60)的矩阵后,可以用向量记录中间结果,而矩阵*向量的复杂度为O(N^2)
最终复杂度: O(T * lb(n) * N^2)->O(1e5 * 60 * 36)->O(2e8)
最终可以AC的代码
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
;
;
LL b[N]= {,,,,,}; //此处初始化列向量
LL hh[N][N]={{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,},
{,,,,,}
};
struct Mat
{
LL mat[N][N];
} A,F[];
void printM(Mat x)
{
puts("=================================================================");
;i<N;i++)
{
;j<N;j++)
printf("%10lld",x.mat[i][j]);
puts("");
}
}
Mat Mut(Mat a,Mat b)
{
Mat c;
memset(c.mat,,sizeof(c.mat));
; k<N; k++)
; i<N; i++)
if(a.mat[i][k])
; j<N; j++)
{
c.mat[i][j]+=a.mat[i][k]*b.mat[k][j]%mod;
c.mat[i][j]=c.mat[i][j]%mod;
}
return c;
}
Mat Qpow(Mat a,LL n)
{
Mat c;
; i<N; ++i)
; j<N; ++j)
c.mat[i][j]=(i==j);
)
{
) c=Mut(c,a);
a=Mut(a,a);
}
return c;
}
void cal(Mat A,LL n,LL b[],LL& Fn,LL& Gn)
{
Mat A_;
LL c[N]={,,,,,};
; i<N; ++i)
; j<N; ++j)
A_.mat[i][j]=(i==j);
;i<&&n;i++,n>>=)
)
{
LL tres[]={,,,,,};
;j<;j++) //矩阵的行
;k<;k++) //矩阵的列
tres[j]=(tres[j]+F[i].mat[j][k]*c[k])%mod;
;j<;j++)
c[j]=tres[j]%mod;
}
Fn=Gn=;
Fn=(c[]+c[]+c[])%mod;
Gn=(c[]+c[]+c[])%mod;
}
void init_A()
{
;i<N;i++)
;j<N;j++)
A.mat[i][j]=hh[i][j];
F[]=A;
;i<;i++)
F[i]=Mut(F[i-],F[i-]);
}
int main()
{
LL n,Fn,Gn;
init_A();
int T;
scanf("%lld",&T);
while(T--)
{
scanf("%lld",&n);
)
{
puts("1 0");
continue;
}
n-=;
cal(A,n,b,Fn,Gn);
printf("%lld %lld\n",Fn,Gn);
}
}
“玲珑杯”ACM比赛 Round #12 (D) 【矩阵快速幂的时间优化】的更多相关文章
- “玲珑杯”ACM比赛 Round #12题解&源码
我能说我比较傻么!就只能做一道签到题,没办法,我就先写下A题的题解&源码吧,日后补上剩余题的题解&源码吧! A ...
- “玲珑杯”ACM比赛 Round #18
“玲珑杯”ACM比赛 Round #18 Start Time:2017-07-15 12:00:00 End Time:2017-07-15 15:46:00 A -- 计算几何你瞎暴力 Time ...
- “玲珑杯”ACM比赛 Round #19题解&源码【A,规律,B,二分,C,牛顿迭代法,D,平衡树,E,概率dp】
A -- simple math problem Time Limit:2s Memory Limit:128MByte Submissions:1599Solved:270 SAMPLE INPUT ...
- “玲珑杯”ACM比赛 Round #19 B -- Buildings (RMQ + 二分)
“玲珑杯”ACM比赛 Round #19 Start Time:2017-07-29 14:00:00 End Time:2017-07-29 16:30:00 Refresh Time:2017-0 ...
- “玲珑杯”ACM比赛 Round #1
Start Time:2016-08-20 13:00:00 End Time:2016-08-20 18:00:00 Refresh Time:2017-11-12 19:51:52 Public ...
- SCUT - 12 - 西方国家 - 矩阵快速幂
https://scut.online/p/12 可以用矩阵快速幂来做. #include<bits/stdc++.h> using namespace std; typedef long ...
- poj 3735 Training little cats 矩阵快速幂+稀疏矩阵乘法优化
题目链接 题意:有n个猫,开始的时候每个猫都没有坚果,进行k次操作,g x表示给第x个猫一个坚果,e x表示第x个猫吃掉所有坚果,s x y表示第x个猫和第y个猫交换所有坚果,将k次操作重复进行m轮, ...
- “玲珑杯”ACM比赛 Round #13 题解&源码
A 题目链接:http://www.ifrog.cc/acm/problem/1111 分析:容易发现本题就是排序不等式, 将A数组与B数组分别排序之后, 答案即N∑i=1Ai×Bi 此题有坑,反正据 ...
- POJ 3735 Training little cats<矩阵快速幂/稀疏矩阵的优化>
Training little cats Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 13488 Accepted: ...
随机推荐
- 通过wireshark学习Traceroute命令(UDP,ICMP协议)
traceroute: 通过TTL限定的ICMP/UDP/TCP侦测包来发现从本地主机到远端目标主机之间的第三层转发路径.用来调试网络连接性和路由问题. mtr: traceroute的一个变种,能根 ...
- 第45篇 js操作打开本地程序
原文地址:http://blog.laofu.online/2017/06/10/how-js-controlApp/ 背景 假设有这样一个产品,一个web和一个winform客户端,在客户在web的 ...
- javaCV开发详解之7:让音频转换更加简单,实现通用音频编码格式转换、重采样等音频参数的转换功能(以pcm16le编码的wav转mp3为例)
javaCV系列文章: javacv开发详解之1:调用本机摄像头视频 javaCV开发详解之2:推流器实现,推本地摄像头视频到流媒体服务器以及摄像头录制视频功能实现(基于javaCV-FFMPEG.j ...
- Python之道1-环境搭建与pycharm的配置django安装及MySQL数据库配置
近期做那个python的开发,今天就来简单的写一下开发路线的安装及配置, 开发路线 Python3.6.1+Pycharm5.0.6+Django1.11+MySQL5.7.18 1-安装Python ...
- 第一次使用idea从SVN什么checkout项目,一直都是用的eclipse
IntelliJ IDEA 14 拉取SVN maven 多模块项目 部署tomcat 详细图解! 二话不说 进入主题 我们创建空项目实际上是项目空间 进入主界面 想用svn必须先启用它 选择Su ...
- go 基础语法
时间有限,简单记一些常用的,麻烦的不写了 定义变量:可以连续定义,也可以单个定义 var a int int类型 var a="ds" 默认string类型 a:=&qu ...
- SQL中创建外键约束
alter table 表名 add constraint 外键约束名 foreign key(列名) references 引用外键表(列名)
- Docker Machine 简介
Docker Machine 是什么? Docker Machine 是 Docker 官方提供的一个工具,它可以帮助我们在远程的机器上安装 Docker,或者在虚拟机 host 上直接安装虚拟机并在 ...
- codeM美团编程大赛初赛B轮D题
[编程题] 模 时间限制:1秒空间限制:32768K 给定四个正整数a,b,c,k,回答是否存在一个正整数n,使得a*n在k进制表示下的各位的数值之和模b为c.输入描述:第一行一个整数T(T < ...
- centos6.7下安装mysql5.6.22同时解决中文乱码问题
1.下载 http://dev.mysql.com/downloads/mysql/ 或者使用wget下载: wget http://dev.mysql.com/get/Downloads/MySQL ...