牛客-富豪凯匹配串(bitset)
题目传送门
sol1:用bitset来维护,其实感觉挺暴力的,不怎么会用bitset,借着这道题学习一下。
- bitset暴力维护
#include "bits/stdc++.h"
#define debug puts("what the fuck");
using namespace std;
const int MAXN = ;
char s[MAXN];
bitset<> bs[][MAXN];
int main() {
int n, m, q;
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++) {
scanf("%s", s + );
for (int j = ; s[j]; j++)
bs[s[j] ^ ''][j][i] = ;
}
scanf("%d", &q);
for (int i = ; i <= q; i++) {
scanf("%s", s + );
bitset<> res;
res.set();
for (int j = ; s[j]; j++) {
if (s[j] == '_') continue;
res &= bs[s[j] ^ ''][j];
}
printf("%d\n", res.count());
}
return ;
}
sol2:一开始做这题,看到能有多少个匹配上的字符串联想到的是字典树,但是不断优化还是超时。然后跟一位网友学到了开两颗字典树然后匹配的方法。
- 字典树
#include "bits/stdc++.h"
using namespace std;
#define debug puts("what the fuck");
typedef long long LL;
typedef pair<int, int> PII;
const int INF = 0x3f3f3f3f;
const int MOD = 1e9 + ;
const int MAXNODE = 3e6 + ;
const int MAXN = ;
int cnt[MAXNODE], ans[MAXNODE];
int res[MAXN];
vector<int> q[MAXNODE];
struct Trie {
int son[MAXNODE][];
int tot;
void insert(char* s, int v, int op) {
// puts(s);
int p = ;
for (int i = ; s[i]; i++) {
int id = (s[i] == '_') ? : s[i] ^ '';
if (!son[p][id]) son[p][id] = ++tot;
p = son[p][id];
// printf("\t%d %c", p, s[i]);
}
// puts("");
if (op == ) cnt[p] += v;
else q[p].push_back(v);
}
} t1, t2;
char s[MAXN];
void merge(int p1, int p2, int p, int m) {
if (p == m) {
ans[p2] += cnt[p1];
// printf("\t %d %d\n", p1, p2);
return;
}
if (t2.son[p2][] && t1.son[p1][]) merge(t1.son[p1][], t2.son[p2][], p + , m);
if (t2.son[p2][] && t1.son[p1][]) merge(t1.son[p1][], t2.son[p2][], p + , m);
if (t2.son[p2][]) {
if (t1.son[p1][]) merge(t1.son[p1][], t2.son[p2][], p + , m);
if (t1.son[p1][]) merge(t1.son[p1][], t2.son[p2][], p + , m);
}
}
int main() {
int n, m, qq;
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++) {
scanf("%s", s);
t1.insert(s, , );
}
scanf("%d", &qq);
for (int i = ; i <= qq; i++) {
scanf("%s", s);
t2.insert(s, i, );
}
merge(, , , m);
for (int i = ; i <= t2.tot; i++) {
for (auto index : q[i]) {
res[index] = ans[i];
}
}
for (int i = ; i <= qq; i++)
printf("%d\n", res[i]);
return ;
}代码妙在离线后的匹配最多只要把两颗字典树都跑一边,复杂度应该是两颗字典树的节点数。网上看到另一种字典树写法分类讨论,如果询问中'_'的 个数小于20就用暴力,感觉在卡数据,不过比赛的时候这种投机的方法也未尝不可。
牛客-富豪凯匹配串(bitset)的更多相关文章
- 牛客练习赛53 (C 富豪凯匹配串) bitset
没想到直接拿 bitset 能过 $10^8$~ code: #include <bits/stdc++.h> #define N 1004 #define setIO(s) freope ...
- 牛客练习赛53 C 富豪凯匹配串
思路: bitset的简单题,不幸的是当时的我并不知道bitset, C++的 bitset 在 bitset 头文件中,它是一种类似数组的结构,它的每一个元素只能是0或1,每个元素仅用1bit空间, ...
- 牛客练习赛53 C题bitset
题目链接https://ac.nowcoder.com/acm/contest/1114/C #include<bits/stdc++.h> using namespace std; #d ...
- 牛客练习赛53 A-E
牛客联系赛53 A-E 题目链接:Link A 超越学姐爱字符串 题意: 长度为N的字符串,只能有C,Y字符,且字符串中不能连续出现 C. 思路: 其实就是DP,\(Dp[i][c]\) 表示长度为 ...
- 牛客小白月赛13 小A的回文串(Manacher)
链接:https://ac.nowcoder.com/acm/contest/549/B来源:牛客网 题目描述 小A非常喜欢回文串,当然我们都知道回文串这种情况是非常特殊的.所以小A只想知道给定的一个 ...
- 牛客网剑指Offer——正则表达式匹配
1. 题目描述 请实现一个函数用来匹配包括'.'和'*'的正则表达式.模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次). 在本题中,匹配是指字符串的所有字符匹配整 ...
- 牛客寒假算法基础集训营4 I Applese 的回文串
链接:https://ac.nowcoder.com/acm/contest/330/I来源:牛客网 自从 Applese 学会了字符串之后,精通各种字符串算法,比如……判断一个字符串是不是回文串. ...
- 2019牛客多校第四场 I题 后缀自动机_后缀数组_求两个串de公共子串的种类数
目录 求若干个串的公共子串个数相关变形题 对一个串建后缀自动机,另一个串在上面跑同时计数 广义后缀自动机 后缀数组 其他:POJ 3415 求两个串长度至少为k的公共子串数量 @(牛客多校第四场 I题 ...
- 好串_via牛客网
题目 链接:https://ac.nowcoder.com/acm/contest/28537/C 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言 ...
随机推荐
- 剑指offer第40题
package com.yan.offer; /** * 题目描述: * * 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. * * @author Ya ...
- List、Set和Map详解及其区别和他们分别适用的场景
Java中的集合包括三大类 它们是Set(集).List(列表)和Map(映射),它们都处于java.util包中,Set.List和Map都是接口,它们有各自的实现类.Set的实现类主要有HashS ...
- 【每日Scrum】第五天冲刺
一.计划会议内容 仍然在解决数据库问题 二.任务看板 三.scrum讨论照片 四.产品的状态 无 五.任务燃尽图
- VMware DRS部分知识点
主机添加到集群中,不需要维护模式(有虚拟机开机状态时也可以添加进去). 主机从集群中移除,需要主机进入维护模式. HA和DRS 全自动 当设置虚拟机必须在主机上时 DRS优先级大于HA 就算主机挂了H ...
- SpringContextHolder类
1.通常使用SpringContextHolder类获取bean实例: 解决: 如果要在静态方法中调用某一bean的方法,那么该bean必须声明为static的,但正常情况下@Autowired无法注 ...
- Linux CMD 笔记 & 正则表达式
一.linux bash 1. 进程名查找kill ps -ef | grep xxxx| grep -v grep| cut -c 9-15 | xargs kill -9 2.端口号kill 占用 ...
- scala快排
笔记积累,直接看代码吧,sublime上运行的 def quickSort(ls:List[Int]):List[Int]={ if (ls.isEmpty) ls else quickSort(ls ...
- 将QT窗口嵌入到WinForm窗口
要想 windows下抓取Qt进程主界面,并嵌入到自己的程序中显示,需要首先设置qt窗口的windowTitle属性,然后就可以通过 windows api 中的 FindWindow 函数查找到窗口 ...
- Ubuntu上运行tensorflow C++的完整例子
个人博客原文:http://www.bearoom.xyz/2019/08/25/ubuntu-tensorflow-cc-example/ 之前记录的运行Tensorflow的C++接口的例子都是零 ...
- ImageTag,图片左上侧有一个小标签
这实现思路其实很简单 需求:1. 图片比原来的<div>大,需要切割图片.2. 图片左上角显示标签 解决思路: 1. 把照片设置成div的backgroundImage,然后用CSS3切割 ...