前言

先是这位神仙写了这道题 \(O(n\log n)\) 的做法。然后去他的博客上恰了一波。

然后发现这道题有 \(O(n)\) 的做法的。其实也不难。

题目

题目链接:https://www.luogu.com.cn/problem/P3500

分别判断多个序列是否是另外一个序列删除若干个数字之后得到的。

思路

考虑暴力。对于每一个询问,我们都维护两个指针,分别扫描原串 \(a\) 和询问的串 \(b\)。如果 \(a[i]=b[j]\),那么两个指针都往后扫,否则仅 \(a\) 的指针往后扫即可。

时间复杂度 \(O(nm)\)。

容易发现,其实没必要对于每一个询问的串都扫描一次 \(a\),我们其实可以只扫描一次 \(a\),对于 \(a\) 的每一位,分别去匹配每一个 \(b\) 即可。

具体一点,设一个串 \(b_i\) 的前 \(x\) 位都被扫完并比配了,我们就需要在 \(a\) 串中找到下一个 \(b_i[x+1]\) 的位置。

扫描 \(a\) 串,设现在扫描到第 \(i\) 位,\(b_i\) 串已经匹配完前 \(num_i\) 个位置了。那么所有 \(a_i=b_j[num_j]\) 的 \(b_j\) 第 \(num_j\) 位就匹配上了,对于这些 \(b_j\),我们将 \(num_j\) 加一即可。

如何求出扫描到第 \(i\) 位时有哪些 \(b\) 串满足正好需要匹配 \(a_i\) 呢?用 \(\operatorname{vector}\) 即可。设 \(pos[x]\) 表示现在需要匹配数字 \(x\) 的 \(b\) 串有哪些,对于 \(a_i=k\),我们将 \(pos[k]\) 里面的 \(b\) 全部往下匹配一个位置即可。

时间复杂度 \(O(n)\)。具体一点 \(O(n+\sum^{m}_{i=1}len[i])\)。其中 \(len[i]\) 表示第 \(i\) 个 \(b\) 串的长度。

代码

#include <cstdio>
#include <vector>
#include <cctype>
#include <cstring>
#include <algorithm>
#define mp make_pair
using namespace std; const int N=1000010;
int n,m,len,a[N],b[N],st[N];
bool ans[N];
vector<pair<int,int> > pos[N],cpy; int read()
{
int d=0,f=1; char ch=getchar();
while (!isdigit(ch)) f=ch=='-'?-1:f,ch=getchar();
while (isdigit(ch)) d=(d<<1)+(d<<3)+ch-48,ch=getchar();
return f*d;
} int main()
{
n=read();
for (int i=1;i<=n;i++)
a[i]=read();
m=read();
for (int i=1,x;i<=m;i++)
{
x=read(); st[i]=len+1;
for (int j=1;j<=x;j++)
b[++len]=read();
pos[b[st[i]]].push_back(mp(i,st[i]));
}
st[m+1]=len+1;
for (int i=1;i<=n;i++)
{
cpy.clear();
for (int j=0;j<pos[a[i]].size();j++)
{
int k=pos[a[i]][j].first,p=pos[a[i]][j].second;
if (p+1==st[k+1]) ans[k]=1;
else cpy.push_back(mp(k,p+1));
}
pos[a[i]].clear();
for (int j=0;j<cpy.size();j++)
{
int k=cpy[j].first,p=cpy[j].second;
pos[b[p]].push_back(mp(k,p));
}
}
for (int i=1;i<=m;i++)
if (ans[i]) printf("TAK\n");
else printf("NIE\n");
return 0;
}

【洛谷P3500】TES-Intelligence Test的更多相关文章

  1. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  2. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

  3. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  4. 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP

    题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...

  5. 洛谷P1710 地铁涨价

    P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交  讨论  题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...

  6. 洛谷P1371 NOI元丹

    P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交  讨论  题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...

  7. 洛谷P1538迎春舞会之数字舞蹈

    题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...

  8. 洛谷八月月赛Round1凄惨记

    个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...

  9. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

随机推荐

  1. 【C语言】利用二维数组输出成绩

    目的:用二维数组输出下面成绩 希望你可以成为第五名童鞋! 代码: #include<stdio.h> int main() { /* 创建一个带有 4行 5 列的数组 */ ][] = { ...

  2. vue工程 使用滚动组件 vue2-better-scroll 实现上拉加载 下拉刷新

    vue2-better-scroll 关于具体安装&使用过程 请移步api文档 已经很详细了 而且超清晰明了. https://cnpmjs.org/package/vue2-better-s ...

  3. 【转载】Java泛型(一)

    转自:http://www.cnblogs.com/lzq198754/p/5780426.html 1.为什么需要泛型 泛型在Java中有很重要的地位,网上很多文章罗列各种理论,不便于理解,本篇将立 ...

  4. static的使用总结

    全局静态变量 全局变量前加上关键字static,全局变量就定义成一个全局静态变量.,全局静态变量存储在静态存储区,在整个程序运行期间一直存在.全局静态变量在程序运行之前就存在. 初始化:未经初始化的全 ...

  5. 把jar包部署为linux服务

    一直未配置成功,直到放弃后reboot了下,才直到错的不是自己的配置,而是自己不懂 1.在touch /etc/rc.d/init.d/tl_c_cons_service(创建新文件) 2.vi /e ...

  6. HBase 启动后HMaster进程自动消失

    原因分析 1.hadoop 与 hbase 版本不兼容,导致的异常. 2.log日志信息显示 org.apache.hadoop.hbase.TableExistsException: hbase:n ...

  7. 【C语言】写一个函数,并调用该函数求两个整数的最大公约数和最小公倍数

    程序分析: 在数学中,两个数的最小公倍数=两个数的乘积/两数的最大公约数. 求两个数的最大公约数,运用辗转相除法:已知两个整数M和N,假定M>N,则求M%N. 如果余数为0,则N即为所求:如果余 ...

  8. 每天进步一点点------CORDIC (一)

    三角函数计算,Cordic 算法入门 三角函数的计算是个复杂的主题,有计算机之前,人们通常通过查找三角函数表来计算任意角度的三角函数的值.这种表格在人们刚刚产生三角函数的概念的时候就已经有了,它们通常 ...

  9. XFire客户端调用CXF服务端(四)

    前面章节:http://www.cnblogs.com/xiehongwei/p/8082337.html 已经开发出了CXF服务端,现在用XFire开发客户端调用CXF服务端,代码如下: impor ...

  10. STM32F103之GPIO学习记录

    9 GPIO:通用I/O口 AFIO:可供选择的I/O口 9.1 GPIO功能描述 每一个通用的I/O口都有: 两个32位的配置寄存器(配置寄存器低和配置寄存器高): 两个32位的数据寄存器(输入数据 ...