首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >有序数组的平方 双指针法

有序数组的平方 双指针法

作者头像
SingYi
发布2023-08-23 08:11:13
发布2023-08-23 08:11:13
18800
代码可运行
举报
文章被收录于专栏:Lan小站Lan小站
运行总次数:0
代码可运行

给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。 示例 1: 输入:nums = [-4,-1,0,3,10] 输出:[0,1,9,16,100] 解释:平方后,数组变为 [16,1,0,9,100],排序后,数组变为 [0,1,9,16,100] 示例 2: 输入:nums = [-7,-3,2,3,11] 输出:[4,9,9,49,121] 双指针法 数组其实是有序的, 只不过负数平方之后可能成为最大数了。 那么数组平方的最大值就在数组的两端,不是最左边就是最右边,不可能是中间。 此时可以考虑双指针法了,i指向起始位置,j指向终止位置。 定义一个新数组result,和A数组一样的大小,让k指向result数组终止位置。 如果A[i] A[i] < A[j] A[j] 那么result[k--] = A[j] * A[j]; 。 如果A[i] A[i] >= A[j] A[j] 那么result[k--] = A[i] * A[i]; 。 https://www.yuque.com/lxyo/course/vb7zmoutvnp5zeeo?#XjKZc

代码语言:javascript
代码运行次数:0
运行
复制
//
// Created by Lan on 2022/11/16.
//
#include 
#include 

using namespace std;

int main() {
    // 初始数组
    vector nums = {-4,-1,0,3,10};
    // 存放结果的数组
    vector result(nums.size(), 0);
    // 用于存结果的指针
    int k = nums.size() - 1;
    // 因为原数组是有序的,但是由于平方之后有的负数会比正数大,所以可以从两边
    // 同时往中间走,直到左右指针相遇。
    // 遍历一次,首指针的平方与尾指针的平方比较
    // 选择大的,然后放在结果指针,然后结果指针-1
    for (int i = 0, j = nums.size() - 1; i <= j;) {
        if (nums[i] * nums[i] > nums[j] * nums[j]) {
            result[k--] = nums[i] * nums[i];
            i++;
        } else {
            result[k--] = nums[j] * nums[j];
            j--;
        }
    }
    // 遍历输出结果
    for (int i = 0; i < result.size(); ++i) {
        printf("%d\t", result[i]);
    }
    return 1;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年11月16日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档