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]
提示:
1 <= nums.length <= 104
-104 <= nums[i] <= 104
nums
已按非递减顺序排序
二、相关链接
- 题目链接:https://leetcode-cn.com/problems/squares-of-a-sorted-array/
- 参考题解:https://leetcode-cn.com/problems/squares-of-a-sorted-array/solution/you-xu-shu-zu-de-ping-fang-by-leetcode-solution/
三、解题思路
- 解法:双指针
- 思路:
- 1.负数的话越小平方的数越大,正数的话越大平方的数越大
- 2.用双指针两端往中间遍历直到重合,比较大的就放在结果集后面
四、代码
class Solution {
public int[] sortedSquares(int[] nums) {
//前提:负数的话越小平方的数越大,正数的话越大平方的数越大
int left = 0;
int right = nums.length - 1;
int result[] = new int[nums.length];
int index = result.length - 1;
//result从右往左排
while(left<=right) {
if(nums[left] * nums[left] > nums[right] * nums[right]) {
result[index] = nums[left] * nums[left];
left++;
index--;
} else {
result[index] = nums[right] * nums[right];
right--;
index--;
}
}
return result;
}
}
五、总结
- 难度:简单(没想到有题解这种操作)