系统程序员成长计划-容器与算法(一)(上)

Sunday, March 08th, 2009 | Author: admin | » Edit «

 

转载时请注明出处和作者联系方式
文章出处:http://www.limodev.cn/blog
作者联系方式:李先静 <xianjimli at hotmail dot com>

系统程序员成长计划-容器与算法(一)(上)

前面我们通过组合的方法,用双向链表实现了队列。大家已经看到,它的实现非常简单。有的读者可能会问了:你说过双向链表和动态数组都有各自的适用范 围,在有的情况下,用双向链表合适,在有的情况下,用动态数组合适。你用双向链表实现了队列,是不是有必要用动态数组再实现一次呢?如果对栈同样如此,那 是不是做了太多重复的工作,有违背DRY(don’t repeat yourself)原则呢?

问得好,这就是本章要学习的。我们请读者实现一个队列,要求如下:

o由调用者决定用双向链表实现还是用动态数组实现,
o 在运行时决定,而不是在编译时决定(宏定义)。
o 如果调用者乐意,他以后还可以选择用单向链表来实现,而不必修改队列的实现代码。
o Don’t Repeat Yourself。

请读者不要急着看后面的内容,先仔细想想,尝试完成这个任务。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值