forked from sitz/UVa-Online-Judge
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path10534.cpp
110 lines (103 loc) · 1.42 KB
/
10534.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#include <bits/stdc++.h>
using namespace std;
#define MIN(a, b) (a > b ? b : a);
#define MAXN 10005
int SEQ[MAXN], TEMP[MAXN], ORDER[MAXN], N, MAX, LIMIT;
// binary search
int FIND_BEST(int key)
{
int lo, up, mid;
lo = 1;
up = LIMIT;
mid = (lo + up) / 2;
if (TEMP[1] > key)
{
return 1;
}
else if (TEMP[LIMIT] < key)
{
return LIMIT + 1;
}
else if (TEMP[LIMIT] == key)
{
return LIMIT;
}
while (lo < up && TEMP[mid] != key)
{
if (TEMP[mid] < key)
{
lo = mid + 1;
}
else if (TEMP[mid] > key)
{
if (TEMP[mid - 1] < key)
{
return mid;
}
up = mid - 1;
}
mid = (lo + up) / 2;
}
return mid;
}
void FIND_LIS()
{
int i, pos;
TEMP[1] = SEQ[0];
ORDER[0] = 1;
LIMIT = 1;
for (i = 1; i < N; i++)
{
pos = FIND_BEST(SEQ[i]);
if (pos > LIMIT)
{
LIMIT = pos;
TEMP[pos] = SEQ[i];
}
else if (TEMP[pos] > SEQ[i])
{
TEMP[pos] = SEQ[i];
}
ORDER[i] = pos;
}
}
void FIND_LDS()
{
int i, pos, lis;
MAX = 1;
LIMIT = 1;
TEMP[1] = SEQ[N - 1];
for (i = N - 2; i >= 0; i--)
{
pos = FIND_BEST(SEQ[i]);
if (pos > LIMIT)
{
LIMIT = pos;
TEMP[pos] = SEQ[i];
}
else if (TEMP[pos] > SEQ[i])
{
TEMP[pos] = SEQ[i];
}
lis = MIN(ORDER[i], pos);
if (lis > MAX)
{
MAX = lis;
}
}
printf("%d\n", MAX * 2 - 1);
}
int main()
{
int i;
while (scanf("%d", &N) == 1)
{
for (i = 0; i < N; i++)
{
scanf("%d", &SEQ[i]);
}
FIND_LIS();
FIND_LDS();
}
return 0;
}