-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathp084.c
42 lines (42 loc) · 1.13 KB
/
p084.c
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
int largestRectangleArea(int* heights, int heightsSize) {
if (heightsSize == 0) return 0;
if (heightsSize == 1) return heights[0];
int *stk = (int*)malloc(sizeof(int)*heightsSize);
int *rightless = (int*)malloc(sizeof(int)*heightsSize);
int *leftless = (int*)malloc(sizeof(int)*heightsSize);
int stksize = 0;
int i;
for (i = 0; i < heightsSize; i++)
{
rightless[i] = heightsSize;
leftless[i] = -1;
}
for (i = 0; i < heightsSize; i++)
{
while (stksize && heights[stk[stksize-1]] > heights[i])
{
rightless[stk[--stksize]] = i;
}
stk[stksize++] = i;
}
stksize = 0;
for (i = heightsSize-1; i >= 0; i--)
{
while (stksize && heights[stk[stksize-1]] > heights[i])
{
leftless[stk[--stksize]] = i;
}
stk[stksize++] = i;
}
int result = 0;
int tmp = 0;
for (i = 0; i < heightsSize; i++)
{
tmp = heights[i]*(rightless[i]-leftless[i]-1);
if (tmp > result)
{
result = tmp;
}
}
return result;
}