前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据结构知识概述

数据结构知识概述

作者头像
用户2192970
发布2019-02-22 16:07:34
3410
发布2019-02-22 16:07:34
举报
文章被收录于专栏:杨飞@益术杨飞@益术

数据结构是计算机软件的一门基础课程,计算机科学各个领域及有关的应用软件都要用到各种数据结构。语言编译要使用栈、散列表及语法树;操作系统中用队列、存储管理表及目录树等;数据库系统运用线性表、多链表及索引树等进行数据管理;而在人工智能领域,依求解问题性质的差异将涉及到各种不同的数据结构,如广义表、集合、搜索树及各种有向图等等。学习数据结构目的是要熟悉一些最常用的数据结构,明确数据结构内在的逻辑关系,知道它们在计算机中的存储表示,并结合各种典型应用说明它们在进行各种操作时的动态性质及实际的执行算法,进一步提高软件计和编程水平。通过对不同存储结构和相应算法的对比,增强我们根据求解问题的性质选择合理的数据结构,并将问题求解算法的空间、时间及复杂性控制在一定范围的能力。

软件设计师考试大纲对数据结构部分的要求是熟练掌握常用数据结构和常用算法,因此,本专题从数据结构的概述出发,对基本的概念引出常用的数据结构类型的介绍和讲解,同时在讲解各种数据结构中间采用算法与数据结构相结合的方式,在算法步骤中使用数据结构,对数据结构的重点、难点进行了分析,最后讲解了与数据结构紧密相关的排序和查找算法,以及一些以往考试题的分析。

    数据结构概述:

    数据结构研究了计算机需要处理的数据对象和对象之间的关系;刻画了应用中涉及到的数据的逻辑组织;也描述了数据在计算机中如何存储、传送、转换。

    学习数据结构注意的问题:

    系统掌握基本数据结构的特点及其不同实现。

    了解并掌握各种数据结构上主要操作的实现及其性能(时间、空间)的分析。

    掌握各种数据结构的使用特性,在算法设计中能够进行选择。

掌握常用的递归、回溯、迭代、递推等方法的设计

    掌握自顶向下、逐步求精的程序设计方法。

    掌握自顶向下、逐步求精的程序设计方法。

    在学习数据结构的知识之前,我们要了解一下数据结构中的基本概念。

    数据:对客观事物的符号表示,在计算机中就是指所有能输入到计算机中并被计算机程序所处理的符号的总称。

    数据项: 是数据的不可分割的最小单位;

    数据元素:是数据的基本单位,在计算机程序中通常作为一个整体进行处理;一个数据元素可由若干个数据项组成。

    数据对象:是性质相同的数据元素的集合,是数据的一个子集。

    数据结构上的基本操作:1.插入操作 2.删除操作 3.更新操作 4.查找操作 5.排序操作

    数据结构是指数据对象及相互关系和构造方法,一个数据结构B形式上可以用一个二元组表示为B=(A,R)。其中,A是数据结构中的数据(称为结点)的非空有限集合,R是定义在A上的关系的非空有限集合。

    根据数据元素之间的关系的不同特性,通常有下列4类基本结构。

    集合——结构中的数据元素除了“同属于一个集合”的关系外,别无其他关系。

    线性结构——结构中的数据元素之间存在一个对一个的关系。

树形结构——结构中的元素之间存在一个对多个的关系。

    图状结构或网状结构——结构中的元素之间存在多个对多个的关系。

数据结构中,结点与结点间的相互关系是数据的逻辑结构。数据结构在计算机中的表示(又称为映象)称为数据的物理结构,也称存储结构。

    数据元素之间的关系在计算机中有两种不同的表示方式:顺序映象和非顺序映象,并由此得到两种不同的存储结构:顺序存储结构和链式存储结构。

    任何一个算法的设计取决于选定的数据(逻辑)结构,而算法的实现依赖于采用的存储结构。

    数据的逻辑结构分为两类:

    线性结构:线性表、栈、队列和串。

    非线性结构:树、图

    数据的存储方法有四类:

    1.顺序存储方法;

    2.链接存储方法;

    3.索引存储方法;

    4.散列存储方法。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013年11月11日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档