-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
sum-of-total-strength-of-wizards.py
55 lines (52 loc) · 2.31 KB
/
sum-of-total-strength-of-wizards.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
46
47
48
49
50
51
52
53
54
55
# Time: O(n)
# Space: O(n)
# mono stack, prefix sum, optimized from solution2
class Solution(object):
def totalStrength(self, strength):
"""
:type strength: List[int]
:rtype: int
"""
MOD = 10**9+7
curr = 0
prefix = [0]*(len(strength)+1)
for i in xrange(len(strength)):
curr = (curr+strength[i])%MOD
prefix[i+1] = (prefix[i]+curr)%MOD
stk, result = [-1], 0
for i in xrange(len(strength)+1):
while stk[-1] != -1 and (i == len(strength) or strength[stk[-1]] >= strength[i]):
x, y, z = stk[-2]+1, stk.pop(), i-1
# assert(all(strength[j] >= strength[y] for j in xrange(x, y+1)))
# assert(all(strength[j] > strength[y] for j in xrange(y+1, z+1)))
result = (result+(strength[y]*((y-x+1)*(prefix[z+1]-prefix[y])-(z-y+1)*(prefix[y]-prefix[max(x-1, 0)]))))%MOD
stk.append(i)
return result
# Time: O(n)
# Space: O(n)
# mono stack, prefix sum
class Solution2(object):
def totalStrength(self, strength):
"""
:type strength: List[int]
:rtype: int
"""
MOD = 10**9+7
prefix, prefix2 = [0]*(len(strength)+1), [0]*(len(strength)+1)
for i in xrange(len(strength)):
prefix[i+1] = (prefix[i]+strength[i])%MOD
prefix2[i+1] = (prefix2[i]+strength[i]*(i+1))%MOD
suffix, suffix2 = [0]*(len(strength)+1), [0]*(len(strength)+1)
for i in reversed(xrange(len(strength))):
suffix[i] = (suffix[i+1]+strength[i])%MOD
suffix2[i] = (suffix2[i+1]+strength[i]*(len(strength)-i))%MOD
stk, result = [-1], 0
for i in xrange(len(strength)+1):
while stk[-1] != -1 and (i == len(strength) or strength[stk[-1]] >= strength[i]):
x, y, z = stk[-2]+1, stk.pop(), i-1
# assert(all(strength[j] >= strength[y] for j in xrange(x, y+1)))
# assert(all(strength[j] > strength[y] for j in xrange(y+1, z+1)))
result = (result+(strength[y]*((z-y+1)*((prefix2[y+1]-prefix2[x])-x*(prefix[y+1]-prefix[x]))+
(y-x+1)*((suffix2[y+1]-suffix2[z+1])-(len(strength)-(z+1))*(suffix[y+1]-suffix[z+1])))))%MOD
stk.append(i)
return result