-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathset2_1.py
More file actions
70 lines (62 loc) · 1.54 KB
/
set2_1.py
File metadata and controls
70 lines (62 loc) · 1.54 KB
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
class typeofquery:
def type1(arr,queries,t):
L = queries[t][1]
R = queries[t][2]
x = queries[t][3]
for i in range(len(arr)):
if(arr[i] >= L and arr[i] <= R):
arr[i]+=x
#print(arr)
def type2(arr,queries,t):
L = queries[t][1]
R = queries[t][2]
x = queries[t][3]
for i in range(len(arr)):
if(arr[i] > L and arr[i] < R):
arr[i] = arr[i]*x
#print(arr)
def type3(arr,queries,t):
z = queries[t][1]
pos = list()
for i in range(len(arr)):
if(z == arr[i]):
pos.append(i)
if(len(pos) == 0):
print(-1)
return
#mini = min(pos)
#maxi = max(pos)
print(max(pos)-min(pos)+1)
#print(arr)
return
#print(maxi-mini+1)
#return(maxi-mini+1)
def call(queries,i):
if(queries[i][0] == 1):
return 1
elif(queries[i][0] == 2):
return 2
elif(queries[i][0] == 3):
return 3
def whole(arr,queries,q):
for j in range(q):
k = call(queries, j)
if(k == 1):
type1(arr,queries,j)
if(k == 2):
type2(arr,queries,j)
if(k == 3):
type3(arr,queries,j)
n = int(input())
if( n < 1 or n > 400000 ):
exit
arr = list(map(int,input().strip().split()))[:n]
q = int(input())
if( q < 1 or q > 10000):
exit
queries = list()
for i in range(q):
queries.append(list(map(int,input().strip().split()))[:4])
#print("queries", queries)
#print(arr)
whole(arr,queries,q)