当前位置 : 主页 > 编程语言 > java >

hdu 5532 Almost Sorted Array(最长上升(不下降)子序列和最长下降(不上升)子序列

来源:互联网 收集:自由互联 发布时间:2022-09-02
看了下去年(2015)的长春赛区的题,发现一道比较好玩的题,hdu5532,然后想写一个模板,RT,不说废话,直接上代码: #include bits/stdc++.h using namespace std ; int main () { int T , n , i , j , k ,


看了下去年(2015)的长春赛区的题,发现一道比较好玩的题,hdu5532,然后想写一个模板,RT,不说废话,直接上代码:

#include <bits/stdc++.h>

using namespace std;

int main()
{
int T,n,i,j,k,a[100005],k1,k2,ans[100005],len,b[100005],flag;
scanf("%d",&T);
while(T--)
{
flag=0;
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
memset(ans,0,sizeof(ans));//ans数组存的是最大子序列终点的数字
k1=k2=0;
scanf("%d",&n);
for(i=1; i<=n; i++)
scanf("%d",&a[i]);
//判断是否是上升子序列
ans[1]=a[1];
len=1;
for(i=2; i<=n; i++)
{
if(a[i]>=ans[len])
ans[++len]=a[i];

else
{
int pos=upper_bound(ans+1,ans+len+1,a[i])-ans;
ans[pos]=a[i];
}
}
if(len==n-1||len==n)
{
printf("YES\n");
continue;
}
//判断是否是下降子序列
for(i=1; i<=n; i++)
b[i]=a[n-i+1];
ans[1]=b[1];
len=1;
for(i=2; i<=n; i++)
{
if(b[i]>=ans[len])
ans[++len]=b[i];

else
{
int pos=upper_bound(ans+1,ans+len+1,b[i])-ans;
ans[pos]=b[i];
}
}
if(len==n-1||len==n)
printf("YES\n");
else printf("NO\n");

}
return 0;
}

把不必要的东西删除掉,剩下的就是我们想要的模板



上一篇:欧拉函数板子
下一篇:没有了
网友评论