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;
	}
}
相关推荐
魑-魅-魍-魉1 分钟前
Maven 构建报错:无法连接私有仓库及依赖传输失败
java·maven
Thomas.Sir1 分钟前
精通 MySQL 面试题
数据结构·数据库·mysql
小王不爱笑1323 分钟前
Java 泛型详解
java·windows·python
阿Y加油吧4 分钟前
力扣打卡——反转链表、回文链表判断 题解
算法·leetcode
羊小猪~~5 分钟前
算法/力扣--数组典型题目
c语言·c++·python·算法·leetcode·职场和发展·求职招聘
Johnny.Cheung5 分钟前
【德国技术面试】两道小算法题(求两数之和/解谜游戏)
算法·面试
无敌昊哥战神6 分钟前
LeetCode 112. 路径总和 - 避坑指南与多语言全解法(C/C++/Python)
c语言·c++·leetcode
x_xbx7 分钟前
LeetCode:198. 打家劫舍
算法·leetcode·职场和发展
罗湖老棍子7 分钟前
打鼹鼠_二维树状数组(信息学奥赛一本通- P1540)(二维树状数组模版题)
数据结构·算法·树状数组·二维树状数组
_日拱一卒8 分钟前
LeetCode:盛最多水的容器
数据结构·算法·leetcode