031--链表的使用

1.参考网址:http://blog.csdn.net/liujiahan629629/article/details/18013523

2.Demo下载地址:http://pan.baidu.com/s/1hrI5YAC

3.链表类型

  • 单向链表
  • 双端链表(不是双向链表)
  • 有序链表

4.笔记展示

LinkedList单向链表使用总结:
1.类说明:
    Data类:数据
    LinkedList类:链表类
    
2.方法说明:
    insertFirst:在链表的第一个位置添加元素
    deleteFirst:删除链表的第一个元素
    find:从链表中查找相关的元素
    remove:从链表中移除相关的元素
    isEmpty:判断链表是否为空
    display:将链表中的元素全部打印出来
    
    

==================================================
FirstLastList双端链表(不是双向链表)使用总结:
1.类说明:
    Data类:数据
    FirstLastList类:链表类
    
2.方法说明:
    insertFirst:在表头插入一个新的链接点,时间复杂度O(1)
    insertLast:在表尾插入一个新的链接点,时间复杂度O(1)
    deleteFirst:删除表头的链接点,时间复杂度O(1)
    deleteLast:删除表尾的链接点,由于只保存了表尾的链接点,而没有保存表尾的前一个链接点(这里就体现出双向链表的优势了)
                     所以在删除表尾链接点时需要遍历以找到表尾链接点的前一个链接点,需查找N-1次,也就是O(N)



==================================================
SortedList有序链表:(数据按从小到大)排列使用总结:
1.类说明:
    Data类:数据
    SortedList类:链表类
    
2.方法说明:
    insert:需要比较N/2次,时间复杂度O(N)
    deleteFirst:需要比较N/2次,时间复杂度O(N)

3.总结:
    表的插入和删除平均需要比较N/2次,即O(N),但是获取最小数据项只需O(1),因为其始终处于表头,
    对频繁操作最小数据项的应用,可以考虑使用有序链表实现,如:优先级队列
    劣势在于随机访问,无法像数组那样直接通过下标找到特定的数据项 
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值