数组理论基础
数组是存放在连续内存空间上的相同类型数据的集合。
通俗的说数组在内存中的存储是连续的,所以我们可以通过索引直接获取值
只要知道数组内存首地址,如果是一维数组就是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