DAY 2 代码随想录刷题 数组篇

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 。

有难度,周末回顾完之后再写

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值