首页 > 编程语言 >代码随想录算法训练营第二天 | 数组 977.有序数组的平方

代码随想录算法训练营第二天 | 数组 977.有序数组的平方

时间:2024-04-05 12:45:12浏览次数:29  
标签:977 平方 right nums 随想录 List 数组 指针

leetcode 977.有序数组的平方

题目

977.有序数组的平方
给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。
示例 1:

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

解题思路1

使用暴力法,先对原数组中每个数字做平方运算,然后对新数组进行排序

实现代码1

from typing import List
class Solution:
    def sortedSquares(self, nums: List[int]) -> List[int]:
        # 对原数组中的每个元素进行平方计算
        i = 0
        while i < len(nums):
            nums[i] = nums[i] ** 2
            i += 1
        # print(nums) # 平方后的新数组
        
        # 对新数组的元素进行递增排序
        j = 0
        while j < len(nums):
            left = 0    # 用于获取位置
            right = left + 1    # 用于获取值
            while right <= len(nums) - 1:
                if nums[right] < nums[left]:
                    tmp = nums[right]
                    nums[right] = nums[left]
                    nums[left] = tmp
                    left += 1
                right += 1
            j += 1
        return nums    

test = Solution()
nums = [-4,-1,0,3,10]
print(test.sortedSquares(nums))  

实现代码1在LeetCode执行会超出时间限制,看题解可以直接使用排序函数,如下:

实现代码2

from typing import List
class Solution:
    def sortedSquares(self, nums: List[int]) -> List[int]:
        # 对原数组中的每个元素进行平方计算
        i = 0
        while i < len(nums):
            nums[i] = nums[i] ** 2
            i += 1       
        
        # 对新数组的元素进行递增排序
        nums.sort()
        return nums    

解题思路2

使用双指针法:
原数组中有负数,每个元素平方后,数组中的大数一定是在左边或右边
(1)通过左右双指针分别获取数组两边的元素,比较后获得数值大的元素
(2)创建一个空数组,从右边开始存放元素,最后一位是(1)左右指针比较后得到的大数
(3)循环以上操作,左指针向右移动取值,右指针向左移动取值,比较大小,把大数从右向左依次放到结果数组中
(4)当左右指针相遇后,循环结束

实现代码

from typing import List
class Solution:
    def sortedSquares(self, nums: List[int]) -> List[int]:
        left = 0    # 原数组左边第一位指针
        right = len(nums) - 1   # 原数组右边第一位指针
        i = len(nums) - 1   # 结果数组右边第一位指针
        arr = [float('inf')] * len(nums)    # 定义新数组,长度和原数组一样,float('inf')表示正无穷大
        while left <= right:
            if nums[left] ** 2 > nums[right] ** 2:
                arr[i] = nums[left] ** 2
                left += 1   # 原数组左指针向右移动
            else:
                arr[i] = nums[right] ** 2
                right -= 1  # 原数组右指针向左移动
            i -= 1  # 结果数组指针向左移动
        return arr       

test = Solution()
nums = [-4,-1,0,3,10]
print(test.sortedSquares(nums))

标签:977,平方,right,nums,随想录,List,数组,指针
From: https://www.cnblogs.com/wanglin2016/p/18115586

相关文章

  • LeetCode in Python 88. Merge Sorted Array (合并两个有序数组)
    合并有序数组也有两种方法,区别是空间复杂度不同。第一种,重新开辟一个数组空间,大小为O(m+n),另外需要三个指针分别指向两个有序数组和新开辟的数组,依次判断两个数组内元素大小,不断更新指针即可。第二种,无需单独开辟空间,在第一个数组(该数组空间足够存放两个数组总长的数据)内进行......
  • 深入理解指针2:数组名理解、一维数组传参本质、二级指针、指针数组和数组指针
    1、数组名理解首先来看一段代码:intmain(){ intarr[10]={1,2,3,4,5,6,7,8,9,10}; printf("%d\n",sizeof(arr)); return0;}输出的结果是:40,如果arr是数组首元素的地址,那输出应该是4/8才对。其实数组名就是数组首元素(第一个元素)的地址是对的,但是有两个例外:sizeof......
  • 代码随想录第30天|51. N皇后
    51. N皇后51.N皇后-力扣(LeetCode)代码随想录(programmercarl.com)这就是传说中的N皇后?回溯算法安排!|LeetCode:51.N皇后_哔哩哔哩_bilibili按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。n 皇后问题 研究的是如何将 n 个皇后放置在......
  • 代码随想录第29天|491.递增子序列 46.全排列 47.全排列 II
    目录:491.递增子序列46.全排列47.全排列II 491.递增子序列491.非递减子序列-力扣(LeetCode)代码随想录(programmercarl.com)回溯算法精讲,树层去重与树枝去重|LeetCode:491.递增子序列_哔哩哔哩_bilibili给你一个整数数组 nums ,找出并返回所有该数组中不同的递......
  • 代码随想录算法训练营第一天 | 704.二分查找、27.移除元素
    704.二分查找文档讲解:代码随想录(https://www.programmercarl.com/)视频讲解:https://www.bilibili.com/video/BV1fA4y1o715/状态:704有思路但是不完善题目给定一个n个元素有序的(升序)整型数组nums和一个目标值target,写一个函数搜索nums中的target,如果目标值存在返回下......
  • 『VUE』11. 操作数组的方法(详细图文注释)
    目录vue中操作数组的方法会修改原数组的会进行渲染更新不修改原数组的不会进行渲染更新push自动渲染concat赋值渲染总结欢迎关注『VUE』专栏,持续更新中欢迎关注『VUE』专栏,持续更新中vue中操作数组的方法vue中数组数据呈现在网页,只检测一开始用到的数......
  • 数组Api归纳篇——splice与slice
    1、splicesplice() 方法就地移除或者替换已存在的元素/添加新的元素。 语法:splice(start,deleteCount,item)        1、start开始索引    2、deleteCount删除几个    3、item替换/添加的元素    4、返回值:一个包含了【删除的元......
  • c语言中关于字符数组赋值问题
    一维数组代码#include<iostream>#include<cstring>#include<algorithm>usingnamespacestd;constintN=1010;charstr[N];charst[N];chars1[N];chars2[N];/*abcdeabcdeabcdeabcde*/intmain(){ scanf("%s",&str+1); ......
  • 数组赋值
    1publicclassShuZhu{2publicstaticvoidmain(String[]args){3int[]a1={2,3,4,5,6,7,8};4int[]a2=a1;56for(inta3:a17){8System.out.println(a3);9}10System.o......
  • 代码随想录算法训练营第二十一天| 530. 二叉搜索树的最小绝对差 501. 二叉搜索树中的
    530.二叉搜索树的最小绝对差https://leetcode.cn/problems/minimum-absolute-difference-in-bst/description/TreeNodepre=null;intres=Integer.MAX_VALUE;publicintgetMinimumDifference(TreeNoderoot){if(root==null)return0;pr......