一、从内存角度上看
1.数组静态分配内存,链表动态分配内存;
2.数组在内存中连续,链表不连续;
3.数组元素在栈区,链表元素在堆区;
二、从逻辑角度上看
1.数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n);
2.数组插入或删除元素的时间复杂度O(n),链表的时间复杂度O(1)。
总结:
如果需要快速访问数据,很少或不插入和删除元素,就应该用数组;相反, 如果需要经常插入和删除元素就需要用链表数据结构了。
一、从内存角度上看
1.数组静态分配内存,链表动态分配内存;
2.数组在内存中连续,链表不连续;
3.数组元素在栈区,链表元素在堆区;
二、从逻辑角度上看
1.数组利用下标定位,时间复杂度为O(1),链表定位元素时间复杂度O(n);
2.数组插入或删除元素的时间复杂度O(n),链表的时间复杂度O(1)。
总结:
如果需要快速访问数据,很少或不插入和删除元素,就应该用数组;相反, 如果需要经常插入和删除元素就需要用链表数据结构了。