leetcode题型分析《数组》

1 双指针

使用两个相同反向或者相反方向的指针扫描数组从而达到解题的目的。

相反方向指针经常用来求排序数组中的两数之和。

相同方向指针经常用来求正数数组中子数组的和或者乘积。

剑指offer II 6 排序数组中两个数组之和

c940b873873245f69cfad2672031d0a9.jpg

 剑指offer II 7 数组中和为0的3个数字

思路:要求三数之和,先求两数之和,固定变量i,求tagert - sum(j, k) = nums[i];如果i,j,k对应的和大于0,k向左移动,如果和小于0,j向右移动。

9ffacc6efda5452dab5fbf17c9bbbab4.jpg

a88ea2f5fe994c66bc4cf5205e795191.jpg

剑指offer II 8 和大于或等于k的最短子数组

解题思路:初始化双指针,使其都指向数组第一个元素。如果子数组之间和大于等于k,左指针向右移动。如果小于k,右指针往前移动。

df246a6f6cf6438abeeaf3b78d7df833.jpg

 剑指offer II 9 乘积小于k的子数组

解题思路同题8

e0d5ba328b244b0ea6dc5e02f4747468.jpg

 

2 前缀和

       假设有一数组nums,  用sum[i] 记录前nums[0...i-1] 之和, 那么区间[i..j] 之间的和则为:sum[i...j]  = sum[j+1] - sum[i];

      利用hash map键值为数组累加和,值为扫描当前数组得下标。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值