文章目录

  • 一、前言
  • 二、为什么要学数据结构
  • 三、数据结构无处不在
    • 3.1 数据库
    • 3.2 操作系统
    • 3.3 文件压缩
    • 3.4 游戏
  • 四、数据结构类型

一、前言

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

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、并查集、红黑树以及哈希表等等...的详细讲解,感兴趣的同学记得关注我,我是牧小农,我喂自己带盐。

为什么要学数据结构?相关推荐

  1. php学数据结构,PHP 程序员学数据结构与算法之《栈》

    介绍 "要成高手,必练此功". 要成为优秀的程序员,数据结构和算法是必修的内容.而现在的Web程序员使用传统算法和数据结构都比较少,因为很多算法都是包装好的,不用我们去操心具体的实 ...

  2. 数据结构 python的书推荐-为什么程序员一定要学数据结构?数据结构书单推荐~...

    原标题:为什么程序员一定要学数据结构?数据结构书单推荐~ 来自:程序员书库(ID:OpenSourceTop) 人们最初使用计算机是用来处理简单的数值计算问题,当你使用计算机来处理一个问题时,一般经过 ...

  3. 从零开始学数据结构和算法(二)线性表的链式存储结构

    链表 链式存储结构 定义 线性表的链式存储结构的特点是用一组任意的存储单元的存储线性表的数据元素,这组存储单元是可以连续的,也可以是不连续的. 种类 结构图 单链表 应用:MessageQueue 插 ...

  4. 学数据结构,仅仅须要主要的编程体验

    [来信] 老师,您好.我是华南理工大学的非计算机专业大二学生,可是发现自己的编程能力太差.想学数据结构但不知道要学好这个须要什么基础. 大一时学校也仅仅是水水地安排了c++课程,可是特别浅.希望您能够 ...

  5. 小朋友学数据结构(3):二叉树的建立和遍历

    小朋友学数据结构(3):二叉树的建立和遍历 一.基本概念 BinaryTree.png 二叉树:每个结点的子结点个数不大于2的树,叫做二叉树. 根结点:最顶部的那个结点叫做根结点,根结点是所有子结点的 ...

  6. diff算法阮一峰_【重学数据结构与算法(JS)】字符串匹配算法(三)——BM算法

    前言 文章的一开头,还是要强调下字符串匹配的思路 将模式串和主串进行比较 从前往后比较 从后往前比较 2. 匹配时,比较主串和模式串的下一个位置 3. 失配时, 在模式串中寻找一个合适的位置 如果找到 ...

  7. java实验报告合肥工业大学_合肥工业大学数据结构上机实验代码与实验报告(全)github地址...

    C++实现链队类--合肥工业大学数据结构实验5:链式队列 实验5 5.1 实验目的 熟练掌握队列的顺序链式存储结构. 熟练掌握队列的有关算法设计,并在链队列上实现. 根据具体给定的需求,合理设计并实现 ...

  8. 大量的数据做字符串匹配_【重学数据结构与算法(JS)】字符串匹配算法(三)——BM算法...

    前言 文章的一开头,还是要强调下字符串匹配的思路 将模式串和主串进行比较 从前往后比较 从后往前比较 2. 匹配时,比较主串和模式串的下一个位置 3. 失配时, 在模式串中寻找一个合适的位置 如果找到 ...

  9. 重学数据结构——快速排序,二分法查找

    每次提起快排,内心中都有点隐隐作痛. 当时腾讯的那个面试官让我写快排的前两遍排序结果,结果,我当时居然没写上来-- 这个,就是所谓的关键时刻掉链子吧,这么经典的快排都不会,真是丢死人了-- 今天在实验 ...

  10. 为什么要学数据结构?| 原力计划

    作者 | 牧小农 责编 | 屠敏 出品 | CSDN 博客 前言 在可视化化程序设计的今天,借助于集成开发环境可以很快地生成程序,程序设计不再是计算机专业人员的专利.很多人认为,只要掌握几种开发工具就 ...

最新文章

  1. NeurIPS 2018 | 如何用循环关系网络机智地解决数独类关系推理任务?
  2. 图论:Dinic算法
  3. pb retrieve时停止工作_电机没有抱闸如何利用变频器实现减速停止
  4. 安卓开发实现画廊效果
  5. mysql contains函数_多属性、多分类MySQL模式设计
  6. thinkphp3.2与phpexcel带图片生成 完美案例
  7. 什么是单应矩阵和本质矩阵
  8. linux guide编译器,GUIDE编译器-GUIDE编程工具-GUIDE编译器下载 v1.0.2官方版-完美下载...
  9. mysql amp;amp;_浅析mysql交互式连接amp;非交互式连接
  10. 7-9 成绩转换 (15 分)
  11. 内核中的Makefile和Kconfig
  12. InfoQ编辑2018年推荐阅读清单(第二部分)
  13. java求职简历模板自我评价_java简历自我评价填写样本
  14. sphinx分词搜索
  15. 畅通工程1863(并查集)(WA的思考)
  16. 基于的Java的十进制转二进制实现
  17. 截取指定字符前面或后面的字符串
  18. python 提取sogou中文语料库
  19. OLTP与OLAP简介
  20. 测试电视是不是4k的软件,如何检测自家的电视是真4K还是假4K?当贝市场告诉你...

热门文章

  1. 作为一名技术人员,我们应该如何践行呢?
  2. 百度API加载离线百度电子地图和卫星切片
  3. 商务邮箱一般用什么邮箱正式?VIP邮箱名怎么设置好?
  4. 论文成功写作技巧之行之有效的写作从“结果”开始(上)
  5. 易买网更多新闻代码_新闻 | 1022Bewhy结婚等更多资讯
  6. 梅西百货公司 - Macy‘s - Shop Fashion Clothing Accessories
  7. HCNA期末测试题答案
  8. 常用插接件2(DC 电源插头)
  9. 解析增量xml数据到数据库
  10. 一个仿微博TextView 筛选,直接使用的工具类