数组是线性结构,能够直接索引,即要去第i个元素,a[i]便可。链表也是线性结构,要取第i个元素,只需用指针日后遍历i次就可。貌似链表比数组还要麻烦些,并且效率低些。数组
想到这些相同处中的一些细微的不一样处,因而他们的真正不一样处渐渐显现了:链表的效率为什么比数组低些?先从二者的初始化开始。数组无需初始化,由于数组的元素在内存的栈区,系统自动申请空间。而链表的结点元素在内存的堆区,每一个元素须手动申请空间,如malloc。也就是说数组是静态分配内存,而链表是动态分配内存。链表如此麻烦为什么还要用链表呢?数组不能彻底代替链表吗?回到这个问题只需想一想咱们当初是怎么完成学生信息管理系统的。为什么那时候要用链表?由于学生管理系统中的插入,删除等操做都很灵活,而数组则大小固定,也没法灵活高效的插入,删除。由于堆操做灵活性更强。数组每次插入一个元素就须要移动已有元素,而链表元素在堆上,无需这么麻烦。指针
说了这么多,数组和链表的区别整理以下:索引
数组静态分配内存,链表动态分配内存;内存
数组在内存中连续,链表不连续;效率
数组元素在栈区,链表元素在堆区;遍历
数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n);链表
数组插入或删除元素的时间复杂度O(n),链表的时间复杂度O(1)。移动