[CF1538E] Funny Substrings (模拟)
题面
该场 Div. 3 最“难”的一道题:Funny Substrings
O
I
D
\tt OID
OID 队长喜欢玩字符串,因为
“
O
n
e
I
n
D
a
r
k
”
\tt “OneInDark”
“OneInDark” 是一个望而生畏的字符串。
O
I
D
\tt OID
OID 会进行
N
\tt N
N 次操作,每次操作形如以下两种之一:
x := S: x 是变量名称,S 是一个具体的字符串,:=符号两边都有空格。O
I
D
\tt OID
OID 把此时的 x 叫做
S
Y
SY
SY 变量。该操作意思是把 x 赋值为字符串 S。
x = a + b: x,a,b 是变量名称,=符号和+符号两边都有空格。O
I
D
\tt OID
OID 把此时的 x 也叫做
S
Y
SY
SY 变量。该操作意思是把 x 赋值为 a 和 b 首尾拼接起来的字符串。保证 a 和 b 在此操作之前作为
S
Y
SY
SY 变量出现过。
现在问你,在最后一次出现的
S
Y
SY
SY 变量储存的字符串中,字符串 haha 作为子串出现过多少次。比如:haha 在 hahahaha 中出现了 3 次。
一共
T
≤
1
0
3
\tt T\leq10^3
T≤103 组数据,每组数据中
1
≤
N
≤
50
\tt1\leq N\leq50
1≤N≤50,
1
≤
∣
S
∣
≤
5
\tt1\leq|S|\leq5
1≤∣S∣≤5 ,
1
≤
∣
变
量
名
∣
≤
5
\tt1\leq|变量名|\leq5
1≤∣变量名∣≤5。
题解
(我看这道题过的人最少,姑且认为它难吧)
不难发现,最终的字符串长度可能超过 long long 范围,因此,直接 string 模拟不是个好方法。
我们会发现,对于一个字符串,有用的信息可以整理成一个三元组
{
l
(
s
t
r
i
n
g
)
,
x
(
l
o
n
g
l
o
n
g
)
,
r
(
s
t
r
i
n
g
)
}
\tt\{l(string),x(long~long),r(string)\}
{l(string),x(long long),r(string)},分别表示:该字符串最左边 3 个(也许不足 3 个)字符,该字符串中 haha 的出现次数,该字符串最右边 3 个(也许不足 3 个)字符。
这个不难处理。关键是这样的三元组可以方便地定义 a + b 操作,返回另一个三元组:
- 把
x
a
\tt x_a
xa 和
x
b
\tt x_b
xb 加起作为
x
\tt x
x ,再把
r
a
\tt r_a
ra 和
l
b
\tt l_b
lb 拼起来(长度不超过 6),统计里面的
haha数量,也加到x
\tt x
x 里面去。
- 把
l
\tt l
l 赋为
l
a
\tt l_a
la ,如果长度不足 3,再把
l
b
\tt l_b
lb 拼在
l
\tt l
l 后面,把长度超过 3 的砍掉。
- 把
r
\tt r
r 赋为
r
b
\tt r_b
rb ,如果长度不足 3,再把
r
a
\tt r_a
ra 拼在
r
\tt r
r 前面,把长度超过 3 的砍掉。
这样就做出这道模拟题了,中间的字符串操作,可以暴力用 string 或者 char*+sprintf,时间足够。对于每个变量怎么存三元组,你可以用哈希也可以用 map。
CODE
#include<set>
#include<map>
#include<queue>
#include<ctime>
#include<cmath>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define MAXN 105
#define ENDL putchar('\n')
#define LL long long
#define DB double
#define lowbit(x) ((-x) & (x))
#define eps 1e-9
LL read() {
LL f = 1,x = 0;char s = getchar();
while(s < '0' || s > '9') {if(s=='-')f = -f;s = getchar();}
while(s >= '0' && s <= '9') {x=x*10+(s-'0');s = getchar();}
return f * x;
}
int n,m,i,j,s,o,k;
struct it{
char l[5],r[5];
LL nm;it(){memset(l,0,sizeof(l));memset(r,0,sizeof(r));nm=0;}
it(char *L,char *R,LL N){
strncpy(l,L,3);nm=N;memset(r,0,sizeof(r));
int le = strlen(R);
for(int i = max(le-3,0),j=0;i < le;i ++,j ++) r[j]=R[i];
}
};
it operator + (it a,it b) {
char ss[10]; int ls; LL as = a.nm+b.nm;
sprintf(ss,"%s%s",a.r,b.l);
ls = strlen(ss);
for(int i = 0;i <= ls-4;i ++) if(ss[i]=='h'&&ss[i+1]=='a'&&ss[i+2]=='h'&&ss[i+3]=='a') as ++;
char rel[10],rer[10];
if(strlen(a.l) < 3) sprintf(rel,"%s%s",a.l,b.l);
else strcpy(rel,a.l);
if(strlen(b.r) < 3) sprintf(rer,"%s%s",a.r,b.r);
else strcpy(rer,b.r);
return it(rel,rer,as);
}
map<string,it> mp;
int main() {
int T = read();
while(T --) {
n = read();
mp.clear();
string las;
for(int i = 1;i <= n;i ++) {
string A,md,B,C;
cin>>A;
las = A;
cin>>md;
if(md[0]==':') {
char ss[15]; int le,as = 0;
scanf("%s",ss); le = strlen(ss);
for(int i = 0;i <= le-4;i ++) {
if(ss[i]=='h'&&ss[i+1]=='a'&&ss[i+2]=='h'&&ss[i+3]=='a') as ++;
}
mp[A] = it(ss,ss,(LL)as);
}
else {
cin>>B;cin>>md;cin>>C;
mp[A] = mp[B] + mp[C];
}
}
printf("%lld\n",mp[las].nm);
}
return 0;
}
[CF1538E] Funny Substrings (模拟)的更多相关文章
- CodeForces 550A Two Substrings(模拟)
[题目链接]click here~~ [题目大意]: You are given string s. Your task is to determine if the given string s ...
- 【CF1029A】Many Equal Substrings(模拟)
题意:给定一个长度为n的串s,要求构造一个长度最小的使s出现了k次的串,可以重叠 n<=50,k<=50 思路:计算一下前后缀相同长度 #include<cstdio> #in ...
- poj 3415 Common Substrings(后缀数组+单调栈)
http://poj.org/problem?id=3415 Common Substrings Time Limit: 5000MS Memory Limit: 65536K Total Sub ...
- Advanced Fruits(好题,LCS的模拟)
Advanced Fruits Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- CF 319D(Have You Ever Heard About the Word?-模拟)
D. Have You Ever Heard About the Word? time limit per test 6 seconds memory limit per test 256 megab ...
- HDU 5908 Abelian Period (BestCoder Round #88 模拟+暴力)
HDU 5908 Abelian Period (BestCoder Round #88 模拟+暴力) 题目链接http://acm.hdu.edu.cn/showproblem.php?pid=59 ...
- Codeforces 626A Robot Sequence(模拟)
A. Robot Sequence time limit per test:2 seconds memory limit per test:256 megabytes input:standard i ...
- Codeforces Round #533 (Div. 2) B. Zuhair and Strings 【模拟】
传送门:http://codeforces.com/contest/1105/problem/B B. Zuhair and Strings time limit per test 1 second ...
- hdu4886 TIANKENG’s restaurant(Ⅱ) (trie树或者模拟进制)
TIANKENG’s restaurant(Ⅱ) Time Limit: 16000/8000 MS (Java/Others) Memory Limit: 130107/65536 K (Ja ...
随机推荐
- Linux免密登陆配置(互信配置)
Linux免密登陆配置(互信配置) 1.生成当前用户的秘钥文件 [oracle@localhost .ssh]$ ssh-keygen -t rsa 2.配置远程登录用户的公钥文件 将公钥文件拷贝至另 ...
- Mac Book安装Windows发烫的问题
Mac Book安装Windows后,电脑发烫,风扇一直高速旋转.针对此问题百度搜索了一下, 大多数人说更改电源选项,由"平衡"模式改为"节能"模式,亲身体验了 ...
- php原生PHPExcel插件导表(附表格合并,加粗居中及加边框换行操作)
PHPExcel是用来操作Office Excel文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言.可以使用它来读取.写入不同格式的电子表格,如 Excel(BIFF) .xls, E ...
- 6000字Locust入门详解
目录 一.Locust 性能测试 (一). 性能测试工具 主流性能测试工具对比 认识Locust (二) locust 基本用法 1.安装locust 2.编写用例 3. 启动测试 GUI 模式启动 ...
- JDBC、ORM、JPA、Spring Data JPA,傻傻分不清楚?一文带你厘清个中曲直,给你个选择SpringDataJPA的理由!
序言 Spring Data JPA作为Spring Data中对于关系型数据库支持的一种框架技术,属于ORM的一种,通过得当的使用,可以大大简化开发过程中对于数据操作的复杂度. 本文档隶属于< ...
- RPA人力资源简历筛选机器人
简历自动筛选及分析机器人,支持前程无忧.猎聘 1.自动登录招聘网站 2.自动填充简历筛选条件 3.RPA依次读取所筛选的简历信息 4.自动将简历数据复制到本地文档中 5.完成简历信息收集及分析表 6. ...
- Docker部署jar包运行
1.上传jar包到服务器 2.在该目录下创建Dockerfile 文件 vi Dockerfile 3.然后将下面的内容复制到Dockerfile文件中 FROM java:8 MAINTAINER ...
- 【问题解决】Alpine镜像中执行jstack、arthas等命令提示Unable to get pid of LinuxThreads manager thread
问题现象 最近在处理项目上问题发现之前同事构建的AlpineLinux的镜像不能执行jstack等JDK命令,报错如下. Unable to get pid of LinuxThreads manag ...
- freeswitch拨打分机号源代码跟踪
概述 freeswitch是一款非常好用的开源VOIP软交换平台. 之前我们有介绍过使用fs拨打分机号的方法,其中代码流程是比较复杂的,所以单独开一章介绍. fs拨打分机号,是使用send_dtmf接 ...
- 30m精度土壤类型、土壤质地、土壤有机质、土壤PH、土壤氮磷钾
数据下载链接:数据下载链接 引言 全国土壤类型.质地.养分及变化等信息产品分为土壤类型数据.土壤质地数据.土壤养分数据及土壤变化数据等.该类产品是基于野外调查和实地采样,结合历史数据,建立全国土壤类 ...