bzoj2973转移矩阵构造法!
/*
构造单位矩阵(转移矩阵)
给定n*m网格,每个格子独立按照长度不超过6的操作串循环操作
对应的操作有
0-9:拿x个石头到这个格子
nwse:把这个格子的石头推移到相邻格子
d:清空该格石子
开始时网格是空的,问t秒后石头最多的格子里有多少个石子 t很大,并且每次操作后格子里的石头是线性变化的,所以用矩阵来加速递推
将n*m网格表示成为(i-1)*m+j的一维数组,那么这个数组对应的转移矩阵大小应该是(nm)^2 然后由于每个格子的操作串最长只有6,并且1-6的最小公倍数是60,所以所有格子的操作60秒一个循环
那么求出每秒的转移矩阵,用Ai表示第i秒的转移矩阵,(1<=i<=60)
另A=mul(Ai),t=p*60+r,那么结果状态就是A^p*mul(A1,Ar); 那么如何将操作对应到转移矩阵的构造上?
考虑转移矩阵的运行原理:可以将F'[j]=F[i]*A[i][j],即将原数组的F[i]*A[i][j]然后加到F'[j]上
0-9:凭空把x个石头转移到第i个格子上,令F[0]=1,A[0][num(i,j)]=x,如此即可完成状态转移
nwse:距离n操作:把第i行的石头转移到第i-1行,即把num[i][j]的石头转移到num[i-1][j],那么令A[num[i][j]][num[i-1][j]]=1即可
保证要使F[0]=1,那么将A[0][0]设置为1
A的其它数值都为0
F数组就是[1,0,0,0,0,0,0,0,...0]
矩阵快速幂加速计算
*/
#include<bits/stdc++.h>
using namespace std;
#define P 65
#define ll long long
int n,m,t,q,i,j,k,x,y,N;
int id[P][P],a[P][P],l[P];//
char b[P][P];
ll ans;
struct mat{
ll a[P][P];
mat(){memset(a,,sizeof a);}
mat operator*(mat b){//重载矩阵乘法
mat c;
for(int i=;i<n;i++)
for(int j=;j<n;j++)
for(int k=;k<n;k++)
c.a[i][j]+=a[i][k]*b.a[k][j];
return c;
}
}one,A[P],pre[P],B,C,D; int main(){
scanf("%d%d%d%d",&n,&m,&t,&q);
char ch;
for(int i=;i<=n;i++)//输入每个格子对应的操作序号
for(int j=;j<=m;j++)
cin>>ch,a[i][j]=ch-'',id[i][j]=++N;
N++;
for(int i=;i<q;i++){//输入q行不同的操作序列
scanf("%s",b[i]+),l[i]=strlen(b[i]+);
b[i][]=b[i][l[i]];//循环点处理一下
}
for(int i=;i<n;i++)one.a[i][i]=;//构造单位矩阵
pre[]=one;
char c;
for(int i=;i<=;i++){//求出每个时间点对应的状态转移矩阵
A[i].a[][]=;//对于第1个点
for(int j=;j<=n;j++)
for(int k=;k<=m;k++){
//求出第[j,k]块的序号,就是a[j][k],在第i个时间点对应的操作c
c=b[a[j][k]][i%l[a[j][k]]]; if(c>='' && c<=''){//数字
A[i].a[id[j][k]][]=c-'';
A[i].a[id[j][k]][id[j][k]]++;
}
if(c=='N'){//向各个方向转移
x=j-,y=k;
if(x>=)
A[i].a[id[x][y]][id[j][k]]++;
}
if(c=='S'){
x=j+,y=k;
if(x<=n)
A[i].a[id[x][y]][id[j][k]]++;
}
if(c=='W'){
x=j,y=k-;
if(y>=)
A[i].a[id[x][y]][id[j][k]]++;
}
if(c=='E'){
x=j,y=k+;
if(y<=m)
A[i].a[id[x][y]][id[j][k]]++;
}
}
pre[i]=A[i]*pre[i-];//把所有时间点的矩阵乘起来
} B=pre[],C=one;
for(k=t/;k;k>>=){//快速幂
if(k&)C=C*B;
B=B*B;
}
D.a[][]=,D=pre[t%]*C*D;//把余下时间的矩阵呈上去
for(int i=;i<N;i++)//由于F数组只有第0项为1,那么直接求D[i][0]的最大值即可!
if(ans<D.a[i][])
ans=D.a[i][];
printf("%lld",ans);
}
bzoj2973转移矩阵构造法!的更多相关文章
- Uva 120 - Stacks of Flapjacks(构造法)
UVA - 120 Stacks of Flapjacks Time Limit: 3000MS Memory Limit: Unknown 64bit IO Format: %lld &a ...
- 利用子集构造法实现NFA到DFA的转换
概述 NFA非有穷自动机,即当前状态识别某个转换条件后到达的后继状态不唯一,这种自动机不便机械实现,而DFA是确定有限状态的自动机,它的状态转换的条件是确定的,且状态数目往往少于NFA,所以DFA能够 ...
- [Luogu4724][模板]三维凸包(增量构造法)
1.向量点积同二维,x1y1+x2y2+x3y3.向量叉积是行列式形式,(y1z2-z1y2,z1x2-x1z2,x1y2-y1x2). 2.增量构造法: 1)首先定义,一个平面由三个点唯一确定.一个 ...
- POJ 3295 Tautology (构造法)
Tautology Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7716 Accepted: 2935 Descrip ...
- 牛客网 牛客小白月赛2 A.数字方阵-反魔方阵,梁邱构造法
天坑未补... 水一波博客,再不写博客就咸成鱼干了,只写题不写题解,过一段时间就忘了自己学过什么了. 最近重点就是把开学以来写的题补出来,没学的就滚去学会啊(= =),填一下坑... 从这篇博客开始, ...
- 紫书 习题 8-24 UVa 10366 (构造法)
又是一道非常复杂的构造法-- #include<cstdio> #include<algorithm> #define REP(i, a, b) for(int i = (a) ...
- 紫书 例题8-17 UVa 1609 (构造法)(详细注释)
这道题用构造法, 就是自己依据题目想出一种可以得到解的方法, 没有什么规律可言, 只能根据题目本身来思考. 这道题的构造法比较复杂, 不知道刘汝佳是怎么想出来的, 我想的话肯定想不到. 具体思路紫书上 ...
- LeetCode42题,单调栈、构造法、two pointers,这道Hard题的解法这么多?
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode专题的第23篇文章. 今天来看一道很有意思的题,它的难度是Hard,并且有许多种解法. 首先我们来看题面,说是我们有若 ...
- 【译】N 皇后问题 – 构造法原理与证明 时间复杂度O(1)
[原] E.J.Hoffman; J.C.Loessi; R.C.Moore The Johns Hopkins University Applied Physics Laboratory *[译]* ...
随机推荐
- Leetcode#832. Flipping an Image(翻转图像)
题目描述 给定一个二进制矩阵 A,我们想先水平翻转图像,然后反转图像并返回结果. 水平翻转图片就是将图片的每一行都进行翻转,即逆序.例如,水平翻转 [1, 1, 0] 的结果是 [0, 1, 1]. ...
- day 12 - 1 装饰器进阶
装饰器进阶 装饰器的简单回顾 装饰器开发原则:开放封闭原则装饰器的作用:在不改变原函数的调用方式的情况下,在函数的前后添加功能装饰器的本质:闭包函数 装饰器的模式 def wrapper(func): ...
- 关于vmvawe的光驱,iso镜像,挂载,卸载
勾选这个使用iso镜像文件,就相当于真实的环境下,将一张光盘插进了光驱里,然后再勾选启动时连接,那么在linux开机后,/dev/cdrom或者/dev/sr0(前者是后者的软连接)就表示这个硬件设备 ...
- 基于netty的一款http server
cicada 基本功能 1.基于注解.注解扫描 2.ioc 对象管理 3.intercepter 拦截器 ref https://github.com/TogetherOS/cicada
- python基础-----变量和简单数据类型
初识变量 1.变量命名规则: a.字母 b.数字(不能开头) c.下划线 ps.硬性规定,命名必须是字母,数字,下划线,且不能以数字开头. 软性规则,以下划线分割 2.实例: a.写法: age_of ...
- Debian 为firefox安装flash插件 以及 音频驱动
1. flash下载地址:http://get.adobe.com/cn/flashplayer/ lv@lv:~/Downloads$ tar -zxvf flash_player_npapi_li ...
- SpringBoot单元测试示例2
package cn.coreqi.security.controller; import org.junit.Before; import org.junit.Test; import org.ju ...
- 【转】python f-string
[转]python f-string 文章目录 1. 主要内容 1.1. 旧时代的格式化字符串 1.1.1. Option #1: %-formatting 1.1.2. 怎样使用 %-forma ...
- 安装mongo php拓展
下载php_mongo.dll文件 下载地址:https://s3.amazonaws.com/drivers.mongodb.org/php/index.html(注意对应版本及是否线程安全)需要注 ...
- 一道搜索题【2013 noip提高组 DAY2 t3】华容道
这篇不多说,具体的解释都在程序里 题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果 ...