209 长度最小的子数组
题目链接
题目
给定一个含有 n
个正整数的数组和一个正整数 target
。
找出该数组中满足其总和大于等于 target
的长度最小的子数组 [nums l, nums l+1, ..., nums r-1, nums r]
,并返回其长度。如果不存在符合条件的子数组,返回 0
。
思路
滑动窗口
- 时间复杂度: O ( n ) O(n) O(n)
- 空间复杂度: O ( 1 ) O(1) O(1)
解答
class Solution:
def minSubArrayLen(self, target: int, nums: List[int]) -> int:
if nums is None or len(nums)==0:
return 0
lenf=len(nums)+1
total=0
i=j=0
while (j<len(nums)):
total=total+nums[j]
j+=1
while (total>=target):
lenf=min(lenf,j-i)
total=total-nums[i]
i+=1
if lenf==len(nums)+1:
return 0
else:
return lenf
59 螺旋矩阵
题目链接
题目
给你一个正整数 n
,生成一个包含 1
到 n2
所有元素,且元素按顺时针顺序螺旋排列的 n x n
正方形矩阵 matrix
。
示例 1:
输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]
示例 2:
输入:n = 1
输出:[[1]]
思路
循环不变量原则
- 时间复杂度: O ( n 2 ) O(n^2) O(n2): 模拟遍历二维矩阵的时间
- 空间复杂度: O ( 1 ) O(1) O(1)
解答
class Solution:
def generateMatrix(self, n: int) -> List[List[int]]:
# ans = []
# n_s = n ** 2
nums = [[0] * n for _ in range(n)]
# for i in range(n_s):
# nums.append(i + 1)
# print(num)
startx, starty = 0, 0 # 起始点
loop, mid = n // 2, n // 2 # 迭代次数,n为奇数时,矩阵的中心点
count = 1 # 计数
for offset in range(1, loop + 1) :
for i in range(starty, n - offset) : # 从左至右,左闭右开
nums[startx][i] = count
count += 1
for i in range(startx, n - offset) : # 从上至下
nums[i][n - offset] = count
count += 1
for i in range(n - offset, starty, -1) : # 从右至左
nums[n - offset][i] = count
count += 1
for i in range(n - offset, startx, -1) : # 从下至上
nums[i][starty] = count
count += 1
startx += 1 # 更新起始点
starty += 1
if n % 2 != 0 :
nums[mid][mid] = count
return nums