Skip to content

Latest commit

 

History

History
56 lines (46 loc) · 1.28 KB

977_squaresOfASortedArray.md

File metadata and controls

56 lines (46 loc) · 1.28 KB

Given an integer array nums sorted in non-decreasing order, return an array of the squares of each number sorted in non-decreasing order.

O(NlogN) Time solution

  • Create new array and push_back squares of each element in it.
  • Sort the new array.
  • Return the new array.

Code

class Solution{
public:
    vector<int> sortedSquares(vector<int> &nums)
    {
        vector<int> ans;
        for (auto &x : nums)
            ans.emplace_back(x * x);

        sort(ans.begin(), ans.end());
        return ans;
    }
};

O(N) Time solution

  • We use two pointer method to solve this problem.
  • set two array l=0 and r=arr.size()-1.
  • traverse throught the array and set max abs values square at last position.
  • return the array.

Code

class Solution {
public:
    vector<int> sortedSquares(vector<int>& nums) {
        vector<int> ans(nums.size(),0);
        int l = 0, r = nums.size()-1;
        int i = nums.size()-1;
        while(l<=r){
            if(abs(nums[l])>abs(nums[r])){
                ans[i--]=nums[l]*nums[l];
                l++;
            }else{
                ans[i--]=nums[r]*nums[r];
                r--;
            }
        }
        return ans;
    }
};