记操作序列为$S$,令$h(S)\equiv \sum_{i}a_{i}x^{i}(mod\ p)$(其中$a_{i}$为操作后的结果)

(以下我们将$S$看作字符串,相邻即拼接操作)

对于操作,有$h(1S)=xh(S)$,$h(3S)=h(S)+1$(另外两种操作类似),这可以看作一个函数,即定义函数$g_{S_{1}}(h(S_{2}))=h(S_{1}S_{2})$

令$s[i,j]$表示操作序列的区间$[i,j]$的子串,则有$g_{s[1,i)}h(s[i,j])=h([1,j])$,同时区间$[i,j]$合法当且仅当$h(s[i,j])=h[s(1,n)]$,即等价于$pre_{j}=g_{s[1,i)}(pre_{n})$(其中$pre_{j}=h(s[1,j])$)

发现右边仅与$i$有关,倒序枚举$i$求出该值,然后在$[i,n]$中找到相同的$pre_{j}$数量,可以用map维护,时间复杂度为$o(n\log_{2}n)$

(后面的值计算可能比较麻烦,可以将$s[1,i)$中的位移和权值拆开来计算)

考虑哈希冲突的概率,假设$x$为变量,那么$h(S)$就是一个关于$x$的函数,且其次数至多为$2n$(算上负幂次),因此$h(S_{1})=h(S_{2})$也就是一个$2n$次的同余方程,由于$p$为大素数,解数量基本为$2n$个

假设选择了$k$个$x$,而$2n$个解就会使得$(2n)^{k}$组$x$不合法,共要判断$o(n^{2})$对哈希值,即会使得$o(n^{2}(2n)^{k})$(同样忽略此处相同)组$x$不合法

对于总共$p^{k}$种,不能选$n^{2}(2n)^{k}$种,即不合法概率为$n^{2}(\frac{2n}{p})^{k}$,取$k=6$,$p$~$10^{9}$可以基本避免冲突

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 250005
4 #define mod 1000000007
5 struct ji{
6 int a[6];
7 bool operator < (const ji &k)const{
8 for(int i=0;i<6;i++)
9 if (a[i]!=k.a[i])return a[i]<k.a[i];
10 return 0;
11 }
12 }o,a[N];
13 map<ji,int>mat;
14 int n,p[N],mi[6][N],mi_inv[6][N],x[6]={998244311,998244341,998244353,998244389,998244391,998244397};
15 long long ans;
16 char s[N];
17 int ksm(int n,int m){
18 if (!m)return 1;
19 int s=ksm(n,m>>1);
20 s=1LL*s*s%mod;
21 if (m&1)s=1LL*s*n%mod;
22 return s;
23 }
24 int calc(int p,int k){
25 if (k>=0)return mi[p][k];
26 return mi_inv[p][-k];
27 }
28 int main(){
29 scanf("%d%s",&n,s);
30 for(int i=0;i<5;i++){
31 mi[i][0]=1;
32 for(int j=1;j<=n;j++)mi[i][j]=1LL*mi[i][j-1]*x[i]%mod;
33 mi_inv[i][1]=ksm(x[i],mod-2);
34 for(int j=2;j<=n;j++)mi_inv[i][j]=1LL*mi_inv[i][j-1]*mi_inv[i][1]%mod;
35 }
36 p[0]=0;
37 for(int i=1;i<=n;i++){
38 p[i]=p[i-1];
39 a[i]=a[i-1];
40 if (s[i-1]=='<')p[i]--;
41 if (s[i-1]=='>')p[i]++;
42 if (s[i-1]=='+')
43 for(int j=0;j<6;j++)a[i].a[j]=(a[i].a[j]+calc(j,p[i]))%mod;
44 if (s[i-1]=='-')
45 for(int j=0;j<6;j++)a[i].a[j]=(a[i].a[j]+mod-calc(j,p[i]))%mod;
46 }
47 for(int i=n;i;i--){
48 for(int j=0;j<6;j++)o.a[j]=(1LL*a[n].a[j]*calc(j,p[i-1])+a[i-1].a[j])%mod;
49 mat[a[i]]++;
50 ans+=mat[o];
51 }
52 printf("%lld",ans);
53 }

[atARC099F]Eating Symbols Hard的更多相关文章

  1. Atcoder 乱做

    最近感觉自己思维僵化,啥都不会做了-- ARC103 F Distance Sums 题意 给定第 \(i\) 个点到所有点的距离和 \(D_i\) ,要求构造一棵合法的树.满足第 \(i\) 个点到 ...

  2. 【AtCoder】ARC099题解

    C - Minimization 每次操作必然包含一个1 枚举第一次操作的位置计算两边即可 代码 #include <bits/stdc++.h> #define fi first #de ...

  3. AtCoder Regular Contest 99

    传送门 C - Minimization 第一次可能有多种选择,我们枚举所有的选择,然后两边贪心取即可. Code #include <bits/stdc++.h> #define MP ...

  4. Undefined symbols for architecture arm64解决方案

    在iOS开发中经常遇到的一个错误是Undefined symbols for architecture arm64,这个错误表示工程某些地方不支持arm64指令集.那我们应该怎么解决这个问题了?我们不 ...

  5. Clang: Undefined symbols, but it is there using nm.

    https://stackoverflow.com/questions/36662920/xcode-clang-link-build-dynamic-framework-or-dylib-not-e ...

  6. 转载:《TypeScript 中文入门教程》 16、Symbols

    版权 文章转载自:https://github.com/zhongsp 建议您直接跳转到上面的网址查看最新版本. 介绍 至ECMAScript 2015开始,symbol成为了一种新的原始类型,就像n ...

  7. ios build时,Undefined symbols for architecture xxx问题的总结

    简单来说,Undefined symbols基本上等于JAVA的ClassNotFoundException,最常见的原因有这几种: build的时候没有加framework 比如说,有一段代码我用了 ...

  8. Undefined symbols for architecture x86_64: "_OBJC_CLASS_$_The49DayPersonalFullscreenGiftModel", referenced from: objc-class-ref in The49DayPersonalRoomGiftModel.o ld: symbol(s) not found for a

    Undefined symbols for architecture x86_64: "_OBJC_CLASS_$_The49DayPersonalFullscreenGiftModel&q ...

  9. ios开发错误之: Undefined symbols for architecture x86_64

    错误如下: Undefined symbols for architecture x86_64: "_OBJC_CLASS_$_RoutingHTTPServer", refere ...

随机推荐

  1. 从零入门 Serverless | SAE 场景下,应用流量的负载均衡及路由策略配置实践

    作者 | 落语 阿里云云原生技术团队 本文整理自<Serverless 技术公开课>,关注"Serverless"公众号,回复"入门",即可获取 S ...

  2. 洛谷5038 [SCOI2012]奇怪的游戏(二分+网络流+判断奇偶)

    寒假的时候就听过这个题.但是一直没有写. qwq 首先,我们发现题目中的图是个网格图,然后每次可以将相邻两个格子加一. 很容易就想到是黑白染色.那么每次操作,就相当于同时操作一个白点,一个黑点. 我们 ...

  3. 洛谷3244 落忆枫音 (拓扑图dp+式子)

    题目大意就是 给你一个DAG 然后添加一条边\(x->y\) ,询问以1为根的生成树的个数 QWQ 首先假设没有添加的边 答案就应该是 \[ans=\prod_{i=1}^{n} in[i] \ ...

  4. 专业网络损伤仪HoloWAN meme只需5999元!

    在人们对互联网的依赖度越来越高的今天,人类社会逐步买入元宇宙时代,为了大大提高整个互联网的用户体验,HoloWAN团队推出每一个互联网应用开发团队都能用得起的专业网络损伤仪HoloWAN meme!售 ...

  5. python socket zmq

    本篇博客将介绍zmq应答模式,所谓应答模式,就是一问一答,规则有这么几条 1. 必须先提问,后回答 2. 对于一个提问,只能回答一次 3. 在没有收到回答前不能再次提问 上代码,服务端: #codin ...

  6. Golang通脉之函数

    函数是组织好的.可重复使用的.用于执行指定任务的代码块. Go语言中支持函数.匿名函数和闭包,并且函数在Go语言中属于"一等公民". 函数定义 Go语言中定义函数使用func关键字 ...

  7. 【UE4 C++ 基础知识】<2> UFUNCTION宏、函数说明符、元数据说明符

    UFunction声明 UFunction 是虚幻引擎4(UE4)反射系统可识别的C++函数.UObject 或蓝图函数库可将成员函数声明为UFunction,方法是将 UFUNCTION 宏放在头文 ...

  8. .Net 5下的单文件部署

    由于.net程序没有静态链接,一直缺乏单文件部署这种干净的发布方案.对客户端程序发布并不是很友好.在之前的.net framework下,有ILMerge合并程序集,以及LibZ的嵌入资源文件等第三方 ...

  9. [敏捷软工团队博客]Beta阶段事后分析

    设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件要解决的问题是:现在的软工课程的作业分布在博客园.GitHub上,没有一个集成多种功能的一体化 ...

  10. springBoot服务整合线程池ThreadPoolTaskExecutor与@Async详解使用

    ThreadPoolExecutor:=======这个是java自己实现的线程池执行类,基本上创建线程池都是通过这个类进行的创建.ThreadPoolTaskExecutor:========这个是 ...