SP9098 LCS3
题目链接
题意分析
\(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的更多相关文章
- (5千字)由浅入深讲解动态规划(JS版)-钢条切割,最大公共子序列,最短编辑距离
斐波拉契数列 首先我们来看看斐波拉契数列,这是一个大家都很熟悉的数列: // f = [1, 1, 2, 3, 5, 8] f(1) = 1; f(2) = 1; f(n) = f(n-1) + f( ...
随机推荐
- 基于python的Appium自动化测试的坑
真的感谢@虫师 这位来自互联网的老师,让我这个原本对代码胆怯且迷惑的人开始学习自动化测试. 一开始搜索自动化测试的时候,虫师的博客园教程都是在百度的前几位的,我就跟着虫师博客园里面的教程学习.后来学s ...
- MongoDB C# 驱动教程
C# 驱动版本 v1.6.x 本教程基于C#驱动 v1.6.x . Api 文档见此处: http://api.mongodb.org/csharp/current/. 简介 本教程介绍由10gen支 ...
- R学习笔记-安装R和RStudio,注意RStudio的版本需要与操作系统版本匹配
1.安装步骤:先安装R,再安装RStudio RStudio是R的集成开发工具,本身不带R环境. 2.从当前R的官网和RStudio下载的R和RStudio的版本分别为: A .For Windows ...
- 通过curl模拟多线程抓取网页(curl_multi_*)
curl请求多个url,以前都是使用循环来处理.最近发现可以通过curl_multi_*系列函数来模拟多线程.比对一下,发现如果请求的url只有几个,2种方案耗时差不多,但是url比较多,差距就非常明 ...
- MVC知识记录
1.完整深入分析 MVC请求机制:http://blog.jobbole.com/85033/ 2.MVC入门:http://www.aizhengli.com/givecase-aspnet-5-m ...
- MySQL数据库远程连接的配置方案
首先,目的是使用本机可视化工具SQLyog通过IP地址远程访问另一台机器上的MySQL数据库. 本人实践的MySQL版本是MySQL 5.7.23,数据库部署的主机系统是Windows.这些简单配置均 ...
- 1.oracle dblink(数据库不同实例数据对导)
.创建一个两个数据库之间的dblink,语法如下 create database link to_test connect to scott identified by tiger using '(D ...
- 使用junit单元测试SpringMvc
对于有依赖关系的方法,junit测试会有些麻烦,可以用@before @after之类的创建数据库连接,然后进行测试,但是有些太麻烦了. 所以就使用一下这个:org.springframework.t ...
- 13 Calculating Expected Offspring
Problem For a random variable XX taking integer values between 1 and nn, the expected value of XX is ...
- 【工具推荐】ELMAH——可插拔错误日志工具(转)
出处:http://www.cnblogs.com/liping13599168/archive/2011/02/23/1962625.html 今天看到一篇文章(构建ASP.NET网站十大必备工具( ...