力扣977. 有序数组的平方(双指针)

给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。
在这里插入图片描述

class Solution {
    
    
    public int[] sortedSquares(int[] nums) {
    
    
        int n = nums.length;
        int[] ans = new int[n];
        for (int i = 0, j = n - 1, pos = n - 1; i <= j;) {
    
    
            if(nums[i]*nums[i]>nums[j]*nums[j]){
    
    
                ans[pos]=nums[i]*nums[i];
                i++;
            }else{
    
    
                ans[pos]=nums[j]*nums[j];
                j--;
            }
            pos--;
        }
        return ans;
    }
}

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/gps666666/article/details/120214891
今日推荐