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;
	}
}
相关推荐
智者知已应修善业5 分钟前
【51单片机4位静态数码管显示1234】2023-11-14
c++·经验分享·笔记·算法·51单片机
♡すぎ♡14 分钟前
镜面 IBL 预过滤贴图的计算
算法·计算机图形学·贴图·pbr
苏三的开发日记23 分钟前
Spring Boot启动慢如何优化
面试·编程语言
神奇小汤圆31 分钟前
125K+ star 的 AI 爬虫神器:让你的 Agent 秒变网络达人
面试
Lsk_Smion32 分钟前
力扣实训 _ [200].岛屿数量
算法·leetcode·深度优先
Boom_Shu40 分钟前
长方形的关系
数据结构·c++·算法
Refrain_zc43 分钟前
Android 音视频通话核心 —— 音频编码(AAC)完整解析
java
xiaoshuaishuai81 小时前
C# AvaloniaUI 资源找不到报错
java·服务器·前端·windows·c#
ZhengEnCi1 小时前
O07-银行家算法
算法
装不满的克莱因瓶1 小时前
图像尺寸调整:缩放矩阵如何改变像素坐标?
人工智能·线性代数·数学·算法·机器学习·矩阵