-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path977_Squares_Of_A_Sorted_Array.py
More file actions
41 lines (33 loc) · 1.19 KB
/
977_Squares_Of_A_Sorted_Array.py
File metadata and controls
41 lines (33 loc) · 1.19 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
class Solution(object):
def sortedSquares(self, nums):
"""
:type nums: List[int]
:rtype: List[int]
"""
# Two Possible Solutions
# Time: O(N), Space: O(N)
sortedSquares = [0 for _ in nums]
leftPointer = 0
rightPointer = len(nums)-1
for index in reversed(range(len(nums))):
leftPointerSquare = nums[leftPointer] * nums[leftPointer]
rightPointerSquare = nums[rightPointer] * nums[rightPointer]
if abs(leftPointerSquare) > abs(rightPointerSquare):
sortedSquares[index] = leftPointerSquare
leftPointer += 1
else:
sortedSquares[index] = rightPointerSquare
rightPointer -= 1
return sortedSquares
# # Time: O(NlogN), Space: O(N)
# def sortedSquares(self, nums):
# sortedSquares = [0 for _ in nums]
# for index in range(len(nums)):
# value = nums[index]
# sortedSquares[index] = value * value
# sortedSquares.sort()
# return sortedSquares
nums = [-4,-1,0,3,10]
[0,1,9,16,100]
soln = Solution()
print(soln.sortedSquares(nums))