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;
    }
};
相关推荐
hie988949 分钟前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼19 分钟前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield1 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦1 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl1 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder1 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
挺菜的2 小时前
【算法刷题记录(简单题)002】字符串字符匹配(java代码实现)
java·开发语言·算法
凌肖战5 小时前
力扣网编程55题:跳跃游戏之逆向思维
算法·leetcode
黑听人5 小时前
【力扣 简单 C】70. 爬楼梯
c语言·leetcode
88号技师6 小时前
2025年6月一区-田忌赛马优化算法Tianji’s horse racing optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法