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

LIS UVA 10534 Wavio Sequence

时间:2015-08-06 00:10:49      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:

 

题目传送门

 1 /*
 2     LIS:应用,nlogn的做法,首先从前扫到尾,记录每个位置的最长上升子序列,从后扫到头同理。
 3             因为是对称的,所以取较小值*2-1再取最大值
 4 */
 5 /************************************************
 6 * Author        :Running_Time
 7 * Created Time  :2015-8-5 21:38:32
 8 * File Name     :UVA_10534.cpp
 9  ************************************************/
10 
11 #include <cstdio>
12 #include <algorithm>
13 #include <iostream>
14 #include <sstream>
15 #include <cstring>
16 #include <cmath>
17 #include <string>
18 #include <vector>
19 #include <queue>
20 #include <deque>
21 #include <stack>
22 #include <list>
23 #include <map>
24 #include <set>
25 #include <bitset>
26 #include <cstdlib>
27 #include <ctime>
28 using namespace std;
29 
30 #define lson l, mid, rt << 1
31 #define rson mid + 1, r, rt << 1 | 1
32 typedef long long ll;
33 const int MAXN = 1e4 + 10;
34 const int INF = 0x3f3f3f3f;
35 const int MOD = 1e9 + 7;
36 int a[MAXN];
37 int d[MAXN];
38 int dp[MAXN], dp2[MAXN];
39 
40 int main(void)    {     //UVA 10534 Wavio Sequence
41     int n;
42     while (scanf ("%d", &n) == 1)   {
43         for (int i=1; i<=n; ++i)    scanf ("%d", &a[i]);
44         memset (d, 0, sizeof (d));
45         memset (dp, 0, sizeof (dp));
46         memset (dp2, 0, sizeof (dp2));
47         d[1] = a[1];    int len = 1;    dp[1] = 1;
48         for (int i=2; i<=n; ++i)    {
49             if (d[len] < a[i])  d[++len] = a[i];
50             else    {
51                 int j = lower_bound (d+1, d+1+len, a[i]) - d;
52                 d[j] = a[i];
53             }
54             dp[i] = len;
55         }
56         d[1] = a[n];    int len2 = 1;   dp2[n] = 1;
57         for (int i=n-1; i>=1; --i)    {
58             if (d[len2] < a[i]) d[++len2] = a[i];
59             else    {
60                 int j = lower_bound (d+1, d+1+len2, a[i]) - d;
61                 d[j] = a[i];
62             }
63             dp2[i] = len2;
64         }
65         int ans = 0;
66         for (int i=1; i<=n; ++i)    {
67             ans = max (ans, min (dp[i], dp2[i]) * 2 - 1);
68         }
69         printf ("%d\n", ans);
70     }
71 
72     return 0;
73 }

 

LIS UVA 10534 Wavio Sequence

标签:

原文地址:http://www.cnblogs.com/Running-Time/p/4706104.html

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