有序数组的平方(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

相关推荐
zhoutongsheng3 分钟前
mysql如何处理表空间碎片问题_执行OPTIMIZE TABLE整理
jvm·数据库·python
狼与自由7 分钟前
Harness
python
shehuiyuelaiyuehao20 分钟前
算法18,二分查找
java·开发语言·算法
IT策士23 分钟前
Python mcp研究:入门到精通
开发语言·python·qt
罗技12325 分钟前
告别“兼容模式“:Easysearch 有了自己的官方 Python 客户端
开发语言·python
IT策士27 分钟前
Python 常见的设计模型:入门到精通
开发语言·python
PSLoverS31 分钟前
Python如何实现测试场景编排_基于pytest的数据驱动组合策略
jvm·数据库·python
不会写DN32 分钟前
如何通过 Python 实现招聘平台自动投递
开发语言·前端·python
西贝爱学习35 分钟前
Python3.13安装包及其下载地址
python