bzoj 1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛【dp+树状数组+hash】
2024-09-30 19:15:00
最长上升子序列。虽然数据可以直接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;
}
最新文章
- 【代码笔记】iOS-柱状图
- css实现三角形箭头
- 博客CSS
- [logstash-input-log4j]插件使用详解
- .net开发windows服务小结
- 天猫浏览型应用的CDN静态化架构演变
- 解决Cannot change version of project facet Dynamic Web M
- MySql避免重复插入记录方法(ignore,Replace,ON DUPLICATE KEY UPDATE)
- Part 92 Significance of Thread Join and Thread IsAlive functions
- C# 白话系列之——白话委托
- 将android中的sample例子到eclipse中
- easyui-tree绑定数据的几种方式
- javascript之window对象
- BZOJ 3295: [Cqoi2011]动态逆序对 [CDQ分治]
- win10安装Oracle11g-出现INS-13001环境不满足最低要求问题
- 基于继承的 MethodInterceptor 动态代理(换种写法)
- mybatis四大接口之 ResultSetHandler
- Axure响应式进阶
- FAQ of db2fmp messages in the db2diag.log
- 收集整理mysql数据库设计规范与原则
热门文章
- L2-001. 紧急救援 (Dijkstra算法打印路径)
- hihoCoder#1082 然而沼跃鱼早就看穿了一切
- cdq分治入门--BZOJ1176: [Balkan2007]Mokia
- zset(sorted set:有序集合)数据类型【八】
- android view自定义
- codeforces Gym 100814 A、B、F、I
- UVA 1025_A Spy in the Metro
- TCP/IP学习笔记(3)----IP,ARP,RARP协议
- MongoDB C#驱动
- FlashChart json数据配置 中文文档