leetcode 977. Squares of a Sorted Array

题目描述

双指针法一

用right表示原数组中负数和非负数的分界线。

nums[0,right-1]的是负数,nums[right,nums.size()-1]是非负数。

然后用合并两个有序数组的方法。合并即可。

cpp 复制代码
class Solution {
public:
    vector<int> sortedSquares(vector<int>& nums) {
        vector<int> res;
        int len = nums.size();
        res.reserve(len);
        int right = -1;
        for(int i =0;i <len;i++){
            if(right == -1 && nums[i] >=0)
                right = i;
            nums[i] = nums[i]*nums[i];
        }
        int left = right-1;
        if(right == -1){
            right = len;
            left = len -1;
        }

        while(left >= 0 && right < len){
            if(nums[left]<=nums[right]){
                res.push_back(nums[left--]);
            }else{
                res.push_back(nums[right++]);
            }
        }
        while(left>=0){
            res.push_back(nums[left--]);
        }
        while(right<len){
            res.push_back(nums[right++]);
        }
        return res;
    }
};

双指针法二

容易发现原数组中元素的绝对值从两端向中间减小。因此可以逆序确定res数组。

cpp 复制代码
class Solution {
public:
    vector<int> sortedSquares(vector<int>& nums) {
        int len = nums.size();
        vector<int> res(len,0);
        int left = 0;
        int right = len -1;
        int res_pos = len - 1;
        while(left <= right){
            if(abs(nums[left]) > abs(nums[right])){
                res[res_pos--] = nums[left]*nums[left];
                left++;
            }else{
                res[res_pos--] = nums[right]*nums[right];
                right--;
            }
        }
        return res;
    }
};
相关推荐
Zephyrtoria12 分钟前
区间合并:区间合并问题
java·开发语言·数据结构·算法
柏箱2 小时前
容器里有10升油,现在只有两个分别能装3升和7升油的瓶子,需要将10 升油等分成2 个5 升油。程序输出分油次数最少的详细操作过程。
算法·bfs
Hello eveybody4 小时前
C++介绍整数二分与实数二分
开发语言·数据结构·c++·算法
Mallow Flowers5 小时前
Python训练营-Day31-文件的拆分和使用
开发语言·人工智能·python·算法·机器学习
GalaxyPokemon6 小时前
LeetCode - 704. 二分查找
数据结构·算法·leetcode
leo__5207 小时前
matlab实现非线性Granger因果检验
人工智能·算法·matlab
GG不是gg7 小时前
位运算详解之异或运算的奇妙操作
算法
FF-Studio8 小时前
万物皆数:构建数字信号处理的数学基石
算法·数学建模·fpga开发·自动化·音视频·信号处理·dsp开发
叶子爱分享10 小时前
从事算法工作对算法刷题量的需求
算法
勇闯IT10 小时前
有多少小于当前数字的数字
java·数据结构·算法