#547. 「LibreOJ β Round #7」匹配字符串

 

题目描述

对于一个 01 串(即由字符 0 和 1 组成的字符串)sss,我们称 sss 合法,当且仅当串 sss 的任意一个长度为 mmm 的子串 s′s's​′​​,不为全 1 串。

请求出所有长度为 nnn 的 01 串中,有多少合法的串,答案对 655376553765537 取模。

输入格式

输入共一行,包含两个正整数 n,mn,mn,m。

输出格式

输出共一行,表示所求的和对 655376553765537 取模的结果。

样例

样例输入 1

5 2

样例输出 1

13

样例解释 1

以下是所有合法的串:

00000
00001
00010
00100
00101
01000
01001
01010
10000
10001
10010
10100
10101

样例输入 2

2018 7

样例输出 2

27940

#include<iostream>
#include<cstdio>
#include<cstring>
#define mod 65537
using namespace std;
int n,m;
struct node{
int n,m;
int a[][];
node(){memset(a,,sizeof(a));}
node operator * (const node &b)const{
node res;
res.n=n;res.m=b.m;
for(int i=;i<=n;i++)
for(int j=;j<=b.m;j++)
for(int k=;k<=m;k++)
res.a[i][j]+=1LL*a[i][k]*b.a[k][j]%mod;
return res;
}
};
bool check(int sta){
int cnt=;
for(int i=;i<=n;i++){
if(sta&(<<i-))cnt++;
else cnt=;
if(cnt>=m)return ;
}
return ;
}
node Pow(node x,int y){
node res;
res.n=;res.m=;
res.a[][]=;res.a[][]=;
while(y){
if(y&)res=res*x;
x=x*x;
y>>=;
}
return res;
}
void work1(){
node a;
a.n=;a.m=;
a.a[][]=;a.a[][]=;
node b;
b.n=b.m=;
b.a[][]=;b.a[][]=;b.a[][]=;
b=Pow(b,n-);
a=a*b;
int ans=(a.a[][]+a.a[][])%mod;
printf("%d",ans);
}
int main(){
scanf("%d%d",&n,&m);
if(m==){puts("");return ;}
if(m==){work1();return ;}
int ans=;
for(int sta=;sta<(<<n);sta++)
if(check(sta)){
ans++;
if(ans>=mod)ans-=mod;
}
printf("%d",ans);
return ;
}

13分 矩阵快速幂优化dp+枚举

#include<iostream>
#include<cstdio>
#include<cstring>
#define mod 65537
using namespace std;
long long n,m;
int tmp[],b[],c[],ans,inv[mod],fac[mod],bin[];
int Pow(int x,int y){
int res=;
while(y){
if(y&)res=1LL*res*x%mod;
x=1LL*x*x%mod;
y>>=;
}
return res;
}
int C(int n,int m){
if(m>n)return ;
return 1LL*fac[n]*inv[m]%mod*inv[n-m]%mod;
}
int Lucas(long long n,long long m){
if(!m)return ;
return 1LL*Lucas(n/mod,m/mod)*C(n%mod,m%mod)%mod;
}
void mul(int *b,int *c){
for(int i=;i<m;i++)
for(int j=;j<m;j++)
tmp[i+j]=(tmp[i+j]+1LL*b[i]*c[j]%mod)%mod;
for(int i=*m-;i>=m;i--)
for(int j=;j<=m;j++)
tmp[i-j]=(tmp[i-j]+tmp[i])%mod;
for(int i=;i<m;i++)b[i]=tmp[i],tmp[i]=tmp[i+m]=;
}
void solve1(){
bin[]=c[]=;
if(m==)b[]=;
else b[]=;
for(int i=;i<m;i++)
bin[i]=1LL**bin[i-]%mod;
while(n){
if(n&)mul(c,b);
mul(b,b);
n>>=;
}
for(int i=;i<m;i++)
ans=(ans+1LL*bin[i]*c[i]%mod)%mod;
cout<<ans;
}
int s(long long n){
long long base=Pow(Pow(,m+),mod-);
long long cc=Pow(,n);int res=;
for(int k=;k*(m+)<=n;k++){
long long tt=1LL*Lucas(n-k*m,k)*cc%mod;
tt=(k&)?mod-tt:tt;
res=(res+tt)>=mod?res-mod+tt:res+tt;
cc=1LL*cc*base%mod;
}
return res;
}
void solve2(){
fac[]=fac[]=;
for(int i=;i<mod;i++)fac[i]=1LL*fac[i-]*i%mod;
inv[mod-]=mod-;
for(int i=mod-;i>=;i--)inv[i-]=1LL*inv[i]*i%mod;
ans=s(n+)-s(n);
printf("%d\n",(ans<)?ans+mod:ans);
}
int main(){
cin>>n>>m;
if(m<=)solve1();
else solve2();
return ;
}

100分

 

loj #547. 「LibreOJ β Round #7」匹配字符串的更多相关文章

  1. [LOJ#531]「LibreOJ β Round #5」游戏

    [LOJ#531]「LibreOJ β Round #5」游戏 试题描述 LCR 三分钟就解决了问题,她自信地输入了结果-- > -- 正在检查程序 -- > -- 检查通过,正在评估智商 ...

  2. [LOJ#530]「LibreOJ β Round #5」最小倍数

    [LOJ#530]「LibreOJ β Round #5」最小倍数 试题描述 第二天,LCR 终于启动了备份存储器,准备上传数据时,却没有找到熟悉的文件资源,取而代之的是而屏幕上显示的一段话: 您的文 ...

  3. [LOJ#516]「LibreOJ β Round #2」DP 一般看规律

    [LOJ#516]「LibreOJ β Round #2」DP 一般看规律 试题描述 给定一个长度为 \(n\) 的序列 \(a\),一共有 \(m\) 个操作. 每次操作的内容为:给定 \(x,y\ ...

  4. [LOJ#515]「LibreOJ β Round #2」贪心只能过样例

    [LOJ#515]「LibreOJ β Round #2」贪心只能过样例 试题描述 一共有 \(n\) 个数,第 \(i\) 个数 \(x_i\) 可以取 \([a_i , b_i]\) 中任意值. ...

  5. [LOJ#525]「LibreOJ β Round #4」多项式

    [LOJ#525]「LibreOJ β Round #4」多项式 试题描述 给定一个正整数 k,你需要寻找一个系数均为 0 到 k−1 之间的非零多项式 f(x),满足对于任意整数 x 均有 f(x) ...

  6. [LOJ#526]「LibreOJ β Round #4」子集

    [LOJ#526]「LibreOJ β Round #4」子集 试题描述 qmqmqm有一个长为 n 的数列 a1,a2,……,an,你需要选择集合{1,2,……,n}的一个子集,使得这个子集中任意两 ...

  7. [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机)

    [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机) 试题描述 IOI 的比赛开始了.Jsp 和 Rlc 坐在一个角落,这时他们听到了一个异样的声音 …… 接着他们发现自己收 ...

  8. loj #535. 「LibreOJ Round #6」花火 树状数组求逆序对+主席树二维数点+整体二分

    $ \color{#0066ff}{ 题目描述 }$ 「Hanabi, hanabi--」 一听说祭典上没有烟火,Karen 一脸沮丧. 「有的哦-- 虽然比不上大型烟花就是了.」 还好 Shinob ...

  9. Loj #528. 「LibreOJ β Round #4」求和 (莫比乌斯反演)

    题目链接:https://loj.ac/problem/528 题目:给定两个正整数N,M,你需要计算ΣΣu(gcd(i,j))^2 mod 998244353 ,其中i属于[1,N],j属于[1,M ...

随机推荐

  1. 转载:trap 的用法 /etc/init.d/rcS trap :1 2 3 24

    在有些情况下,我们不希望自己的shell脚本在运行时刻被中断,比如说我们写得shell脚 本设为某一用户的默认shell,使这一用户进入系统后只能作某一项工作,如数据库备份, 我 们可不希望用户使用c ...

  2. 嵌入式系统LINUX环境搭建

    Linux kernel Complier: http://supportopensource.iteye.com/blog/680483 sudo make mrproper         净化解 ...

  3. spring之:XmlWebApplicationContext作为Spring Web应用的IoC容器,实例化和加载Bean的过程

    它既是 DispatcherServlet 的 (WebApplicationContext)默认策略,又是 ContextLoaderListener 创建 root WebApplicationC ...

  4. 第15届浙江省赛 D Sequence Swapping(dp)

    Sequence Swapping Time Limit: 1 Second      Memory Limit: 65536 KB BaoBao has just found a strange s ...

  5. jdk中那些常见的类不能被继承的

    对于java中的类,如果是使用final修饰的话,那么这个类就不能够被继承,因为jdk的开发者认为,有一些最基本的类没要必要对开发者开放,如果用户 继承时操作有误,很可能引入很多问题.为了防止用户对基 ...

  6. VxVM如何扩展和收缩卷及文件系统

    1. 同时扩展卷和文件系统 先用vxassist命令检查DG可用空间 [root@rhelnode1 ~]# vxassist -g testdg maxsize Maximum volume siz ...

  7. java反射专题一

    一丶Class的理解 /* * Class类是反射的源头 * 创建一个类,通过编译(javac.exe),生成对应的.class文件,之后使用java.exe加载(JVM的类加载器完成的)此.clas ...

  8. Android CTS

    1.什么是CTS CTS是google制定的兼容性测试包(Compatibility Test Suite),只有通过CTS测试的设备才有可能获得Android的商标和享受Android Market ...

  9. Linux系统的安装(centos的下载地址:http://mirror.symnds.com/distributions/CentOS-vault/6.3/isos/i386/,选择:CentOS-6.3-i386-bin-DVD1.iso 这个下载并进行安装)

    1.首先打开虚拟机: 在上面的那个按钮旁有一个下拉的符号,点开后会看到一个进入固件的按钮,直接点击进去. 便会进入这个界面: 在这个界面其实我们不需要该任何的东西,但是我们需要进入boot界面看一眼, ...

  10. SQLAchemy ORM框架

    SQLAchemy SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行S ...