数组总结(二分、双指针、滑动窗口、模拟、前缀和)

数组理论基础

 

数组是存放在连续内存空间上的相同类型数据的集合。

通俗的说数组在内存中的存储是连续的,所以我们可以通过索引直接获取值

 

只要知道数组内存首地址,如果是一维数组就是arr[0],如果是二维数组,那么每个arr[i][0]就是首地址,我们可以根据存储元素的大小来推出后面所有元素的地址。

 

注意二维数组其中的一位数组是连续的,一维数组和一维数组之间不一定连续。

 

因为数组在内存空间的地址是连续的,所以我们在删除或者增添元素的时候,就难免要移动其他元素的地址。

例如插入一个元素,后面所有元素都要后移,或者删除一个元素,后面所有元素都要前移。

 

 

数组的一些常见题目类型

 

 

二分查找

数组:每次遇到二分法,都是一看就会,一写就废https://programmercarl.com/0704.%E4%BA%8C%E5%88%86%E6%9F%A5%E6%89%BE.html

 

双指针

数组:就移除个元素很难么?https://programmercarl.com/0027.%E7%A7%BB%E9%99%A4%E5%85%83%E7%B4%A0.html

 

滑动窗口
 

滑动窗口

 

模拟行为

数组:这个循环可以转懵很多人!https://programmercarl.com/0059.%E8%9E%BA%E6%97%8B%E7%9F%A9%E9%98%B5II.html

前缀和

数组:求取区间和https://programmercarl.com/kamacoder/0058.%E5%8C%BA%E9%97%B4%E5%92%8C.html

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值