HDU 5904 LCIS
2024-10-18 22:35:33
$dp$。
这题的突破口在于要求数字是连续的。
可以分别记录两个串以某个数字为结尾的最长上升长度,然后枚举一下以哪个数字为结尾就可以得到答案了。
因为$case$有点多,不能每次$memset$,额外开一个数组记录一下这组$case$中数字有没有出现过。
#pragma comment(linker, "/STACK:1024000000,1024000000")
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<iostream>
using namespace std;
typedef long long LL;
const double pi=acos(-1.0),eps=1e-;
void File()
{
freopen("D:\\in.txt","r",stdin);
freopen("D:\\out.txt","w",stdout);
}
template <class T>
inline void read(T &x)
{
char c=getchar(); x=;
while(!isdigit(c)) c=getchar();
while(isdigit(c)) {x=x*+c-''; c=getchar();}
} const int maxn=;
int dp[*maxn],f[*maxn],n,m;
int s1[*maxn],s2[*maxn]; int main()
{
int T; scanf("%d",&T);
for(int cas=;cas<=T;cas++)
{
dp[]=; f[]=; s1[]=cas; s2[]=cas;
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)
{
int x; scanf("%d",&x);
if(s1[x]<cas) s1[x]=cas, dp[x]=;
if(s1[x-]<cas) dp[x-]=;
dp[x]=max(dp[x],dp[x-]+);
}
int ans=;
for(int i=;i<=m;i++)
{
int x; scanf("%d",&x);
if(s2[x]<cas) s2[x]=cas, f[x]=;
if(s2[x-]<cas) f[x-]=;
f[x]=max(f[x],f[x-]+);
if(s1[x]<cas) dp[x]=;
int pp=min(f[x],dp[x]);
ans=max(ans,pp);
}
printf("%d\n",ans);
}
return ;
}
最新文章
- .NET框架解决的问题
- 【BZOJ】2286: [Sdoi2011消耗战
- 依赖于spring 4.x的spring组件
- Swift翻译之-关于Swift
- js鼠标事件、键盘事件实例代码
- nodejs for centos配置
- 惠普M1005打印机无法自动进纸的问题
- UML用户指南--UML图简介
- C#实现文件数据库
- poj1458 dp入门
- L7,too late
- TP框架 基础1
- H5页面中尝试调起APP
- AIX盘rw_timeout值过小导致IO ERROR
- springCloud项目练习
- java中的String整理
- Sqlite3并发读写注意事项
- zabbix 添加被监控主机
- Android 组件系列-----Activity初步
- DefinePlugin插件
热门文章
- SugarSync的API总结
- Java:终结器
- web前端学习笔记
- ios学习之category设计模式
- WCF引用方式
- appfog java jdbc mysql连接
- python cookbook学习1
- xls===>;csv tables===via python ===>; sqlite3.db
- 【Chrome】如何在C++中增加给JavaScript调用的API
- ASP.NET Zero--5.配置权限