最长上升子序列。虽然数据可以直接n方但是另写了个nlogn的

转移:f[i]=max(f[j]+1)(a[j]<a[i])

O(n^2)

#include<iostream>
#include<cstdio>
using namespace std;
const int N=5005;
int n,a[N],f[N],ans;
int read()
{
int r=0,f=1;
char p=getchar();
while(p>'9'||p<'0')
{
if(p=='-')
f=-1;
p=getchar();
}
while(p>='0'&&p<='9')
{
r=r*10+p-48;
p=getchar();
}
return r*f;
}
int main()
{
n=read();
for(int i=1;i<=n;i++)
a[i]=read();
for(int i=1;i<=n;i++)
{
for(int j=0;j<i;j++)
if(a[j]<a[i]&&f[j]+1>f[i])
f[i]=f[j]+1;
ans=max(ans,f[i]);
}
printf("%d\n",ans);
return 0;
}

O(nlogn)树状数组+hash

#include<iostream>
#include<cstdio>
#include<map>
#include<algorithm>
using namespace std;
const int N=5005;
int n,a[N],f[N],ans,g[N],t[N];
map<int,int>mp;
int read()
{
int r=0,f=1;
char p=getchar();
while(p>'9'||p<'0')
{
if(p=='-')
f=-1;
p=getchar();
}
while(p>='0'&&p<='9')
{
r=r*10+p-48;
p=getchar();
}
return r*f;
}
inline int lb(int x)
{
return x&(-x);
}
void update(int x,int v)
{
for(int i=x;i<=n;i+=lb(i))
t[i]=max(t[i],v);
}
int ques(int x)
{
int re=0;
for(int i=x;i>=1;i-=lb(i))
re=max(re,t[i]);
return re;
}
int main()
{
n=read();
for(int i=1;i<=n;i++)
a[i]=g[i]=read();
sort(g+1,g+1+n);
for(int i=1;i<=n;i++)
mp[g[i]]=i;
for(int i=1;i<=n;i++)
a[i]=mp[a[i]];
for(int i=1;i<=n;i++)
{
f[i]=ques(a[i]-1)+1;
update(a[i],f[i]);
ans=max(ans,f[i]);
}
printf("%d\n",ans);
return 0;
}

最新文章

  1. 【代码笔记】iOS-柱状图
  2. css实现三角形箭头
  3. 博客CSS
  4. [logstash-input-log4j]插件使用详解
  5. .net开发windows服务小结
  6. 天猫浏览型应用的CDN静态化架构演变
  7. 解决Cannot change version of project facet Dynamic Web M
  8. MySql避免重复插入记录方法(ignore,Replace,ON DUPLICATE KEY UPDATE)
  9. Part 92 Significance of Thread Join and Thread IsAlive functions
  10. C# 白话系列之——白话委托
  11. 将android中的sample例子到eclipse中
  12. easyui-tree绑定数据的几种方式
  13. javascript之window对象
  14. BZOJ 3295: [Cqoi2011]动态逆序对 [CDQ分治]
  15. win10安装Oracle11g-出现INS-13001环境不满足最低要求问题
  16. 基于继承的 MethodInterceptor 动态代理(换种写法)
  17. mybatis四大接口之 ResultSetHandler
  18. Axure响应式进阶
  19. FAQ of db2fmp messages in the db2diag.log
  20. 收集整理mysql数据库设计规范与原则

热门文章

  1. L2-001. 紧急救援 (Dijkstra算法打印路径)
  2. hihoCoder#1082 然而沼跃鱼早就看穿了一切
  3. cdq分治入门--BZOJ1176: [Balkan2007]Mokia
  4. zset(sorted set:有序集合)数据类型【八】
  5. android view自定义
  6. codeforces Gym 100814 A、B、F、I
  7. UVA 1025_A Spy in the Metro
  8. TCP/IP学习笔记(3)----IP,ARP,RARP协议
  9. MongoDB C#驱动
  10. FlashChart json数据配置 中文文档