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

相关推荐
范范@20 小时前
day2-python基础语法
开发语言·python
ZPC821020 小时前
规划后的轨迹,如何发给 moveit_servo 执行
c++·人工智能·算法·3d
编码者卢布20 小时前
【Azure Container App】容器应用的维护窗口设置
python·azure
70asunflower20 小时前
5.4 分布分析
人工智能·算法·机器学习·数据挖掘·数据分析
夏至春来-美美20 小时前
python 使用pytest的ini配置
开发语言·python·pytest
Pkmer21 小时前
滑动窗口专题
算法
Omics Pro21 小时前
柳叶刀|参考文献不存在
人工智能·算法·机器学习·支持向量机·自然语言处理
geovindu21 小时前
python: Mutex Pattern
开发语言·python·设计模式·互斥锁模式
C137的本贾尼21 小时前
告别硬编码:提示词模板入门
python·langchain
初心未改HD21 小时前
机器学习之K-Means聚类算法详解
算法·机器学习·kmeans