网站首页 > java教程 正文
有序数组的平方
题目描述:给定一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。
示例:
输入: nums = [-4,-1,0,3,10]
输出: [0,1,9,16,100]
暴力解法
Java代码
import java.util.Arrays;
public class Solution {
public int[] sortedSquares(int[] nums) {
int n = nums.length;
int[] result = new int[n];
for (int i = 0; i < n; i++) {
result[i] = nums[i] * nums[i];
}
Arrays.sort(result);
return result;
}
}
时间复杂度
- 时间复杂度:O(nlogn),其中 n 是数组的长度。这是因为 Arrays.sort() 方法通常使用一种基于归并排序或快速排序的算法,这两种算法的时间复杂度均为 O(nlogn)。
空间复杂度
- 空间复杂度:O(1),除了输入数组和输出数组外,我们没有使用额外的空间。
双指针法
Java代码
public class Solution {
public int[] sortedSquares(int[] nums) {
int n = nums.length;
int[] result = new int[n];
int left = 0;
int right = n - 1;
int index = n - 1; // 从后往前填充结果数组
while (left <= right) {
int leftSquare = nums[left] * nums[left];
int rightSquare = nums[right] * nums[right];
if (leftSquare > rightSquare) {
result[index] = leftSquare;
left++;
} else {
result[index] = rightSquare;
right--;
}
index--;
}
return result;
}
}
时间复杂度
- 时间复杂度:O(n),其中 n 是数组的长度。因为我们只遍历了一次数组。
空间复杂度
- 空间复杂度:O(1),除了输入数组和输出数组外,我们没有使用额外的空间。
总结
暴力解法简单直观,但时间复杂度较高。双指针法则利用了题目中数组的有序性,以空间换时间,实现了更高效的解决方案。在处理这类问题时,优先考虑是否能利用数据的特性(如有序性)来优化算法。
猜你喜欢
- 2025-05-28 Alibaba EasyExcel:合并列、行 设置,OnceAbsoluteMergeStrategy
- 2025-05-28 JAVA学习:跨平台时如何处理回车换行
- 2025-05-28 Java经典实例分析和相关知识总结与思考
- 2025-05-28 去字节跳动面试(Java岗),这1道面试题100%会问到
- 2025-05-28 分片篇:shardingsphere JDBC 5.X 改写引擎设计思路
你 发表评论:
欢迎- 06-04C++优先级调度队列(Priority Queue)
- 06-04数据结构与算法-优先队列(优先队列 数组实现)
- 06-04什么是优先队列?(优先队列原理)
- 06-04终于有架构大牛把分布式系统概念讲明白了,竟然用了足足800页
- 06-04分布式事物如何保证接口请求顺序性?
- 06-04微服务下分布式事务模式的详细对比
- 06-04彻底掌握分布式事务2PC、3PC模型(分布式事务 三阶段)
- 06-04分布式事务最全详解(看这篇就够了)
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)