思路:经典贪心问题,从前往后扫描原数组,每到一个数,找个当前最大值最大的不降数组加入其中,否则新建一个不降数组。
#include <bits/stdc++.h>
#define N 10000
#define LL long long
#define U unsigned
using namespace std;
int cas=1,T;
int n,a[N+10],len[N+10];
bool cmp(const int&a,const int &b)
{
return a>b;
}
int main()
{
//freopen("1.in","w",stdout);
//freopen("1.in","r",stdin);
//freopen("1.out","w",stdout);
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
int k=0;
for(int i=0,x;i<n;i++)
{
scanf("%d",&x);
if(k==0||x<len[k-1]) len[k++]=x;
else *lower_bound(len,len+k,x,cmp)=x;
}
printf("%d\n",k);
}
//printf("time=%.3lf",(double)clock()/CLOCKS_PER_SEC);
return 0;
}
Description
将一个给定的数列,拆分成K个不降序列,每个数出现且只出现一次,且在各序列中各个数相对于原数列的相对顺序不变。
如7 6 9 8 10可以拆成 7 9 10和6 8。求最小的K值。
Input
第一行输入一个整数T(1 <= T <= 100),表示接下来T组测试数据,
每组两行,第一行为n,代表数列长度(1<=n<=10000)
接下来一行有n个数,空格分隔(每个数<=50000)。
Output
对每组数据输出一个最小的K值。
Sample Input
2
5
7 6 9 8 10
5
5 4 3 2 1
Sample Output
2
5