【力扣刷题 day2】977.有序数组的平方 简单
2021/7/20 23:37:24
本文主要是介绍【力扣刷题 day2】977.有序数组的平方 简单,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目
给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。
思路
当0号位小于0时,取出,使用二分查找将其绝对值插入,最后一起平方。注意长度为1时单独讨论
结果
不忍直视
代码
class Solution(object): def sortedSquares(self, nums): """ :type nums: List[int] :rtype: List[int] """ lenn = len(nums) if(lenn==1): nums[0] *= nums[0] return nums while(nums[0]<0): temp = abs(nums[0]) #取出第一个负数的绝对值 del nums[0] #删除第一个负数 start,end = 0,lenn-2 mid = (start + end) / 2 while(start <= end): mid = (start+end)/2 if(temp == nums[mid]): nums.insert(mid+1,temp) break #插入,跳出 elif(temp > nums[mid]): start = mid+1 else: end = mid-1 if(start > end):#没找到相等的 if(temp>nums[mid]): nums.insert(mid + 1, temp) else: nums.insert(mid, temp) for i in range(0,lenn): nums[i] *= nums[i] return nums
改进 双指针
头尾一起
class Solution(object): def sortedSquares(self, nums): """ :type nums: List[int] :rtype: List[int] """ '''双指针''' reslst = [] front,post = 0,len(nums)-1 while(front != post): f = abs(nums[front]) p = abs(nums[post]) if(f>p): reslst.insert(0,f*f) front+=1 else: reslst.insert(0,p*p) post-=1 reslst.insert(0, nums[front]*nums[front]) return reslst
但是这样时间很长,可能因为每次都在第一个加,动态变化 ,可以直接把答案列表设置成n个长度,用pos记录存放位置
class Solution: def sortedSquares(self, nums): n = len(nums) ans = [0] * n i, j, pos = 0, n - 1, n - 1 while i <= j: if nums[i] * nums[i] > nums[j] * nums[j]: ans[pos] = nums[i] * nums[i] i += 1 else: ans[pos] = nums[j] * nums[j] j -= 1 pos -= 1 return ans
这篇关于【力扣刷题 day2】977.有序数组的平方 简单的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-30Sentinel限流教程:新手入门指南
- 2024-12-30Springboot框架教程:新手入门及初级技巧
- 2024-12-30Springboot框架教程:初学者必看指南
- 2024-12-30Springboot企业级开发教程:从入门到实践
- 2024-12-30Springboot企业级开发教程:新手入门与实践
- 2024-12-30SpringBoot微服务教程:入门与实践
- 2024-12-30SpringBoot项目开发教程:从入门到实践
- 2024-12-30Springboot项目开发教程:从入门到实践
- 2024-12-30SpringCloud Alibaba教程:轻松入门与实践
- 2024-12-30SpringCloud Alibaba教程:入门与实践指南