目录

题目链接

loj#2128. 「HAOI2015」数字串拆分

题解

\(f(s)\)对于\(f(i) = \sum_{j = i - m}^{i - 1}f(j)\)

这个可以用转移矩阵通过矩阵乘法处理出来

预处理出\(A[i][j]\)表示数S为\(j * 10 ^ i\)的转移矩阵

对于g的转移

\(g(i) = \sum_{j = 0}^{i - 1}g(j) * D(j + 1,i)\)

D[i][j]表示第i位到底j位构成的数的f,(转移矩阵

对于g的转移也是需要矩阵的

g(0) = 1也就是{0,0,0,.....,0,1}

代码


#include<map>
#include<vector>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define gc getchar()
#define pc putchar
#define LL long long
inline int read() {
int x = 0,f = 1;
char c = gc;
while(c < '0' || c > '9')c = gc;
while(c <= '9' && c >= '0') x = x * 10 + c - '0',c = gc;
return x * f;
}
void print(int x) {
if(x < 0) {
pc('-');
x = -x;
}
if(x >= 10) print(x / 10);
pc(x % 10 + '0');
}
const int maxn = 507;
int n,m;
const int mod = 998244353;
struct Ma {
int a[6][6];
Ma() { memset(a,0,sizeof a); }
Ma operator * (const Ma & t)const {
Ma ret;
memset(ret.a,0,sizeof ret.a);
for(int i = 1;i <= m;++ i)
for(int j = 1;j <= m;++ j)
for(int k = 1;k <= m;++ k)
(ret.a[i][j] += 1ll * a[i][k] * t.a[k][j] % mod) %= mod;
return ret;
}
Ma operator + (const Ma &k)const {
Ma ret;
memset(ret.a,0,sizeof ret.a);
for(int i = 1;i <= m;++ i)
for(int j = 1;j <= m;++ j)
ret.a[i][j] = (a[i][j] + k.a[i][j]) % mod;
return ret;
}
} A[maxn][10],f[maxn];
char s[maxn];
int main() {
scanf("%s",s + 1);
n = strlen(s + 1);
m = read();
for(int i = 1;i <= m;++ i)
A[0][0].a[i][i] = 1 ,
A[0][1].a[i][m] = 1;
for(int i = 1;i < m;++ i)
A[0][1].a[i + 1][i] = 1;
for(int i = 2;i <= 9;++ i)
A[0][i] = A[0][i - 1] * A[0][1];
for(int i = 1;i <= n;++ i) { //十进制快速幂
A[i][0] = A[0][0];
A[i][1] = A[i - 1][9] * A[i - 1][1];
for(int j = 2;j <= 9;++ j)
A[i][j] = A[i][j - 1] * A[i][1];
}
f[0].a[1][m] = 1;
Ma now;
for(int i = 1;i <= n;++ i) {
now = A[0] [s[i] - '0'];
for(int j = i - 1;j >= 0;-- j) {
f[i] = f[i] + (f[j] * now);
if(j) now = A[i - j][s[j] - '0'] * now;
}
}
print(f[n].a[1][m]);
pc('\n');
return 0;
}

loj#2128. 「HAOI2015」数字串拆分 矩阵乘法的更多相关文章

  1. 【LOJ】#2128. 「HAOI2015」数字串拆分

    题解 题中给的函数可以用矩阵快速幂递推 我们记一个数组dp[i](这个数组每个元素是一个矩阵)表示从1到i所有的数字经过拆分矩阵递推的加和 转移方法是 \(dp[i] = \sum_{j = 0}^{ ...

  2. loj#2002. 「SDOI2017」序列计数(dp 矩阵乘法)

    题意 题目链接 Sol 质数的限制并没有什么卵用,直接容斥一下:答案 = 忽略质数总的方案 - 没有质数的方案 那么直接dp,设\(f[i][j]\)表示到第i个位置,当前和为j的方案数 \(f[i ...

  3. loj #2006. 「SCOI2015」小凸玩矩阵

    #2006. 「SCOI2015」小凸玩矩阵   题目描述 小凸和小方是好朋友,小方给小凸一个 N×M N \times MN×M(N≤M N \leq MN≤M)的矩阵 A AA,要求小凸从其中选出 ...

  4. LOJ#2127「HAOI2015」按位或

    用$ Min-Max$容斥之后要推的东西少了好多 无耻的用实数快读抢了BZOJ.Luogu.LOJ三个$ OJ$的Rank 1 即将update:被STO TXC OTZ超了QAQ 题意:集合$ [0 ...

  5. LOJ#2083. 「NOI2016」优秀的拆分

    $n \leq 30000$的字符串,问其所有子串的所有AABB形式的拆分有多少种.$t \leq 10$组询问. $n^3$过80,$n^2$过95,鬼去写正解.. $n^2$:先枚举一次算每个位置 ...

  6. 「BZOJ2510」弱题(矩阵乘法,降维)

    有M个球,一开始每个球均有一个初始标号,标号范围为1-N且为整数,标号为i的球有ai个,并保证Σai = M. 每次操作等概率取出一个球(即取出每个球的概率均为1/M),若这个球标号为k(k < ...

  7. loj#2013. 「SCOI2016」幸运数字 点分治/线性基

    题目链接 loj#2013. 「SCOI2016」幸运数字 题解 和树上路径有管...点分治吧 把询问挂到点上 求出重心后,求出重心到每个点路径上的数的线性基 对于重心为lca的合并寻味,否则标记下传 ...

  8. Loj #3089. 「BJOI2019」奥术神杖

    Loj #3089. 「BJOI2019」奥术神杖 题目描述 Bezorath 大陆抵抗地灾军团入侵的战争进入了僵持的阶段,世世代代生活在 Bezorath 这片大陆的精灵们开始寻找远古时代诸神遗留的 ...

  9. Loj #3055. 「HNOI2019」JOJO

    Loj #3055. 「HNOI2019」JOJO JOJO 的奇幻冒险是一部非常火的漫画.漫画中的男主角经常喜欢连续喊很多的「欧拉」或者「木大」. 为了防止字太多挡住漫画内容,现在打算在新的漫画中用 ...

随机推荐

  1. .NET中制做对象的副本(二)继承对象之间的数据拷贝

    定义学生 /// <summary> /// 学生信息 /// </summary> public class Student { /// <summary> // ...

  2. Linux内核驱动之延时 【转】

    转自:http://blog.chinaunix.net/uid-24219701-id-3288103.html  jiffies 计数器 定时器中断由系统定时硬件以规律地间隔产生; 这个间隔在启动 ...

  3. Python3学习笔记21-实例属性和类属性

    由于Python是动态语言,根据类创建的实例可以任意绑定属性. 给实例绑定属性的方法是通过实例变量,或者通过self变量: class Student(object): def __init__(se ...

  4. 数据库的连接使用——使用ADO.NET连接数据库

    一.ADO.NET简介 ADO.NET是由很多类组成的一个类库,这些类库提供了很多对象,用来完成数据的连接.查询.插入.更新和删除等操作.其中主要包括以下对象: 1.Connection对象:用来连接 ...

  5. 阿里云服务器搭建FTP

    操作系统:Windows Server 2008 R2企业版. 首先,创建一个用户组:ftpUsers,创建一个用户:ftpAdmin.并将ftpAdmin隶属于ftpUsers组 其次,需要安装ft ...

  6. plsql developer导入导出序列方法

    导出: 1.打开PLSQL Developer,工具 2.类型排序,选中所有sequence,指定用户,单个文件,选择导出文件路径,等待执行完毕即可. 导入: 打开导出的文件,复制,在新打开的命令窗口 ...

  7. jenkins cobertura单元测试

    1.1      Maven 工程 pom.xml 修改 1.2      Build添加插件目标 此时构建项目,会在项目 targer/site/cobertura 目录中生成 html 与 xml ...

  8. 一个shell的面试题

    5.写一个脚本,实现判断192.168.1.024网络里,当前在线的D有哪些,能ping通则认为在线,在线输出"TP地址UP",不在线输出TP地址DOWN",无其他输出. ...

  9. Ex 6_23 一个生产系统共包含n个顺序执行的阶段..._第七次作业

  10. 基于python的k-s值计算

    做评分卡模型时(假设有多个自变量,因变量即是否违约.)通常需要筛选变量. k-s值的作用类似于AUC,它期初是用来评价模型(变量)对是否违约事件的区分程度的. # -*- coding: utf-8 ...