Leetcode977有序数组的平方(双指针解法)

举报
伯约同学 发表于 2022/03/23 22:05:31 2022/03/23
【摘要】 Leetcode977有序数组的平方题目给你一个按 **非递减顺序** 排序的整数数组 `nums`,返回 **每个数字的平方** 组成的新数组,要求也按 **非递减顺序** 排序。答题```/** \* @param {number[]} nums \* @return {number[]} */var sortedSquares = function(nums) {  let left ...

Leetcode977有序数组的平方

题目

给你一个按 **非递减顺序** 排序的整数数组 `nums`,返回 **每个数字的平方** 组成的新数组,要求也按 **非递减顺序** 排序。

答题

```
/**
 \* @param {number[]} nums
 \* @return {number[]}
 */
var sortedSquares = function(nums) {
  let left = 0
  let right = nums.length -1
  let res = []
  while(left <= right){
​    if(nums[left]*nums[left] >= nums[right]*nums[right]){
​      res.push(nums[left]*nums[left])
​      left++
​    }else{
​      res.push(nums[right]*nums[right])
​      right--
​    }
  }
  return res.reverse()
};
```

解题思路:

我们中学的时候都有学到曲线,大家应该都知道x的平方这条曲线怎么个走势吧,对于这道题而言,我们可以计算出对应数字的平方,然后把它插入到数组中,如果左边的平方大就左边+1如果右边的平方大就右边-1这样我们可以知道所有的数全都求一个平方,再把整个数组翻转过来就好了。

至于为什么不直接unshift呢?毕竟unshift方法操作数组是在最前面插个队,这样后面所有的都得往后挪一个,不如push操作,直接放在最后面,省得每个元素后移了。

有感兴趣的可以试试两者之间的差别哈。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。