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

相关推荐
helloweilei5 小时前
python 抽象基类
python
用户8356290780515 小时前
Python 实现 PPT 转 HTML
后端·python
CoovallyAIHub6 小时前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
NineData7 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
木心月转码ing8 小时前
Hot100-Day14-T33搜索旋转排序数组
算法
zone773911 小时前
004:RAG 入门-LangChain读取PDF
后端·python·面试
zone773911 小时前
005:RAG 入门-LangChain读取表格数据
后端·python·agent
会员源码网11 小时前
内存泄漏(如未关闭流、缓存无限增长)
算法
颜酱12 小时前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱13 小时前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法