力扣刷题-数组-数组理论基础

数组是存放在连续内存空间上的相同类型数据的集合。
力扣刷题-数组-数组理论基础_第1张图片
需要两点注意的是

  • 数组下标都是从0开始的。
  • 数组内存空间的地址是连续

正是因为数组的在内存空间的地址是连续的**,所以我们在删除或者增添元素的时候,就难免要移动其他元素的地址。**
力扣刷题-数组-数组理论基础_第2张图片
注意:数组的元素其实是不能删的,只能覆盖。
力扣刷题-数组-数组理论基础_第3张图片
那么二维数组在内存的空间地址是连续的么?
C++:
不同编程语言的内存管理是不一样的,以C++为例,在C++中二维数组是连续分布的。
测试一下:
力扣刷题-数组-数组理论基础_第4张图片
注意地址为16进制,可以看出二维数组地址是连续一条线的。
力扣刷题-数组-数组理论基础_第5张图片
JAVA:
像Java是没有指针的,同时也不对程序员暴露其元素的地址,寻址操作完全交给虚拟机。
测试一下:
力扣刷题-数组-数组理论基础_第6张图片
这里的数值也是16进制,这不是真正的地址,而是经过处理过后的数值了,我们也可以看出,二维数组的每一行头结点的地址是没有规则的,更谈不上连续。

参考:https://programmercarl.com/

你可能感兴趣的:(leetcode刷题,leetcode,算法,python)