leetcode_977. 有序数组的平方_java

news2025/7/15 16:29:44

977. 有序数组的平方https://leetcode.cn/problems/squares-of-a-sorted-array/

1.题目

给你一个按 非递减顺序 排序的整数数组 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]
    

    提示:

    • 1 <= nums.length <= 104
    • -104 <= nums[i] <= 104
    • nums 已按 非递减顺序 排序

    进阶:

    • 请你设计时间复杂度为 O(n) 的算法解决本问题

    2.题解

    题解1:

    先把所有的元素平方,然后再使用选择排序算法进行排序(用其他排序算法也可以)。

    class Solution {
        public int[] sortedSquares(int[] nums) {
            int i,j,min,temp;
            //1、把所有的元素平方
            for(i=0; i<nums.length; i++) {
                nums[i] = nums[i] * nums[i];
            }
    
            //选择排序算法,使元素从小到大排序
            for(i=0;i<nums.length-1;i++)
            {
                min=i; // 记录最小值的位置,第一个元素默认最小
                for(j=i+1;j<nums.length;j++)
                    if(nums[j]<nums[min]) // 找到目前最小值
                        min=j;  // 记录最小值的位置
                
                if(min!=i) { // 交换两个变量
                    temp=nums[min];
                    nums[min]=nums[i];
                    nums[i]=temp;
                }
                
            }
            return nums;        
        }
    }

    注:选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

    题解2:

    使用Arrays.sort()函数。

    class Solution {
        public int[] sortedSquares(int[] nums) {
            for(int i=0; i<nums.length; i++) {
                nums[i] = nums[i] * nums[i];
            }
    
            Arrays.sort(nums);
            
            return nums;        
        }
    }

    题解3:

    使用双指针。

    class Solution {
        public int[] sortedSquares(int[] nums) {
            // 创建一个与输入数组相同长度的数组来存储结果
            int[] result = new int[nums.length];
            
            // 初始化变量 i 为数组的起始位置,j 为数组的结束位置,k 为结果数组的最后一个位置
            int i, j, k = nums.length - 1;
            
            // 使用双指针法进行比较,i 从数组开头,j 从数组结尾,k 从结果数组的末尾开始填充
            for(i = 0, j = nums.length - 1; i <= j; ) {
                // 比较当前 i 和 j 位置的平方值,较大的平方值放到 result[k] 中
                if(nums[i] * nums[i] > nums[j] * nums[j]) {
                    // 将 i 位置的平方放入 result[k] 中
                    result[k] = nums[i] * nums[i];
                    // k 递减,准备填充下一个最大值
                    k--;
                    // i 向右移动,继续向右处理
                    i++;
                } else {
                    // 将 j 位置的平方放入 result[k] 中
                    result[k] = nums[j] * nums[j];
                    // k 递减,准备填充下一个最大值
                    k--;
                    // j 向左移动,继续向左处理
                    j--;
                }
            }
            
            // 返回结果数组,它已经按升序排列了
            return result;
        }
    }
    

    本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2325513.html

    如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

    相关文章

    网络探索之旅:网络原理(第二弹)

    上篇文章&#xff0c;小编分享了应用层和传输层深入的一点的知识&#xff0c;那么接下来&#xff0c;这篇文章&#xff0c;继续分享网络层和数据链路层。 网络层 了解这个网络层&#xff0c;那么其实就是重点来了解下IP这个协议 对于这个协议呢&#xff0c;其实也是和前面的…

    深入剖析 JVM:从组成原理到调优实践

    深入剖析 JVM&#xff1a;从组成原理到调优实践 深入剖析 JVM&#xff1a;从组成原理到调优实践一、JVM 组成架构&#xff1a;运行 Java 程序的 “幕后引擎”1.1 内存结构&#xff1a;数据存储的 “分区管理”1.2 执行引擎&#xff1a;字节码的 “翻译官”1.3 本地方法接口&…

    阿里云下一代可观测时序引擎-MetricStore 2.0

    作者&#xff1a;徐昊&#xff08;博澍&#xff09; 背景 作为可观测场景使用频度最高的数据类型&#xff0c;Metrics 时序数据在可观测领域一直占有着重要地位&#xff0c;无论是从全局视角来观测系统整体状态&#xff0c;还是从大范围数据中定位某一个异常的位置&#xff0…

    从入门到精通【 MySQL】 数据库约束与设计

    文章目录 &#x1f4d5;1. 数据库约束✏️1.1 NOT NULL 非空约束✏️1.2 DEFAULT 默认值约束✏️1.3 UNIQUE 唯一约束✏️1.4 PRIMARY KEY 主键约束✏️1.5 FOREIGN KEY 外键约束✏️1.6 CHECK 约束 &#x1f4d5;2. 数据库设计✏️2.1 第一范式✏️2.2 第二范式✏️2.3 第三范…

    Dubbo 通信流程 - 服务的调用

    Dubbo 客户端的使用 在 Dubbo 应用中&#xff0c;往类成员注解 DubboReference&#xff0c;服务启动后便可以调用到远端&#xff1a; Component public class InvokeDemoFacade {AutowiredDubboReferenceprivate DemoFacade demoFacade;public String hello(String name){// …

    【数据结构】哈夫曼树

    哈夫曼树 在学习哈夫曼树之前&#xff0c;先了解以下几个概念&#xff1a; 一&#xff1a;**路径长度&#xff1a;**在一棵树中&#xff0c;从一个节点到另一个节点所经过的“边”的数量&#xff0c;被我们称为两个节点之间的路径长度。 二&#xff1a;**树的路径长度&#xf…

    HCIP(TCP)(2)

    1. TCP三次握手 SYN (同步序列编号) 报文: 客户端发送 SYN 报文&#xff0c;开始建立连接&#xff0c;并初始化序列号。 SYN-ACK (同步序列编号-确认) 报文: 服务器收到 SYN 报文后&#xff0c;回复 SYN-ACK 报文&#xff0c;确认连接请求&#xff0c;并初始化自己的序列号和确…

    基于Web的交互式智能成绩管理系统设计

    目录 摘要 绪论 一、应用背景 二、行业发展现状 三、程序开发的重要意义 四、结语 1 代码 2 数据初始化模块 3 界面布局模块 4 核心功能模块 5 可视化子系统 6 扩展功能模块 7 架构设计亮点 功能总结 一、核心数据管理 二、智能分析体系 三、可视化系统 四、扩…

    k8s日志管理

    k8s日志管理 k8s查看日志查看集群中不是完全运行状态的pod查看deployment日志查看service日志进入pod的容器内查看日志 管理k8s组件日志kubectl logs查看日志原理 管理k8s应用日志收集k8s日志思路收集标准输出收集容器中日志文件 k8s查看节点状态失败k8s部署prometheus监控 k8s…

    element-plus中,Loading 加载组件的使用

    一.基本使用 给一个组件&#xff0c;如&#xff1a;table表格&#xff0c;加上v-loading"true"即可。 举例&#xff1a;复制如下代码。 <template><el-table v-loading"loading" :data"tableData" style"width: 100%"><…

    Mybatis_Plus中的常用注解

    目录 1、TableName TableId TableId的type属性 TableField 1、TableName 经过以上的测试&#xff0c;在使用MyBatis-Plus实现基本的CRUD时&#xff0c;我们并没有指定要操作的表&#xff0c;只是在 Mapper接口继承BaseMapper时&#xff0c;设置了泛型User&#xff0c;而操…

    高并发金融系统,“可观测-可追溯-可回滚“的闭环审计体系

    一句话总结 在高并发金融系统中&#xff0c;审计方案设计需平衡"观测粒度"与"系统损耗"&#xff0c;通过双AOP实现非侵入式采集&#xff0c;三表机制保障操作原子性&#xff0c;最终形成"可观测-可追溯-可回滚"的闭环体系。 业务痛点与需求 在…

    企业内训|DeepSeek技术革命、算力范式重构与场景落地洞察-某头部券商

    3月19日北京&#xff0c;TsingtaoAI公司负责人汶生受邀为某证券公司管理层和投资者举办专题培训&#xff0c;围绕《DeepSeek技术革命、算力范式重构与场景落地洞察》主题&#xff0c;系统阐述了当前AI技术演进的核心趋势、算力需求的结构性变革&#xff0c;以及行业应用落地的关…

    VS Code C/C++项目设置launch.json中的environment参数解决支持库路径问题

    问题描述 Windows 11 VS Code C/C 开发环境搭建分别写了c和cpp两个示例代码&#xff0c;在运行过程中c代码没有发现问题&#xff08;可能简单&#xff0c;没有用到太多支持&#xff09;&#xff0c;但使用了stl的cpp代码并没有运行出来&#xff0c;如下图&#xff1a; 出问题…

    怎样解决 Windows 11 上的 DirectX 错误,最新DX 问题解决方法

    在使用 Windows 11 操作系统的过程中&#xff0c;大家可能会遇到 DirectX 错误的情况&#xff0c;这可能会给游戏体验、多媒体应用甚至是系统的整体性能带来负面影响。不过别担心&#xff0c;本文将为大家详细介绍如何解决 Windows 11 上的 DirectX 错误&#xff0c;让您的系统…

    PH热榜 | 2025-03-30

    1. Deepcord 标语&#xff1a;Discord 数据分析&#xff1a;获取指标洞察与受众研究 介绍&#xff1a;Deepcord&#xff1a;为社区建设者提供的Discord分析工具。跟踪超过50万个服务器的指标&#xff0c;发现热门社区&#xff0c;监控竞争对手&#xff0c;找到你的目标受众。…

    Open webui的使用

    问题 之前本地量化模型管理器ollama的文章&#xff0c;我们知道可以通过ollama来管理本地量化模型&#xff0c;也能够在命令行中与相关模型进行对话。现在我们想要在有个web页面通过浏览器来与本地模型对话。这里我们就使用Open webui作为界面来与本地模型对话。 安装启动 这…

    STM32单片机的桌面宠物机器人(基于HAL库)

    效果 基于STM32单片机的桌面宠物机器人 概要 语音模块&#xff1a;ASR PRO&#xff0c;通过天问block软件烧录语音指令 主控芯片&#xff1a;STM32F103C8T6 使用HAL库 屏幕&#xff1a;0.96寸OLED屏&#xff0c;用来显示表情 4个舵机&#xff0c;用来当作四只腿 底部一个面…