LeetCode 0977.有序数组的平方【Go】

简介: LeetCode 0977.有序数组的平方【Go】

有序数组的平方

LeetCode977. 有序数组的平方

题目描述

给你一个按非递减顺序排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。-10^4 <= nums[i] <= 10^4

示例 1:

输入:nums = [-4,-1,0,3,10]
输出:[0,1,9,16,100]
解释:平方后,数组变为 [16,1,0,9,100]
排序后,数组变为 [0,1,9,16,100]

示例 2:

输入:nums = [-7,-3,2,3,11]
输出:[4,9,9,49,121]

思路

题目要求

  • 给定一个含负数的升序排列的数组,
  • 返回每个数字的平方组成的新的升序数组

暴力解法:平方后排序

暴力解法没有利用题目中给到的条件:给定一个含正负数的升序数组。所以平方以后的大值肯定出现在两侧,不是左边就是右边(负数的平方为正数)

双指针法:两个指针分别指向数组的首部和尾部,每次比较两个指针所指值的大小,将大的逆序放入新数组。将双指针从外向内移动不会发生数组越界问题。

注意

因为是逆序存入数组,所以for循坏的循坏变量ilen(nums)-1开始递减。

代码

Go

func sortedSquares(nums []int) []int {
  length := len(nums)
  left, right := 0, length-1
  newNums := make([]int, length)
  for i := len(nums) - 1; i >= 0; i-- {
    if l, r := nums[left]*nums[left], nums[right]*nums[right]; l < r {
      newNums[i] = r
      right--
    } else {
      newNums[i] = l
      left++
    }
  }
  return newNums
}

Link

GitHub

目录
相关文章
|
17天前
|
算法 测试技术 程序员
力扣经典150题第二十七题:两数之和 II - 输入有序数组
力扣经典150题第二十七题:两数之和 II - 输入有序数组
13 1
|
1月前
|
存储 算法 Java
【经典算法】LeetCode 26. 删除有序数组中的重复项:(Java/C/Python3实现含注释说明,Easy)
【经典算法】LeetCode 26. 删除有序数组中的重复项:(Java/C/Python3实现含注释说明,Easy)
23 2
|
26天前
|
存储 算法
leetcode题解:88.合并有序数组
leetcode题解:88.合并有序数组
14 0
|
26天前
|
索引
leetcode题解:26.删除有序数组重复项
leetcode题解:26.删除有序数组重复项
10 0
|
1月前
|
算法
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
|
1月前
|
存储 算法 数据挖掘
LeetCode 题目 88:双指针\直接\递归\插入排序\归并排序 实现合并两个有序数组
LeetCode 题目 88:双指针\直接\递归\插入排序\归并排序 实现合并两个有序数组
|
1月前
|
SQL 算法 数据挖掘
LeetCode 第四题:寻找两个正序数组的中位数 【4/1000 】【python + go】
LeetCode 第四题:寻找两个正序数组的中位数 【4/1000 】【python + go】
|
1月前
|
算法 Java Go
【经典算法】LeetCode 392 判断子序列(Java/C/Python3/Go实现含注释说明,Easy)
【经典算法】LeetCode 392 判断子序列(Java/C/Python3/Go实现含注释说明,Easy)
27 0
|
1月前
|
存储 算法 Java
【经典算法】LeetCode112. 路径总和(Java/C/Python3/Go实现含注释说明,Easy)
【经典算法】LeetCode112. 路径总和(Java/C/Python3/Go实现含注释说明,Easy)
17 0
|
1月前
|
算法 Java Go
【经典算法】LeetCode 100. 相同的树(Java/C/Python3/Go实现含注释说明,Easy)
【经典算法】LeetCode 100. 相同的树(Java/C/Python3/Go实现含注释说明,Easy)
12 0