HDU 4521 小明系列问题――小明序列 (DP)
来源:互联网 发布:淘宝手机开店确认协议 编辑:程序博客网 时间:2024/05/22 17:45
这个题解法花样,这里说单纯DP的做法。
根据题意很容易想到最长递增子序列,回顾nlogn的二分做法。
dp[i]为长度为i+1的子序列的末尾元素的最小值。每加入a[i]时对应的值就是以a[i]结尾的最大长度。
假设b[i]为以a[i]结尾的最大长度,dp[]中已经加入了a[0]....a[i-d-1],那么b[i] = lower_bound(dp,dp+maxn,a[i])-dp+1。
求出b[i]后要把a[i-d]加入到dp数组中,注意不能直接加入,不然就不满足序列各元素距离都大于d的要求,
前面已经求出了a[i-d]的位置,在相应位置插入到dp数组中就好。
我的代码:
#include<cstdio>#include<algorithm>#include<iostream>#include<cstring>using namespace std;const int maxn = 200005;const int INF = 0x3f3f3f3f;int n,d,dp[maxn],a[maxn],b[maxn];int main(){ while(~scanf("%d%d",&n,&d)){ for(int i=0;i<n;i++){ scanf("%d",&a[i]);b[i] = 1; } fill(dp,dp+maxn,INF); int ans = 1; for(int i=d;i<n;i++){ b[i] = lower_bound(dp,dp+maxn,a[i])-dp+1; ans = max(ans,b[i]); dp[b[i-d]-1] = min(dp[b[i-d]-1],a[i-d]); } printf("%d\n",ans); } return 0;}
0 0
- HDU 4521 小明系列问题――小明序列 (DP)
- HDU - 4521 小明系列问题――小明序列 (LIS&DP)好题
- 【HDU】4521 小明系列问题——小明序列 线段树+DP
- HDU 4521 小明系列问题——小明序列 (线段树维护DP)
- 小明系列问题——小明序列 - HDU 4521 DP
- HDU 4521 小明系列问题——小明序列 (DP)
- HDU - 4521 小明系列问题――小明序列 (存在间隔的LIS)
- HDU 4521 小明系列问题——小明序列【dp+线段树优化||最长递增序列】
- HDU 4521 小明系列问题——小明序列 DP – LIS加强版 #by Plato
- hdu 4521 小明系列问题——小明序列(线段树+DP或扩展成经典的LIS)
- hdu 小明系列问题——小明序列
- hdu 4521 小明系列问题——小明序列(线段树)
- hdu 4521 小明系列问题——小明序列(单点更新)
- 线段树(端点更新) hdu-4521 小明系列问题——小明序列
- hdu 4521 小明系列问题——小明序列
- HDU 4521 小明系列问题——小明序列
- HDU 4521 小明系列问题——小明序列
- 小明系列问题——小明序列 - HDU 4521 线段树
- (九十八)通讯录的访问和修改
- 我跟敏捷开发的故事--三面墙
- 云存储基础架构剖析
- 老菜鸟致青春,程序员应该选择java 还是 c#
- HLSL效果框架实例之高斯模糊
- HDU 4521 小明系列问题――小明序列 (DP)
- [V1.0]小木虫路径搜索问题C语言处理方案
- C#桌面办公应用-工资管理系统系列一
- 用手机调试Android手机连上没反应解决办法
- excel导入MySQL 学习
- li:hover{ color: #ffffff; }
- 神经网络-并行BP算法
- java中使用日志组件和mysql数据库
- 平面向量