有序数组的平方(LeetCode)

题目

给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。

解题

以下算法时间复杂度为

python 复制代码
def sortedSquares(nums):
    n = len(nums)
    result = [0] * n  # 创建一个结果数组,长度与 nums 相同
    left, right = 0, n - 1  # 初始化左右指针
    position = n - 1  # 初始化结果数组的插入位置

    while left <= right:
        left_square = nums[left] ** 2
        right_square = nums[right] ** 2
        if left_square > right_square:
            result[position] = left_square
            left += 1
        else:
            result[position] = right_square
            right -= 1
        position -= 1

    return result


nums = [-4, -1, 0, 3, 10]
print(sortedSquares(nums))  # 输出: [0, 1, 9, 16, 100]

nums = [-7, -3, 2, 3, 11]
print(sortedSquares(nums))  # 输出: [4, 9, 9, 49, 121]

0, 1, 9, 16, 100

4, 9, 9, 49, 121

相关推荐
qq_206901391 分钟前
c++怎么在Linux下获取文件被最后一次访问的精确纳秒时间【进阶】
jvm·数据库·python
hakesashou1 分钟前
python如何保存img文件
开发语言·python
Lazionr1 分钟前
数据结构入门:栈实现全解析
c语言·数据结构
小π军2 分钟前
STL之multiset 常见API介绍
数据结构·c++·算法
Shan12053 分钟前
浅谈:从经典算法到实战优化的案例分析
数据结构
踩坑记录3 分钟前
leetcode hot100 1143. 最长公共子序列 mediuim 递归优化
leetcode
MarkHD4 分钟前
调度、监控与部署:Python自动化任务全栈实践
开发语言·python·自动化
m0_748920364 分钟前
如何让点击目标元素时随机移动到页面任意位置
jvm·数据库·python
研究点啥好呢4 分钟前
Momenta算法工程师面试题精选:10道高频考题+答案解析
人工智能·算法·求职招聘·面试笔试
Resistance丶未来4 分钟前
DeepSeek-V4 新手快速上手指南
数据结构·python·gpt·算法·机器学习·claude·claude 4.6