977.有序数组的平方
题目描述
题目链接:题目链接
给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。
输入:nums = [-4,-1,0,3,10]
输出:[0,1,9,16,100]
解释:平方后,数组变为 [16,1,0,9,100]
排序后,数组变为 [0,1,9,16,100]
输入:nums = [-7,-3,2,3,11]
输出:[4,9,9,49,121]
代码
暴力解法,没什么好说的
class Solution:
def sortedSquares(self, nums: List[int]) -> List[int]:
for i, num in enumerate(nums):
nums[i] = num * num
nums = sorted(nums)
return nums
结果
解法2–双指针
数组原本是有序的, 只是在平方之后就变得无序了, 根本原因就是负数平方之后可能成为最大数了, 那么数组平方的最大值就在数组的两端, 不是最左边就是最右边, 不可能是中间.这样我们就能确定了平方后最大值的位置, 所以用双指针指向数组的两端, 必定能找到平方后的最大值, 将其放到新数组末尾, 之后不断向中间移动, 通过比较两个指针平方后的大小, 就能不断地将当前的最大值放入数组的尾部, 直到两个指针相遇为止.这种一种比较简单的双指针实现方式, 另外一种稍微麻烦一点的方式就是 先找到负值和正值的分界点, 相当于找到了平方后的最小值, 然后向两边不断进行遍历, 不过这种方法还多了一层循环来找分界点, 这种思想也要了解一下, 对于之后的题目还是挺有用的.
代码
class Solution(object):
def sortedSquares(self, nums):
"""
:type nums: List[int]
:rtype: List[int]
"""
n = len(nums)
res = [0] * n
l,r,pos = 0,n-1,n-1
while(l <= r):
if(nums[l]*nums[l] > nums[r]*nums[r]):
res[pos] = nums[l]*nums[l]
l += 1
else:
res[pos] = nums[r] * nums[r]
r -= 1
pos -= 1
return res
结果演示
参考
https://leetcode-cn.com/problems/squares-of-a-sorted-array
https://leetcode-cn.com/problems/squares-of-a-sorted-array/comments/