码迷,mamicode.com
首页 > 其他好文 > 详细

UVa 10534 DP LIS Wavio Sequence

时间:2015-08-03 20:51:04      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

两边算一下LIS就出来了,因为数据比较大,所以需要二分优化一下。

技术分享
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <algorithm>
 5 using namespace std;
 6 
 7 const int maxn = 10000 + 10;
 8 
 9 int n;
10 
11 int a[maxn], l[maxn], r[maxn];
12 int g[maxn];
13 
14 void LIS(int d[])
15 {
16     memset(g, 0x3f, sizeof(g));
17     for(int i = 0; i < n; i++)
18     {
19         int k = lower_bound(g+1, g+1+n, a[i]) - g;
20         d[i] = k;
21         g[k] = a[i];
22     }
23 }
24 
25 int main()
26 {
27     while(scanf("%d", &n) == 1)
28     {
29         for(int i = 0; i < n; i++) scanf("%d", a + i);
30         LIS(l);
31         reverse(a, a + n);
32         LIS(r);
33 
34         int ans = 1;
35         for(int i = 0; i < n; i++) ans = max(ans, min(l[i], r[n-1-i]));
36         printf("%d\n", ans * 2 - 1);
37     }
38 
39     return 0;
40 }
代码君

 

UVa 10534 DP LIS Wavio Sequence

标签:

原文地址:http://www.cnblogs.com/AOQNRMGYXLMV/p/4700211.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!