977. 有序数组的平方


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 已按非递减顺序排序

二、相关链接

三、解题思路

  • 解法:双指针
  • 思路
    • 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;
    }
}

五、总结

  • 难度:简单(没想到有题解这种操作)

文章作者: GaryLee
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 GaryLee !
  目录