-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdata_stream.py
45 lines (44 loc) · 908 Bytes
/
data_stream.py
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
from collections import deque
def find_island(arr):
st = deque()
st.append(-1)
scnt=-1
ecnt=0
cnt=0
for i in range(len(arr)):
if st[-1] == arr[i]:
continue
if st[-1] < arr[i]:
st.append(arr[i])
scnt+=1
#print(st)
elif st[-1] == -1:
continue
else:
while st:
print(st)
if st[-1]>arr[i]:
st.pop()
ecnt+=1
elif st[-1]==arr[i]:
ecnt+=1
break
else:
break
st.append(arr[i])
ecnt-=1
scnt+=1
print(scnt,ecnt)
return ecnt
T = int(input())
for test in range(T):
arr = list(map(int,input().split()))[1:]
print(find_island(arr))
"""
0 -> 2 -> 4 -> 1 -> 0
0
0 2
0 2 4
0 1
0
"""