【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

这篇具有很好参考价值的文章主要介绍了【全面突击数据结构与算法001】绪论篇,数据结构的基本概念。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🍁前言

👑:👉CSDN丨博客园

🏆:👉在下周周ovoの社区

💎全栏:👉数据结构与算法专栏

PS:本篇文章主要综合了【王道数据结构与算法】与我的个人笔记与理解,如果文章有任何错误欢迎各位大佬的指出

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

快期末考试了,复习一波,冲冲冲

文章目录

🍁前言

🍁一、基本概念和术语

💎1.1、数据

💎1.2、数据元素、数据项

💎1.3、数据对象、数据类型、数据结构

​编辑

🍁二、数据结构的三要素

💎2.1、数据的逻辑结构

💎2.2、数据的存储结构

💎2.3、数据的运算

🍁三、 算法和算法的评价

💎3.1、算法的基本概念

​编辑

💎3.2、算法效率的度量

⚡3.2.1、时间复杂度

​编辑

⚡3.2.2、空间复杂度


🍁一、基本概念和术语

💎1.1、数据

数据是指事实、信息或知识等在计算机中的表现形式,是一种离散的、数字化的描述。数据通常以二进制形式存储在计算机的内存或硬盘中,它们可以被计算机程序读取、处理和操作,从而实现各种功能和应用。在计算机科学中,数据是非常重要的基础概念,其在各种应用领域中都有广泛的应用。

💎1.2、数据元素、数据项

数据元素是指数据的基本单位,通常是指一个整体。而数据项则是数据元素中的一个个体,通常是数据元素中最小的单元。因此,数据元素由若干个数据项组成。

例如:

以一个学生信息的数据结构为例,一个学生的信息就是一个数据元素,它包含了学生的姓名、学号、年龄等多个数据项,每个数据项分别表示学生的不同属性。因此,可以说数据项是数据元素的组成部分,而数据元素则是数据项的集合。

💎1.3、数据对象、数据类型、数据结构

数据对象:是指计算机中用来表示某种事物的实体,可以是具体的实物或抽象的概念。在计算机中,数据对象通常以数据元素的形式出现,一个数据对象由若干个数据元素组成。在一个学生信息管理系统中,一个学生就是一个数据对象,包含了学生的姓名、学号、年龄等多个属性,每个属性都可以看作是一个数据元素。

数据类型:数据类型是对数据对象的一种分类,是计算机科学中一个重要的概念。不同类型的数据对象在计算机内部需要不同的存储方式和处理方法。例如,整数、浮点数、字符串等都是不同的数据类型。

数据结构:是指计算机中存储和组织数据的方式,是一种数据类型的具体实现。数据结构可以通过不同的方式来表示数据对象,包括数组、链表、树等。不同的数据结构在计算机内部的存储方式和操作方法也不同,可以根据实际需要来选择合适的数据结构。

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

🍁二、数据结构的三要素

💎2.1、数据的逻辑结构

数据的逻辑结构指的是数据元素之间的关系,是数据在逻辑上的组织方式。它与数据的物理结构是不同的,物理结构指的是数据在计算机内部的存储方式。

常见的数据逻辑结构包括:

1. 线性结构:数据元素之间呈线性关系,每个数据元素只有一个直接前驱和一个直接后继。例如,线性表、栈、队列等数据结构都是线性结构。

2. 非线性结构:数据元素之间呈非线性关系,每个数据元素可能有多个直接前驱或直接后继。例如,树、图等数据结构都是非线性结构。

3. 集合结构:数据元素之间没有任何关系,它们之间是独立的。例如,数组就是一种集合结构。

4. 文件结构:数据元素之间存在某种关联关系,通常是通过某个共同的特征来关联。例如,数据库中的关系型数据就是一种文件结构。

5、树形结构:结构中的数据元素存在一对多的情况

6.图形结构或网状结构:结构中的数据元素存在多对多的情况

在实际应用中,根据问题的特点和需求,选择合适的数据逻辑结构是非常重要的,它能够直接影响数据处理的效率和正确性。

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

💎2.2、数据的存储结构

数据的存储结构是指在计算机内部,数据在存储介质中的具体存储方式,可以分为以下几种常见的存储结构:

1. 顺序存储结构:数据元素按照其逻辑顺序在存储介质上连续存储,可以通过元素在存储介质上的物理位置来访问元素。顺序存储结构通常用于存储连续的数据,如数组和线性表等。

2. 链式存储结构:数据元素在存储介质上不连续,每个元素保存着下一个元素的地址,通过遍历链表中的元素来访问链表。链式存储结构通常用于存储不连续的数据,如链表、树和图等。

3. 索引存储结构:数据元素分别存储在存储介质的不同位置,通过索引表来访问这些元素,索引表中保存着每个元素在存储介质中的位置。索引存储结构通常用于数据元素较大或数据元素的数量较大的情况。

4. 散列存储结构数据元素存储在散列表中,每个元素对应一个关键字,通过哈希函数将关键字映射为元素在散列表中的地址,从而实现对元素的访问。散列存储结构通常用于实现快速的数据查找和插入操作,如哈希表等。

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

💎2.3、数据的运算

数据的运算是指对数据进行的各种操作,包括查找、排序、插入、删除、修改等。不同的数据结构支持不同的数据运算,数据运算也是数据结构的最终目的之一。

以下是常见的几种数据运算:

1. 查找:在数据集合中查找指定元素的位置或者判断该元素是否存在。常见的查找算法有线性查找、二分查找、哈希查找等。

2. 排序:将数据集合按照一定的规则排序,使其按照某种顺序排列。常见的排序算法有冒泡排序、快速排序、归并排序等。

3. 插入:将一个元素插入到数据集合中的指定位置。常见的插入算法有直接插入排序、折半插入排序、希尔排序等。

4. 删除:将数据集合中指定位置的元素删除。常见的删除算法有直接删除、移动删除、标记删除等。

5. 修改:修改数据集合中指定位置的元素。例如,修改一个学生的成绩或者修改一个商品的价格等。

🍁三、 算法和算法的评价

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

💎3.1、算法的基本概念

算法是指解决特定问题的一系列清晰而有限的指令集合,它描述了一个计算过程,能够把一个初始状态转变成所需的最终状态。算法可以用来求解各种问题,例如排序、搜索、最短路径等。

算法具有以下几个基本概念:

1. 有限性:算法必须在有限步内结束,不能无限循环或递归

2. 确定性:算法的每一步必须明确而无歧义,执行结果唯一

3. 可行性:算法必须能够在计算机或者其他可执行设备上实现。

4. 输入:算法需要接受输入数据,这些数据可能是预处理的、用户输入的或者从其他系统获取的。

5. 输出:算法必须产生输出结果,这些结果可能是打印、显示、存储等形式。

6. 无误性:算法必须能够正确地解决问题,无论输入数据是什么,都能够得到正确的结果。

算法是计算机科学中的核心概念之一,是计算机程序设计的基础。

好的算法应该考虑达到下面这几个目标:

1. 正确性(Correctness):算法应该能够正确地解决问题,无论输入数据是什么,都能够得到正确的结果。

2. 可读性(Readability):算法应该易于理解和阅读,便于他人理解和维护。代码应该注重命名、缩进、注释等方面的规范化和可读性。

3. 高效性(Efficiency):算法应该具有高效的执行速度和内存占用,能够在可接受的时间内完成运算。

4. 健壮性(Robustness):算法应该能够在各种不同情况下都能够正确地运行,避免因异常或无效输入导致程序崩溃或出现错误。

5. 可扩展性(Scalability):算法应该能够适应不同规模和复杂度的问题,随着数据规模增大而不失效率。

这些目标是设计和实现好的算法时需要考虑的关键因素。一个好的算法应该能够在正确性、可读性、高效性、健壮性和可扩展性等方面达到一个良好的平衡,从而满足问题需求并提高程序的性能和可靠性。

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

💎3.2、算法效率的度量

算法效率的度量通常使用时间复杂度和空间复杂度来描述。

特别注意:

在算法设计中,原地工作(in-place)指的是一种特殊的算法实现方式,它能够在不使用额外的辅助空间(除了常数大小的辅助空间)的情况下,在原始数据上进行计算和修改。

如果一个算法被称为是“原地工作”的,只有该算法只使用了与输入数据规模无关的额外辅助空间。这种算法实现方式可以有效地减少空间复杂度,并且避免不必要的空间浪费,特别适用于在嵌入式系统和其他资源受限环境中的应用场景。

但是、并非所有的算法都可以或者需要原地工作。某些问题可能需要构造新的数据结构,而不得不使用额外的辅助空间,才能更加高效地解决问题。因此,在选择算法实现方式时,需要综合考虑时间复杂度、空间复杂度、实际应用场景等多个方面的因素。

总结下:原地工作是一种重要的算法设计思想,它可以帮助我们优化算法性能和节约资源开销。

⚡3.2.1、时间复杂度

时间复杂度是用来描述算法执行时间与输入规模之间关系的度量,它是指算法的运行时间随着问题规模的增加而增加的速度。在进行算法分析时,我们通常关注最坏情况下的时间复杂度,即算法在最坏情况下执行所需的最长时间。

时间复杂度通常用大 O 记号来表示,记为 O(f(n)),其中 n 表示输入规模,f(n) 是一个随着 n 增大而增加的函数。O 表示算法的时间复杂度,f(n) 表示随着输入规模 n 的增大,算法所需要的计算量也随之增加,但增加的速度最终被 f(n) 控制。

举个栗子:

若一个算法的时间复杂度为 O(n),则表示当输入规模 n 增大时,该算法执行所需的计算量随之线性增长。如果输入规模增加一倍,那么算法执行所需的时间也会增加一倍

若算法的时间复杂度为 O(n^2),则表示该算法执行所需的计算量随着输入规模的平方级别增加,如果输入规模增加一倍,那么算法执行所需的时间就会增加四倍。

时间复杂度是衡量算法效率的重要指标,一般来说,时间复杂度越小的算法效率越高。但在实际应用中,我们还需要考虑空间复杂度、代码的可读性和可维护性等因素来综合评估算法的优劣。

例子:

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

 【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

 重点部分:

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

⚡3.2.2、空间复杂度

空间复杂度是指算法在执行过程中需要占用的内存空间大小,通常用数据占用的存储单元数量来表示。和时间复杂度一样,空间复杂度也是衡量算法效率的一个重要指标。

空间复杂度的计算方法与时间复杂度类似,都是通过分析算法执行过程中所需的存储空间与输入规模之间的关系来确定的。我们通常关注的是算法在最坏情况下的空间复杂度,即算法在存储最多数据时所需的最大存储空间。

空间复杂度也通常用大 O 记号来表示,记为 O(f(n)),其中 n 表示输入规模,f(n) 是一个随着 n 增大而增加的函数。与时间复杂度类似,空间复杂度越小的算法所占用的内存空间越少,效率越高。

需要注意的是,在实际应用中,我们往往需要在时间复杂度和空间复杂度之间进行权衡,找到一个平衡点来满足实际需求。有些算法可能时间复杂度比较高,但空间复杂度比较低;有些算法则相反。因此,我们需要根据具体问题的特点来选择合适的算法。

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念

【全面突击数据结构与算法001】绪论篇,数据结构的基本概念文章来源地址https://www.toymoban.com/news/detail-469637.html

到了这里,关于【全面突击数据结构与算法001】绪论篇,数据结构的基本概念的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构学习之数据结构绪论

      《大话数据结构》是程杰老师著作的一本书,作者将跟着程杰老师写的这本书,记录自己数据结构学习之旅。   数据结构是一门研究非数值计算的程序设计问题中的操作对象,以及他们之间的关系和操作等相关问题的学科。   我的理解,数据结构就是数据和数据之

    2024年02月04日
    浏览(76)
  • 数据结构绪论(3)

    目录 一、客观题(1) 二、客观题(2)  三、客观题(3) 四、客观题(4)  五、客观题(5)  六、客观题(6) 1、以下与数据的存储结构有关的术语是(D)。 A、有序表   B、线性表   C、有向图   D、顺序表 2、从存储结构上可以把数据结构分成(A)。 A、顺序结构和链式

    2024年02月07日
    浏览(29)
  • 第一章-数据结构绪论

    数据结构是一门研究非数值计算的程序设计问题中的操作对象,以及它们之间的关系和操作等相关问题的学科。 程序设计的实质是选择一个好的结构,再设计一种好的算法。 数据:是描述客观事物的符号,是计算机中可以操作的对象,是能被计算机识别,并输入给计算机处

    2024年02月13日
    浏览(27)
  • 【数据结构】实验一:绪论

    实验一  绪论 一、实验目的与要求 1)熟悉C/C++语言(或其他编程语言)的集成开发环境; 2)通过本实验加深对算法时间复杂度的理解; 3)结合具体的问题分析算法时间复杂度。 二、实验内容 设计程序实现统计一个班的学生成绩(学生的人数可以设置3000、5000、8000、1000

    2024年02月15日
    浏览(27)
  • 【数据结构】绪论

    数据 数据是信息的载体,是描述客观事物属性的数、字符及所有能输入到计算机中并被计算机程序识别 和处理的符号的集合。数据是计算机程序加工的原料。 数据元素、数据项 数据元素是数据的基本单位,通常作为一个整体进行考虑和处理。 一个数据元素可由若干数据项

    2024年02月09日
    浏览(28)
  • 数据结构 - 绪论

    数据 Data :信息的载体。能被计算机识别并处理的符号的集合。 数据元素 Data element :数据的基本单位,通常作为一个整体进行考虑和处理。一个数据元素往往由若干 数据项 组成。数据项是组成数据元素的不可分割的最小单位。 如学生的信息记录就是一个数据元素,它由学

    2023年04月18日
    浏览(34)
  • [数据结构]喵桑,学费了——绪论

    本喵是FW视频封面最终版 宝子,你不点个赞吗?不评个论吗?不收个藏吗? 最后的最后,关注我,关注我,关注我,你会看到更多有趣的博客哦!!! 喵喵喵,你对我真的很重要。 目录 前言 绪论 1.1数据结构的研究的内容 1.2数据结构的基本概念和术语 1.2.1 数据,数据元素

    2024年02月06日
    浏览(29)
  • 24考研数据结构-——绪论2

    1.4.1 渐近时间复杂度 一般情况下,算法中基本操作重复执行的次数是问题规模n的某个函数f(n),算法的时间量度记作T(n)=O(n),它表示随问题规模n的增大而增大,算法执行时间的增长率和f(n)的增长率相同,称作算法的 渐近时间复杂度 ,简称时间复杂度。 大O表示“同阶”,

    2024年02月16日
    浏览(30)
  • 数据结构——第1章 绪论

    目录 1.1 数据结构的研究内容 1.2 基本概念和术语 1.2.1 数据、··元素、··项和··对象 1.2.2 数据结构 1.2.3 数据类型和抽象数据类型 1.3 抽象数据类型的表示与实现 1.4 算法和算法分析 1.4.1 算法的定义与特性 1.4.2 算法的时间复杂度 1.4.3 算法的空间复杂度 1.5 小结 数据: 是客观事

    2024年02月19日
    浏览(25)
  • 数据结构笔记(王道考研) 第一章:绪论

    大部分内容基于中国大学MOOC的2021考研数据结构课程所做的笔记,该课属于付费课程(不过盗版网盘资源也不难找。。。)。后续又根据23年考研的大纲对内容做了一些调整,将二叉排序树和平衡二叉树的内容挪到了查找一章,并增加了并查集、平衡二叉树的删除、红黑树的内

    2024年02月14日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包