DAY 2 数组篇
977.有序数组的平方
题目
给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。
思路
采样双指针法的思想,设置l和r两个边界指针,判断这两个数的平方大小,再进一步更新,如果左边界大,则l++;如果右边界大,则r–,同时把值存入新数组的最后一位。
代码
class Solution(object):
def sortedSquares(self, nums):
"""
:type nums: List[int]
:rtype: List[int]
"""
l, r, i = 0, len(nums)-1, len(nums)-1
new = [float('inf')] * len(nums) # 定义列表
while l <= r:
if nums[l] ** 2 < nums[r] ** 2: # 左右边界进行对比,找出最大值
new[i] = nums[r] ** 2
r -= 1 # 右指针往左移动
else:
new[i] = nums[l] ** 2
l += 1 # 左指针往右移动
i -= 1 # 存放结果的指针需要往前平移一位
return new
209.长度最小的子数组
题目
给定一个含有 n 个正整数的数组和一个正整数 target 。
找出该数组中满足其总和大于等于 target 的长度最小的 连续子数组 [numsl, numsl+1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。
思路
采用滑动窗口法。滑动窗口的精妙之处在于根据当前子序列和大小的情况,不断调节子序列的起始位置。用一个终止位置的循环代替暴力解法的两个循环。
代码
class Solution(object):
def minSubArrayLen(self, target, nums):
"""
:type target: int
:type nums: List[int]
:rtype: int
"""
begin = 0
end = 0
l = len(nums)
min_len = float('inf')
cur_num = 0 #当前累加值
while end < l:
cur_num += nums[end]
while cur_num >= target: #当前累加值大于目标
min_len = min(min_len, end-begin+1)
cur_num -= nums[begin]
begin += 1
end += 1
#需要注意的是返回时要判断min_len是否为正无穷,如果是,则说明不存在符合条件的子数组
return min_len if min_len != float('inf') else 0
59.螺旋矩阵
题目 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。
有难度,周末回顾完之后再写