1.数组
查询快:数组要求是一块连续的内存空间来存储,这就要求在物理上这一片空间是连续的,每一个元素都有指定的索引index指向内存地址,所以查询对时候,可根据index快速找到对应地址存储的信息,此为查询快.
增删慢:但要进行增删的时候,就必须将目标位置后的全部元素都总体移动,所以就比较耗时,此为增删慢.
2.链表
增删快:链表在物理上是动态地分配储存空间,不要求连续性,可是要求逻辑上的连续。它须要存储每一个元素在内存中的地址,以及它相邻元素的地址,而后像链条同样把各元素链起来,保证了在逻辑上的连续性。
好比:
单链表,每一个元素除了存储自己的值外,还存储了前驱的引用,也就是存储了前驱所在的内存地址信息。
双链表就是不只存储了前驱的引用还存储了后继的引用.数组
增长元素的时候,只需给增长元素添加其前元素或后元素的地址;删除元素的时候,修改目标元素前驱和后驱的首位链接地址. 故此为增删快。索引
查询慢:因为没有像数组那样的索引,所以,查询的时候须要遍历整个链表全部元素的内存地址,而后才能肯定目标元素,此为查询慢。内存
内存中的存储形式能够分为连续存储和离散存储两种。所以,数据的物理存储结构就有连续存储和离散存储两种,它们对应了咱们一般所说的数组和链表。遍历
*由于数组是连续存储的,在操做数组中的数据时就能够根据离首地址的偏移量直接存取相应位置上的数据,可是若是要在数据组中任意位置上插入一个元素,就须要先把后面的元素集体向后移一位为其空出存储空间。引用
与之相反,链表是离散存储的,因此在插入一个数据时只要申请一片新空间,而后将其中的链接关系作一个修改就能够,可是显然在链表上查找一个数据时就要逐个遍历了。
考虑以上的总结可见,数组和链表各有优缺点。在具体使用时要根据具体状况选择。当查找数据操做比较多时最好用数组;当对数据集中的数据进行添加或删除比较多时最好选择链表。链表
做者:MonsieurX
连接:https://www.jianshu.com/p/0b7b41e65194
來源:简书
著做权归做者全部。商业转载请联系做者得到受权,非商业转载请注明出处。总结