力扣 LeetCode 977. 有序数组的平方(Day1:数组)

解题思路:

方法一:先平方再快排

方法二:双指针

因为可能有负数,所以对于一个数组 [ -5 , -3 , 0 , 2 , 4 ] 可以从两边向内靠拢,最大值一定出现在两端

设置指针 i 和指针 j 分别从左右两边靠拢

因为要从小到大排序,所以用 k 倒着赋值即可

java 复制代码
class Solution {
    public int[] sortedSquares(int[] nums) {
        int i = 0;
        int j = nums.length - 1;
        int k = nums.length - 1;
        int[] res = new int[nums.length];

        while (i <= j) {
            if (nums[i] * nums[i] < nums[j] * nums[j]) {
                res[k] = nums[j] * nums[j];
                k--;
                j--;
            } else {
                res[k] = nums[i] * nums[i];
                k--;
                i++;
            }
        }

        return res;
    }
}
相关推荐
不二狗43 分钟前
每日算法 -【Swift 算法】电话号码字母组合
开发语言·算法·swift
AL流云。1 小时前
【优选算法】分治
数据结构·算法·leetcode·排序算法
行驶2 小时前
数据结构 - 栈与队列
数据结构
haoly19892 小时前
数据结构篇--分离链表vs线性探测
数据结构
小贾要学习2 小时前
【数据结构】AVL树的实现
数据结构
andyweike2 小时前
数据结构-文件
数据结构
andyweike2 小时前
数据结构-线性表
数据结构
C++ 老炮儿的技术栈6 小时前
UDP 与 TCP 的区别是什么?
开发语言·c++·windows·算法·visual studio
殇者知忧6 小时前
【论文笔记】若干矿井粉尘检测算法概述
深度学习·神经网络·算法·随机森林·机器学习·支持向量机·计算机视觉
mochensage8 小时前
C++信息学竞赛中常用函数的一般用法
java·c++·算法