leetcode977-Squares of a Sorted Array

题目

给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。

示例 1:

输入:nums = [-4,-1,0,3,10]

输出:[0,1,9,16,100]

解释:平方后,数组变为 [16,1,0,9,100]

排序后,数组变为 [0,1,9,16,100]

分析

这道题目用双指针遍历可以很好的解决,因为平方以后最小的元素肯定是在中间,所以每次只要比较首尾俩个元素的大小取最大值即可

java 复制代码
public class squaresofaSortedArray {
	public static void main(String[] args) {
		int[] arr = {-4,-1,0,3,10};
		int[] brr = getArray(arr);
		for(int i = 0;i<brr.length;i++) {
			System.out.println(brr[i]);
		}
	}
	public static int[] getArray(int[] arr) {
		int start = 0;
		int end = arr.length - 1;
		int[] brr = new int[arr.length];
		int j = arr.length - 1;
		while(start <= end) {
			if(Math.abs(arr[start]) > Math.abs(arr[end])) {
				brr[j--] = arr[start] * arr[start];
				start++;
			} else {
				brr[j--] = arr[end] * arr[end];
				end--;
			}
		}
		return brr;
	}
}
相关推荐
ANYOLY11 分钟前
Redis 面试题库
java·redis·面试
有意义17 分钟前
栈数据结构全解析:从实现原理到 LeetCode 实战
javascript·算法·编程语言
顾林海18 分钟前
从0到1搭建Android网络框架:别再让你的请求在"路上迷路"了
android·面试·架构
懒惰蜗牛18 分钟前
Day63 | Java IO之NIO三件套--选择器(下)
java·nio·选择器·selector·半包粘包·tcp缓冲区
鹿鹿鹿鹿isNotDefined22 分钟前
逐步手写,实现符合 Promise A+ 规范的 Promise
前端·javascript·算法
JavaGuide25 分钟前
美团2026届后端一二面(附详细参考答案)
java·后端
打工人你好27 分钟前
如何设计更安全的 VIP 权限体系
java·jvm·安全
拉不动的猪28 分钟前
前端三大权限场景全解析:设计、实现、存储与企业级实践
前端·javascript·面试
L.EscaRC34 分钟前
Spring IOC核心原理与运用
java·spring·ioc
封奚泽优39 分钟前
下降算法(Python实现)
开发语言·python·算法