Given an integer array nums sorted in non-decreasing order, return an array of the squares of each number sorted in non-decreasing order.
- Create new array and push_back squares of each element in it.
- Sort the new array.
- Return the new array.
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;
}
};
- 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.
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;
}
};