数据结构
来源:互联网 发布:怎么做手机淘宝店铺 编辑:程序博客网 时间:2024/06/07 09:23
数据结构是编程最重要的基本功之一!
学了顺序表和链表,你就知道,在查询操作更多的程序中,你应该用顺序表;而修改操作更多的程序中,你要使用链表;而单向链表不方便怎么办,每次都从头到尾好麻烦啊,怎么办?你这时就会想到双向链表or循环链表。
学了栈之后,你就知道,很多涉及后入先出的问题,例如函数递归就是个栈模型、Android的屏幕跳转就用到栈,很多类似的东西,你就会第一时间想到:我会用这东西来去写算法实现这个功能。
学了队列之后,你就知道,对于先入先出要排队的问题,你就要用到队列,例如多个网络下载任务,我该怎么去调度它们去获得网络资源呢?再例如操作系统的进程(or线程)调度,我该怎么去分配资源(像CPU)给多个任务呢?肯定不能全部一起拥有的,资源只有一个,那就要排队!那么怎么排队呢?用普通的队列?但是对于那些优先级高的线程怎么办?那也太共产主义了吧,这时,你就会想到了优先队列,优先队列怎么实现?用堆,然后你就有疑问了,堆是啥玩意?自己查吧,敲累了。
总之好好学数据结构就对了。我觉得数据结构就相当于:我塞牙了,那么就要用到牙签这“数据结构”,当然你用指甲也行,只不过“性能”没那么好;我要拧螺母,肯定用扳手这个“数据结构”,当然你用钳子也行,只不过也没那么好用。学习数据结构,就是为了了解以后在IT行业里搬砖需要用到什么工具,这些工具有什么利弊,应用于什么场景。以后用的过程中,你会发现这些基础的“工具”也存在着一些缺陷,你不满足于此工具,此时,你就开始自己在这些数据结构的基础上加以改造,这就叫做自定义数据结构。而且,你以后还会造出很多其他应用于实际场景的数据结构。。你用这些数据结构去造轮子,不知不觉,你成了又一个轮子哥。
清华大学出版社出版的《数据结构(C++语言版)》和《数据结构习题解析(C++语言版)》,作者是邓俊辉。
这两本书是他在“数据结构”这门MOOC课程中推荐的。我是在MOOC学院看到这门课的,据清华的学生说,这课在校内相当火爆。去年,清华把它做成MOOC课程,放在学堂在线和edX上,任何人都可以注册去上课。
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- 数据结构
- centos 编译 vlc-android
- React 的 diff 算法
- python小贴士之strip() split()
- linux netfilter
- 在i3 Cpu上允许64位系统
- 数据结构
- ubuntu 14 java web服务器搭建
- Android开发时图片Bitmap序列化问题(How to fix a java.io.NotSerializableException: android.graphics.Bitmap)
- aliyun 一键安装 备忘
- 杭电acm2124
- java多线程之volatile关键字与线程栈内存
- ArcGIS教程:聚合 (Spatial Analyst)
- 前沿技术解密——Virtual DOM
- 【项目记录】常用opencv函数运行速度实测