标签:
可以用二分写...
第1行:1个数N,N为序列的长度(2 <= N <= 50000) 第2 - N + 1行:每行1个数,对应序列的元素(-10^9 <= S[i] <= 10^9)
输出最长递增子序列的长度。
8 5 1 6 8 2 4 5 10
5
1 #include <cstdio> 2 #include <cmath> 3 #include <cstring> 4 #include <string> 5 #include <algorithm> 6 #include <queue> 7 #include <stack> 8 #include <map> 9 #include <set> 10 #include <vector> 11 #include <iostream> 12 using namespace std; 13 #define for0(i, n) for(int i=0; i<(n); ++i) 14 #define for1(i,a,n) for(int i=(a);i<=(n);++i) 15 #define for2(i,a,n) for(int i=(a);i<(n);++i) 16 #define for3(i,a,n) for(int i=(a);i>=(n);--i) 17 #define for4(i,a,n) for(int i=(a);i>(n);--i) 18 #define CC(i,a) memset(i,a,sizeof(i)) 19 #define LL long long 20 #define MOD 1000000007 21 #define INF 0x3f3f3f3f 22 #define MAX 50100 23 24 int dp[MAX],num[MAX]; 25 int n; 26 27 int main() 28 { 29 scanf("%d",&n); 30 memset(dp,INF,sizeof(dp)); 31 memset(num,INF,sizeof(num)); 32 for(int i=0; i<n; i++) 33 scanf("%d",&dp[i]); 34 int path=0; 35 for(int i=0; i<n; i++){ 36 for(int j=0; j<n; j++){ 37 if(dp[i]<num[j]){ 38 num[j]=dp[i]; 39 if(path<j) 40 path=j; 41 break; 42 } 43 } 44 } 45 printf("%d\n",path+1); 46 }
标签:
原文地址:http://www.cnblogs.com/wangmengmeng/p/5535356.html