【BZOJ1489】[HNOI2009]双递增序列(动态规划)
2023-09-11 14:14:40 时间
【BZOJ1489】[HNOI2009]双递增序列(动态规划)
题面
题解
这\(dp\)奇奇怪怪的,设\(f[i][j]\)表示前\(i\)个数中,第一个数列选了\(j\)个数,第二个数列的最大值的最小情况。
那么转移如下,如果\(a_i>a_{i-1}\),那么可以直接接在第一个序列后面,\(f[i][j]=f[i-1][j-1]\)
然后考虑怎么样接在第二个序列后面,如果\(a_i>f[i-1][i-j]\),那么就可以接在第二个序列后面,即从前\(i-1\)个位置中,有一个序列的长度为\(i-j\)(第二个序列),那么我就可以把它接在这个序列后面。
这\(dp\)奇奇怪怪,我自己都觉得上面说得好假啊。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define MAX 2050
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
int n,a[MAX];
int f[MAX][MAX];
int main()
{
int T=read();
while(T--)
{
n=read();for(int i=1;i<=n;++i)a[i]=read();
memset(f,63,sizeof(f));f[0][0]=-1;a[0]=-1;
for(int i=1;i<=n;++i)
for(int j=0;j<=i&&j<=n/2;++j)
{
if(f[i-1][i-j]<a[i])f[i][j]=min(f[i][j],a[i-1]);
if(a[i]>a[i-1])f[i][j]=min(f[i][j],f[i-1][j]);
}
puts(f[n][n/2]<1e9?"Yes!":"No!");
}
return 0;
}
相关文章
- python序列中是否包含某个元素
- python投票统计程序,统计序列中各个数值的份数,字典的应用。
- python 序列排序 排序后返回相应的索引
- Python 序列、列表(List)、元组(Tuple)
- 【BZOJ1046】上升序列(动态规划,贪心)
- 【BZOJ2962】序列操作(线段树)
- 【BZOJ3992】序列统计(动态规划,NTT)
- 地球引擎中级教程——时间序列图表(指定区域NDVI值的计算)(含综合练习)
- 【logistic-map混沌】一种基于logistic-map的混合混沌序列的图像加解密算法仿真
- [转]MySQL如何设置自动增长序列 SEQUENCE
- oracle自增序列创建
- 简单创建序列和触发器示例
- 《剑指offer》-- 和为S的连续整数序列、和为S的两个数字、左旋转字符串、翻转单词顺序列
- LeetCode1143之最长公共子序列和最长公共子串(相关话题:动态规划)
- 179、【动态规划】leetcode ——115. 不同的子序列(C++版本)
- 178、【数组/动态规划】leetcode ——392. 判断子序列:双指针+动态规划(C++版本)
- 173、【动态规划】leetcode ——300. 最长递增子序列 (C++版本)
- 洛谷 P1628 合并序列
- 动态规划-子序列问题(判断子序列、不同的子序列、两个字符串的删除操作、编辑距离、回文子串、最长回文子序列)
- nyoj 214-单调递增子序列(二) (演算法,PS:普通的动态规划要超时)
- leetcode 594. Longest Harmonious Subsequence 最长和谐子序列(简单).md