-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy path396.py
More file actions
27 lines (25 loc) · 870 Bytes
/
396.py
File metadata and controls
27 lines (25 loc) · 870 Bytes
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
# 这题测时间还挺有趣的
# 第一版
class Solution:
def maxRotateFunction(self, nums: List[int]) -> int:
n = len(nums)
fval = 0
total = sum(nums)
for i in range(n):
fval += i * nums[i]
ans = fval
for i in range(n-1):
fval = fval - total + n * nums[i]
ans = max(ans, fval)
return ans
# 第二版
class Solution:
def maxRotateFunction(self, nums: List[int]) -> int:
res = cur = sum(idx * num for idx,num in enumerate(nums))
total = sum(nums)
n = len(nums)
while nums:
cur += total - nums.pop() * n
res = cur if cur > res else res
return res
# 结论:1.当ind和值都要用的时候,enumerate很快。2.pop确实会加速,但是只适用于用完即弃。3.max()会造成100ms左右的差异