秒秒pk10大小计划 _【一】、什么是数据结构

  • 时间:
  • 浏览:1

前言

令人头疼的书啊,一切尽在不言中。

对数据特性的理解

首先从定义上来说一句话,好像对数据特性没人那些八个 统一的、标准的答案,我找了好几本书,挑了八个 我认为还计较好理解的定义:

数据特性是计算机中存储、组织数据的办法。通常情况表下,精心选泽的数据特性后要 带来最优速率单位的算法。

已经 你没接触过数据特性,你看多定义能看懂吗?已经 你能看懂,我很佩服你,我反正是不行,不过现在已经 接触的东西比较多,听得多了,看多不能理解。觉得对于新手,应该先让新手去理解,等有了各人的理解已经 再看官方定义一句话,效果会比较好,反正我是没人认为的。我用生活中的例子来解释那些是数据特性吧:

举例:怎么在书架上摆放图书?

也要是说,现在有某些书架,还有一堆图书,我愿意 怎么把它们中放书架上去呢?换言之说,有一堆数据,给了你某些存储空间,我愿意 为社 把那些数据存起来呢?

觉得你你这一什么的问题问的不科学,已经 你问你所谓的书架是长那些样,已经 是下面图片中的任意并就有。

 

 

统统你就知道了,当一帮人问你八个 数据为社 组织的已经 ,觉得是跟你你这一数据的规模有关系的。不一样规模的什么的问题,它补救起来的难度就不一样。难在那些地方呢?难没哟说我愿意 把它为社 放,而在于放你你这一书是为了做事情用的,统统说图书的摆放觉得跟八个 操作直接相关:

操作一:新书为社 插入

操作二:为社 找到某本指定的书

办法一:问你当你们是怎么考虑的,我第八个 感觉要是随便放,随便放八个 好处要是:新书为社 插入,你你这一操作是非常简单的,哪有空就放哪,最简单的办法要是把所有的书一本一本挨着放,统统呢,所有的新书哪里有空放哪里,So easy!放起来简单,但第八个操作为社 办,怎么查找?那就会成为一件很恐怖的事……累死你!那些已经 累死呢,觉得已经 要是八个 很小的书架,倒也累不死,但已经 是里边第三张那样的书城,或者 你想象,里边所有的图书后要 随便放的,或者 一帮人问你,你你这一书城里有没人某一本书,觉得那本书没人,但遇见你忘了有没人,那你为社 能选泽它到底有没人呢?你就只好从头到尾把每一本书都过一遍,或者 不能叹一口气说……唉,不好意思,没人这本书。

办法二:没人 们有没人稍微聪明某些的补救办法呢?要是怎么我愿意 找书找的方便呢?第八个办法,要是按照书名的拼音字母顺序排放,有了你你这一字母序已经 ,查找就方便多了。八个 最聪明的办法是二分查找那些是二分查找:比如说现在有一长排的书中放你身后,或者 当你们找一本叫《数据特性》的以S开头的书,没人 先从你你这一排的里边找一本书出来看它的书名的首字母,倘若说是《离散数学》,以L开头的书,没人 们知道,S在L的里边,统统《离散数学》前面的书我就后要管它了,我的查找范围缩小了一半,从L现在开使往后找,或者 再找你你这一半的里边,比如找到的一本书是《网络爬虫》,以W开头的,那S在L和W里边,《网络爬虫》里边的书我就后要管了,于是我的查找范围又缩小了一半,以此类推,我愿意 每次都找,或者 跟里边你你这一比,调快就会把范围缩小到一本书上,我就会知道这本书到底是有还是没人。你你这一办法比前面的办法聪明多了,它很好的补救了查找的什么的问题。或者 ,什么的问题又来了,新书来了为社 插入呢?它就会成为新的令人头疼的什么的问题。比如说,我新买了一本书叫《阿Q正传》,是以A开头的,呃……惨了,没人 们得把几乎所有的书往后一本一本的错位,无缘无故到前面留出八个 空挡,把新书中放去,你你这一似乎也很头疼。

办法三:那怎么找八个 两全其美的办法呢?当你们来想想,图书馆里是怎么来摆书的,当你们倘若说去图书馆,找《数据特性》,要为社 找,你不已经 是从第一本现在开使找,要是已经 是随便里边摸一本找,你进到图书馆里,第一件事情要找的是计算机类的书在哪里对不对?图书馆里的书通常是按照书的类别来分的,比如说当你们有社会科学类、文学类、艺术类、理科、工科等,或者 工科下面已经 后要 分的再细某些,比如说当你们计算机类已经 就分在工科的下面,你你这一分法有那些好处呢?把书架划分成2个区域,每快区域指定摆放并就有类别的图书,在每项类别内,按照书名的拼音字母顺序排放,没人 不管我在每八个 类里做那些样的操作,总归来说,图书的规模小了统统,跟整个图书馆的规模相比,我是某一类的,无论是查找还是插入,后要 非常方便的。查找呢,要是在二分查找已经 ,当你们先定八个 类别,或者 在八个 类的八个 小范围里边做二分查找,就后要 调快的找到当你们要查找的书了。已经 是插入,也是先定类别,用二分查找来选泽一下它应该被插在那些位置,或者 移空位这件事已经 还是要做的,或者 总归比当你们刚现在开使要移的书的数量少多了。

那现在什么的问题又来了:

什么的问题一:空间怎么分配?

什么的问题二:类别应该分多细?

当你们分的各种类别的书,它的藏书量是不一样的,你是统一都给它分……还是每一类都2个个书架,已经 分好吗?这也是八个 很头疼的什么的问题,我真难了,你已经 书架给多了,就会有某些空间始终空在那浪费着,你已经 书架给小了,新书来的已经 要不断地加新柜子,很讨厌。还有分类别要分多细的什么的问题,我愿意 是分的比较粗,没人同一类里边的书就会有统统,那你的工作量还是会很大,要是想减少工作量,最好还是类别分的细某些,或者 类别一分细,就会有副作用,类别很多了,图书的量一多,也是麻烦。

说那些什么的问题是想说明:

补救什么的问题办法的速率单位,跟数据的组织办法是直接相关的

没人 这介绍数据特性的组织办法的已经 ,觉得有八个 概念:

一、关于数据对象的逻辑特性

比如说,当你们一现在开使把书架想象成简单的一长条,没人一层的架子,或者 所有的书是八个 八个 挨着放的,除了一头一尾的书以外,每一本书的前面和里边都不后要 一本书,已经 每一本书后要 八个 编号一句话,没人这八个 编号对应的要是一本书,没人你你这一特性是一对一的特性,当你们管它叫线性特性。

另外并就有组织办法是里边说的第并就有办法,要是先把图书分类,已经 我给每八个 类八个 编号一句话,没人这八个 类别的编号里边对应着统统本书,没人这是八个 一对多的逻辑特性,你你这一特性有个名字叫做树。

再说图书馆,假设当你们还统计没人 某些信息:你你这一本书后要 那些人买过,买了这本书的人还买过其它的那些书,于是呢,觉得是一本书对应着统统人,而有一个 人又对应了统统本书,这是八个 多对多的、很复杂性的八个 关系网,没人你你这一关系网对应的逻辑特性叫叫做图

二、关于对象的物理存储特性

除了逻辑特性之外,当你们还有数据对象再计算机里边的物理存储特性,也要是当你们说的那些逻辑特性在机器的内存里到底要为社 放,是连续放呢还是东八个 西八个 隔开放呢?也要是说用八个 数组来存它呢,还是用八个 链表来存它呢?你你这一就属于物理存储特性。

此篇完

以上那些要是对数据特性的理解,我愿意 应该说全面了吧,要是没全面要是要紧,里边学了再继续补充。

看多有收获?没人希望老铁别吝啬你的三连击哦1、点个推荐,让更多的人看多这篇文章2、关注我的原创微信公众号【泰斗贤若如】,第一时间阅读我的文章3、欢迎关注我的博客

 【原创声明】:各人原创:https://www.cnblogs.com/zyx110/