题目链接

题意分析

\(olinr\) : 序列自动机+一系列的鬼畜操作

相信我 你们没人能切

\(lzxkj\) : \(2^m+vector+\)暴力二分 跑得比你正解还快

首先一看\(m≤5\) 直接\(2^m\)枚举所有的子序列

然后我们用一个\(vector\)把匹配序列中的权值相同的位置存入一个\(vector\)

匹配当前值的时候 直接二分找到刚好可以满足的位置就可以了

复杂度\(O(q* 2^m* m* log_n)\)(应该远不及上界)

CODE:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdlib>
#include<string>
#include<queue>
#include<map>
#include<stack>
#include<list>
#include<set>
#include<deque>
#include<vector>
#include<ctime>
#define ll long long
#define inf 0x7fffffff
#define N 508
#define IL inline
#define M 1008611
#define D double
#define ull unsigned long long
#define R register
using namespace std;
template<typename T>IL void read(T &_)
{
T __=0,___=1;char ____=getchar();
while(!isdigit(____)) {if(____=='-') ___=0;____=getchar();}
while(isdigit(____)) {__=(__<<1)+(__<<3)+____-'0';____=getchar();}
_=___ ? __:-__;
}
/*-------------OI使我快乐-------------*/
int n,m,len,ans1,maxn,ans2;
int num[M],key[N],lg[N],tmp[N];
vector<int> G[M];
vector<int>::iterator it;
IL int getlen(int x)
{int res=0;for(;x;x-=x&-x) res++;return res;}
IL bool check(int x)
{
int pos=0;
for(;x;x-=x&-x)
{
int now=lg[x&-x]+1;
it=upper_bound(G[key[now]].begin(),G[key[now]].end(),pos);
if(it==G[key[now]].end()) return 0;
else pos=*it;
}
return 1;
}
IL void comp(int &x,int y)
{
int cdy=x,wzy=y;
for(;cdy&&wzy;cdy-=cdy&-cdy,wzy-=wzy&-wzy)
{
int nowx=lg[cdy&-cdy]+1,nowy=lg[wzy&-wzy]+1;
if(key[nowx]>key[nowy]) {x=y;return;}
else if(key[nowx]<key[nowy]) return;
}
}
int main()
{
// freopen("flag.in","r",stdin);
// freopen("flag.out","w",stdout);
read(n);
for(R int i=1;i<=n;++i)
{
read(num[i]);
G[num[i]].push_back(i);
maxn=max(maxn,num[i]);
}
for(R int i=0;i<=6;++i) lg[1<<i]=i;
read(m);
while(m--)
{
int len,tmp=0;ans1=0;ans2=0;read(len);
for(R int i=1;i<=len;++i) read(key[i]);
for(R int i=0;i<(1<<len);++i)
{ if(check(i))
{
int tmp=getlen(i);
if(tmp>ans1) ans1=tmp,ans2=i;
else if(ans1==tmp) ans1=tmp,comp(ans2,i);
}
}
printf("%d ",ans1);
for(R int i=1;i<=len;++i)
if((1<<(i-1))&ans2) printf("%d ",key[i]);puts("");
}
// fclose(stdin);
// fclose(stdout);
return 0;
}

HEOI 2019 RP++

SP9098 LCS3的更多相关文章

  1. (5千字)由浅入深讲解动态规划(JS版)-钢条切割,最大公共子序列,最短编辑距离

    斐波拉契数列 首先我们来看看斐波拉契数列,这是一个大家都很熟悉的数列: // f = [1, 1, 2, 3, 5, 8] f(1) = 1; f(2) = 1; f(n) = f(n-1) + f( ...

随机推荐

  1. UNITY5 为什么Inspector视图中脚本前面的勾选框没了

    结果发现了一个奇葩的问题..凡事脚本没有勾选项的,都是因为你的脚本没有Start方法..如果你想让勾选框显示出来,把如下方法加入即可,不信你可以试试.嘿嘿.

  2. Django基础学习一

    Django需要安装Django和jinja2,所以在开始学习之前,要先按照Django模块和jinja2模块,Django默认的数据库是SQLite,所以建议大家在学习之前需要先安装SQLite 一 ...

  3. CodeForces 688B Lovely Palindromes (水题回文)

    题意:给一个数n,让你找出长度为偶数,并且是第 n 个回文数. 析:你多写几个就知道了,其实就是 n,然后再加上n的逆序,不过n有点大,直接用string 好了. 代码如下: #include < ...

  4. linux每天一小步---tail命令详解

    1 命令功能 tail命令用于显示文件中末尾的内容(默认显示最后10行内容) 2 命令语法 tail [选项参数] [文件名1] [文件名2] 3 命令参数 -f  用于循环读取文件的内容,监视文件的 ...

  5. POJ1789 Truck History 2017-04-13 12:02 33人阅读 评论(0) 收藏

    Truck History Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 27335   Accepted: 10634 D ...

  6. 3D 相关

    1. STL 2. AMF 3. X3D 网址: http://www.web3d.org/x3d-resources/content/examples/X3dResources.html

  7. Java Float类型 减法运算时精度丢失问题

    package test1; public class Test2 { /*** @param args*/public static void main(String[] args) {   Flo ...

  8. Java8接口中的默认方法

    Java8新增特性,可以为接口中添加默认方法,实现这个接口的所有类都会继承这个方法,这样看起来,接口和类的界限就有点不明显了,同时也会带来多继承,菱形问题.这样设计的初衷是什么? 重所周知,java8 ...

  9. DELPHI如何获取某目录下的所有文件名?

    //=====================================================================// 函数名称: FindPathFiles// 功能描述 ...

  10. ajax 调用示例

    $.ajax({ type: "post", url: url, data: { "key": "ValidateMobile", &quo ...