为什么要学数据结构?_牧小农的博客-程序员秘密_为什么要学习数据结构

技术标签: 算法  树结构  游戏  数据结构  线性结构  

一、前言

在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利。很多人认为,只要掌握几种开发工具就可以成为编程高手,其实,这是一种误解。要想成为一个专业的开发人员,至少需要以下三个条件:

1) 能够熟练地选择和设计各种数据结构和算法

2) 至少要能够熟练地掌握一门程序设计语言

3) 熟知所涉及的相关应用领域的知识

其中,后两个条件比较容易实现,而第一个条件则需要花相当的时间和精力才能够达到,它是区分一个程序设计人员水平高低的一个 重要标志,数据结构 贯穿程序设计的始终 ,缺乏数据结构和算法的深厚功底,很难设计出高水平的具有专业水准的应用程序。曾经有一本经典计算机专业书籍叫做《数据结构+算法=程序》,也说明了数据结构和算法的重要性。

在这里插入图片描述

二、为什么要学数据结构

  • 数据结构是所有计算机专业的同学必学的一门课程
  • 数据结构研究的是数据如何再计算机中进行组织和存储,使得我们可以高效的获取数据或者修改数据

计算机专业的学生都开设过数据结构课程,它是计算机学科知识结构的核心和技术体系的基石。数据结构作为计算机专业的专业基础课程,是计算机 考研必考 科目之一,如果有打算报考计算机专业的研究生,这门数据结构你是必须要学好它的,同时,工作以后的同学,会有想去报考计算机 软考 、计算机 等级考试 的,数据结构也是必考的内容之一,科学技术在飞速发展,但是作为基石的科学技术没有动摇,由于近年来算法工程师的高薪火爆,使得数据结构的重视程序空前高涨,总而言之,既然我们已经与计算机接轨就必须 掌握 好它。

三、数据结构无处不在

不管你是IT开发,还是其他岗位的工作人员,或者是游戏爱好者,只要你用过电脑,那么你就接触过数据结构,下面我们就来讲一讲,数据结构究竟是如何 无处不在 的。

3.1 数据库

不管你是从事IT工作的,还是准备从事IT开发的,数据库一定是了解的,我们知道,数据库查询是数据库的最主要功能之一。我们都希望查询数据的速度能尽可能的快,因此数据库系统的设计者会从查询算法的角度进行优化。最基本的查询算法当然是顺序查找(linear search),这种复杂度为 O(n)的算法在数据量很大时显然是糟糕的,好在计算机科学的发展提供了很多更优秀的查找算法,例如 二分查找(binary search)、二叉树查找(binary tree search)等。如果稍微分析一下会发现,每种查找算法都只能应用于特定的数据结构之上,但是数据本身的组织结构不可能完全满足各种数据结构,所以,在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构上实现高级查找算法。这种数据结构,就是 索引 ,索引是一种帮助MySQL高效获取数据的 排好序数据结构,其中MySQL使用的数据结构为 B+Tree
在这里插入图片描述

3.2 操作系统

相信现在的我们常用的操作系统大家一定都知道吧,例如:比尔盖茨大叔成立的微软的 Windows操作系统,大神乔布斯苹果的 Mac OS,Java开发常用的 Linux系统,由林纳斯·本纳第克特·托瓦兹开发(百度来的),还有redhat、Solaris、SunCobalt等等,都有使用到数据结构中的,系统栈以及优先队列:堆
在这里插入图片描述

3.3 文件压缩

比如:RAR压缩软件、PNG图片、MAP3文件等等,都会使用数据结构,对数据进行压缩(很怕打成了亚索,心虚),而使用压缩的算法是一种树结构叫 哈夫曼树

在这里插入图片描述

3.4 游戏

1) 数组:需处理的元素个数确定并且需使用下标时可以考虑,不过建议用泛型List
优点:数组在内存中是连续存储的,索引和修改的速度都非常快
缺点:插入和删除很慢,长度开辟过长易造成内存浪费,长度开辟过短易造成内存越界

2) List: List是泛型的,即List,需处理的元素个数可以不确定,不存在装箱与拆箱,建议多用;而ArrayList:ArrayList list1 = new ArrayList(); ArrayList的元素属于 object 类型存在装箱与拆箱,很损耗性能。,List的底层数据结构就是数组。

List<string> list = new List<string>();
//新增数据   
list.Add(“abc”);   
//修改数据   
list[0] = “def”;   
//移除数据   
list.RemoveAt(0);  
//错误操作,因为数据的类型不是string
list.add(123);

3) 链表:常用来维护、管理那些需要频繁产生、消除的游戏对象,比如:消除类游戏中需要消除的对象。

4) HashMap:底层是哈希表,是键值对容器,用于处理key/value键值对;底层使用的是数组+链表的结构:Map<String,String> map = new HashMap<>();

5) 树: 1.场景管理中的四叉树;2.游戏UI里的菜单一般是分级的,一个主页面可以衍生出很多的子页面的时候,使用树来管理这些菜单是很合适的做法。

6) 图: A*寻路算法、DFS、BFS

游戏也是采用了大量的算法,都需要以数据结构为基石,就最简单的功能寻路,鼠标从A点到B点,这个角色就需要寻找一条从A点到B点的路,这条路还需要绕过所有的障碍物,甚至还需要找出最短的路径,这就是最经典的 图论算法,在图论算法种就使用了大量的数据结构。

在这里插入图片描述

四、数据结构类型

在这里插入图片描述

在计算机领域有一句名言 数据结构+算法=程序,而数据结构本身就是算法的基石,在近乎任何一本算法教材,都花了大量的时间讲解数据结构,学好数据结构和算法可以让我们在计算机这条道路上走的更远。如果数据结构是因为它无处不在,学好数据结构是使我们快速成长的垫脚石。

在接下面的几篇文章中,我会为大家更新数据结构中:数组、栈、队列、链表、二分搜索树、堆、线段树、Trie、并查集、红黑树以及哈希表等等...的详细讲解,感兴趣的同学记得关注我,我是牧小农,我喂自己带盐。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_14996421/article/details/103135914

智能推荐

此计算机上未安装sql2000,Windows10系统安装sql2000没有反应如何解决_weixin_39795065的博客-程序员秘密

很多朋友因为工作上的需求,都会在电脑中安装SQL2000软件。不过在Win10中就没那么容易了,一些用户反馈Win10正式版10586安装SQL2000过程中,在执行安装的时候,系统没任何反应。这是怎么回事呢?接下来,系统城小编就给大家介绍下Windows10系统安装sql2000没有反应问题的解决方法。具体如下:第一步:把安装文件夹下sql20004in1--&gt;X86--&gt;SYSTE...

Jersey构建REST服务实战_蔓延幸福的博客-程序员秘密

由于参与移动项目,需要移动终端和服务端传递数据,经过技术对比分析,觉得基于REST模式的Web服务比较简洁易用,于是采取了Jersey开发, 一个Java规范下REST风格Web Service开发框架。

光纤资料大全之光纤分类_haijs的博客-程序员秘密

本文转载自:http://network.51cto.com/art/201504/472710_all.htm光纤的种类很多,分类方法也是各种各样的。从材料角度分按照制造光纤所用的材料分类,有石英系光纤、多组分玻璃光纤、塑料包层石英芯光纤、全塑料光纤和氟化物光纤等。塑料光纤是用高度透明的聚苯乙烯或聚甲基丙烯酸甲酯(有机玻璃)制成的。它的特点是制造成本低

CTF-PWN-level2(x64)(Jarvis OJ)_pwn2_x64 40063e_SuperGate的博客-程序员秘密

这道题和level2的32位版本的漏洞一样,不过32位程序函数的参数是压在栈中的,而64位程序的前6个参数是存在寄存器中的,第7个开始才压入栈中。由于我们的目的是将system函数的参数改为/bin/sh,所以我们考虑用pop edi ret 语句将字符串赋值给edi。同样的,程序中hint存入了/bin/sh,我们直接使用即可。system函数的地址也很容易获得,剩下的就是pop e...

AnonymousAuthenticationFilter详解_「已注销」的博客-程序员秘密

匿名认证过滤器,可能有人会想:匿名了还有身份?我自己对于Anonymous匿名身份的理解是Spirng Security为了整体逻辑的统一性,即使是未通过认证的用户,也给予了一个匿名身份。而AnonymousAuthenticationFilter该过滤器的位置也是非常的科学的,它位于常用的身份认证过滤器(如UsernamePasswordAuthenticationFilter、BasicAuthenticationFilter、RememberMeAuthenticationFilter)之后,意味着只

【HEVC】目前H265分析软件推荐_h265分析工具_挫败但不断进步的草的博客-程序员秘密

本帖最后由 zxdaemon 于 2012-12-25 04:06 PM 编辑1,Codecvisa:http://codecian.com/国产软件,从最早的H264visa发展至今,感觉从刚开始的玩票,发展到今天专业级别的商业软件,值得支持。软件试用版30天试用,20帧限制。优点:QT开发,跨平台缺点:性能,功能,风格,专业程度和真正大牛级别的商业软件相比还是有距离。

随便推点

树莓派python环境安装第三方库的方法_树莓派python安装第三方库_snower晕眩的博客-程序员秘密

不像win系统下给Python安装第三方插件的方式,树莓派的Linux有一种直接复制的方式。步骤:(1)下载好需要的python扩展库(2)从树莓派文件管理目录找到如下位置:'''python/usr/lib/python2.7/dist-package'''(3)利用linux指令复制python扩展库文件夹到此位置,注意,要用超级用户权限“sudo”格式

《Python 深度学习》刷书笔记 Chapter 8 Part-2 用Keras 实现 DeepDream_梯度上升的上升步数与上升步数的size_FeverTwice的博客-程序员秘密

文章目录用keras实现DeepDream8-8 加载预训练的 Inception V3模型8-9 设置DeepDream配置8-10 定义需要最大化的损失8-11 梯度上升过程8-12 在多个连续尺度上运行梯度上升8-13 辅助函数最终效果写在最后用keras实现DeepDream我们将在一个ImageNet上一个预训练的卷积神经网络开始。Keras中有许多这样的网络,使用DeepDream有以下几个特点使用DeepDream,我们尝试将所有的层激活最大化,而不是某一层激活的最大化同时将大.

模拟版图设计全流程总结报告_IC观察者的博客-程序员秘密

1.打开 terminal,输入命令“qinling“,选择”1“进入”c_training_layout“进入到自己的目录下面,然后依次输入:“cd target/cd Bandgap1/virtuoso &”这三个指令,启动 virtuoso。图 1.1 所示CIw 的菜单按主要包括文件(File)、工具(Tools)选项(Options)和帮助 (Help)。其中,文件菜单主要完成文件库和单元的建立 、打开以及文件格式的转换,打开库单元的历史列表,退出软件等, File 菜单说明见表 1.1。

Linux:Ubuntu 国内源介绍_Brendon_Tan的博客-程序员秘密

本文介绍了archive源和ports源的区别,收录了Ubuntu 官方中国源、阿里源、清华源、中科大源、北外源等源地址。

微信小程序单位__rpx2px_weixin_33785972的博客-程序员秘密

微信小程序单位处理在微信小程序中,常用的单位:rpx 和 px, 但是设计,通常给我们的是的 width = 750, 基于 iphone6 的设计稿(375px * 667px),各种常用设备的尺寸分析设备宽高设备像素比iphone5320px568px2iphone6375px667px2iphone6+414px736px3ip...

jsoup_gl-i-wrap_tansuoliming的博客-程序员秘密

使用jsoup抓取jd的数据一、逐步分析(1)获取所有三级分类            /** * 获取jd所有的三级分类 * @param url jd有全部分类的链接:https://www.jd.com/allSort.aspx * @return 返回所有有效的三级分类链接 * @throws IOException */ public List&amp;lt;String&amp;g...

推荐文章

热门文章

相关标签