就知道有这么回事,但是又不明所以,因为学到List集合中特有方法等包括add,然后add方法中出现个这个添加元素效率的问题,引出我对于在数组中末位添加元素效率是最高的疑问,不懂
2条回答 默认 最新
- 谢玄. 2022-10-29 01:31关注
内存的分配
因为List的内存分配是连续的。
比如一个LIst长度为10,每个子单元大小为2,那么List就是在内存0x00
一直到0x12
连续的一段有序数组。
当你获取 List[n] 的时候 他就会获取到 0x00 + ( 0x02 * n ) 这个地址的数据 。
如果你是在末尾添加的话,比如List[10] 他就直接在这个 0x00 + ( 0x02 * 10 ) 写入数据即可。
如果你是在中间写数据的话,那么就是在 0x00 + ( 0x02 * 10 ) 的位置写入最后一个数据,并且一直往推到你要插入的数据的位置。这样子效率就会大大降低。总结
在末尾添加数据只需要动一个数据。而在中间插入需要移动其他的数据后再将其插入。所以数组中末位添加元素效率是最高。
$$\color{red}{有问题可以回复我,望采纳}$$本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 机器学习预测遇到的目标函数问题
- ¥15 python的EOFError该怎么解决?
- ¥15 Fluent,液体进入旋转区域体积分数不连续
- ¥15 java linux下将docx文件转pdf
- ¥15 maven无法下载依赖包
- ¥15 关于pycharm, Callable[[str],bool]作为方法参数使用时, lambda 类型不提示问题
- ¥15 layui数据重载无效
- ¥15 寻找了解qq家园纵横四海的程序猿。
- ¥15 optisystem
- ¥15 VB.NET画图时的撤销编程