代码随想录算法训练营第二天|977.有序数组的平方 209.长度最小的子数组 59.螺旋矩阵II

数组 part02

977.有序数组的平方

这一题那难度确实偏低,第一遍可以想出这两种解法。

第一种,暴力解法就是遍历数组,让每个数字平方,然后重新排列即可。较慢。

第二种,这个方法是基于平方结果最大数一定是在最左边或者最右边。新建一个和原数组等长的数组,设置两个指针,一个指针在最左边,一个指针在最右边,比较最左边和最右边的哪个数的平方更大,将更大的那个平方结果放在新数组的最后的位置。依次填满即可。

209.长度最小的子数组

这个题是唯一今天有卡壳的题目。需要重点标记,明天进行重复,加深记忆。

首先是想到了暴力解法,使用两个for循环依次遍历,写法简单,但是超时了。。。

学到的方法:原理类似于栈,依次存入数字,在每次存入数字后进行判断是否满足目标值,如果不满足就继续遍历加入后面的数字,如果已经满足,则要进行如下操作:1.将现在满足情况的数组长度与现有的最短长度进行比较,并且取小的那一个(用Math.min()来进行)2.目前的总和减掉最左端的数字  3.最左端的指针右移。

59.螺旋矩阵II

找到左右上下边界,依次填充即可。较基础。

第二天总体来说不算难。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值