题目链接:https://leetcode-cn.com/problems/squares-of-a-sorted-array/
给定一个按非递减顺序排序的整数数组 A,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。
示例 1:
输入:[-4,-1,0,3,10]
输出:[0,1,9,16,100]
示例 2:
输入:[-7,-3,2,3,11]
输出:[4,9,9,49,121]
提示:
1 <= A.length <= 10000
-10000 <= A[i] <= 10000
A 已按非递减顺序排序。
¥¥¥¥¥¥¥¥¥¥¥¥¥¥
我的:
class Solution {
public int[] sortedSquares(int[] A) {
int[] r=new int[A.length];
for(int m=0;m<A.length;m++){
r[m]=A[m]*A[m];
}
for(int i=0;i<r.length;i++){
for(int j=0;j<r.length-i-1;j++){
if(r[j]>r[j+1]){
int tmp=r[j];
r[j]=r[j+1];
r[j+1]=tmp;
}
}
}
return r;
}
}
有点偷懒,自己又想不出好的方法。找了一个评论里的优秀代码:
class Solution {
public int[] sortedSquares(int[] A) {
int start = 0;
int end = A.length;
int i = end - 1;
int[] nums = new int[end--];
while (i >= 0) {
nums[i--] = A[start]*A[start] >= A[end]*A[end] ? A[start]*A[start++] : A[end]*A[end--];
}
return nums;
}
}
对指针这个词,印象里第一次听说的时候是:java里没有指针。。。这里为啥又有了呢?我的理解是,这个“指针”,是我们自己定义的一个可以移动的数组下标而已,跟之前听说的说法并不矛盾。比如快排里面,说定义了两个“游标”,其实是一个意思。