数据结构基础知识、名词概述

news2025/1/23 12:07:56

    • 1.1 基本概念和术语
      • 1.1.1 数据、 数据元素、 数据项和数据对象
      • 1.1.2 数据结构
      • 1.1.3 数据类型和抽象数据类型
    • 1.2 抽象数据类型的表示与实现
    • 1.3 算法与算法分析(1)
    • 1.4 算法与算法分析(2)
    • 1.5 算法与算法分析(3)
    • 1.6 算法与算法分析(4)

整体知识框架

image-20230721101102611

1.1 基本概念和术语

image-20230718220144794

1.1.1 数据、 数据元素、 数据项和数据对象

数据 (Data) 是客观事物的符号表示,是所有能输入到计算机中并被计算机程序处理的符号 的总称。如数学计算中用到的整数和实数,文本编辑中用到的字符串,多媒体程序处理的图形、 图像、声音及动画等通过特殊编码定义后的数据。

数据元素(Data Element)是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。 在有些情况下,数据元素也称为元素、记录等。

数据元素用于完整地描述一个对象,如图中的一名学生记录,树中棋盘的一个格局(状态),以及图中的一个顶点等。

image-20230717220507287

数据项 (Data Item) 是组成数据元素的、有独立含义的、不可分割的最小单位。例如,学生 基本信息表中的学号、姓名、性别等都是数据项。

image-20230717220620660

数据对象 (Data Object) 是性质相同的数据元素的集合,是数据的一个子集。

image-20230717220717463

数据元素与数据对象的区别

image-20230717220812856

1.1.2 数据结构

数据结构 (Data Structure) 是相互之间存在一种或多种特定关系的数据元素的集合。换句话 说,数据结构是带 “结构” 的数据元素的集合, “结构” 就是指数据元素之间存在的关系

数据结构包括逻辑结构存储结构两个层次。

1、数据元素及其关系在计算机内存中的表示(又称为映像),称为数据的物理结构或存储结构

2、数据元素之间的逻辑关系,称为逻辑结构

image-20230717221408015

逻辑结构和存储结构之间的关系是:逻辑结构定义了数据之间的逻辑关系,而存储结构则实现了这种逻辑关系在内存中的存储方式。

逻辑结构的种类

划分方法一

image-20230717223917738

划分方式二

(1) 集合结构

数据元素之间除了 “属于同一集合” 的关系外,别无其他关系。例如,确定一名学生是否为 班级成员, 只需将班级看做一个集合结构。

(2) 线性结构

数据元素之间存在一对一的关系。例如,将学生信息数据按照其入学报到的时间先后顺序进 行排列,将组成一个线性结构。

(3) 树结构

数据元素之间存在一对多的关系。例如,在班级的管理体系中,班长管理多个组长,每位组 长管理多名组员,从而构成树形结构。

(4) 图结构或网状结构

数据元素之间存在多对多的关系。例如,多位同学之间的朋友关系, 任何两位同学都可以是 朋友,从而构成图状结构或网状结构。

image-20230717224115191

存储结构的种类

(1)顺序存储结构

用一组连续的存储单元依次存储数据元素,数据元素之间的逻辑关系由元素的存储位置来表示. 比如:数组

(2)链接存储结构

用一组任意的存储单元存储数据元素,数据元素之间的逻辑关系用指针来表示, 每一个元素不仅存储它本身的数据,还要存储下一个元素的地址, 例如:链表

image-20230717224638473

(3)索引存储结构

在存储节点信息的同时,还建立附加的索引表。索引表中的每一项称为一个索引项,一般形式为:(关键字,地址)

(4)散列存储

根据节点的关键字直接计算出该节点的地址

image-20230717224923808

1.1.3 数据类型和抽象数据类型

**数据类型 (Data Type) **

在使用高级程序设计语言编写程序时,必须对程序中出现的每个变量常量或表达式,明确说明它们所属的数据类型

例如: Java语言中的 int、long、short等八种基本数据类型

而另一些常用的数据结构,如栈、队列、树、图等,不能直接用数据类型来表示。

类型明显或隐含地规定了数 据的取值范围、存储方式以及允许进行的运算,数据类型是一个值的集合和定义在这个值集上的 一组操作的总称.

例如: int类型代表整数,其范围 -2,147,483,648到2,147,483,647

image-20230718213804980

抽象数据类型(Abstract Data Type, ADT)

抽象数据类型 (Abstract Data Type, ADT) 一般指由用户定义的、表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称,具体包括三部分:数据对象数据对象上关系的集合 以及对数据对象的基本操作的集合

ADT抽象数据类型名(
    数据对象:(数据对象的定义〉
    数据关系:(数据关系的定义〉
    基本操作:(基本操作的定义〉
}ADT抽象数据类型名

其中,数据对象和数据关系的定义采用数学符号和自然语言描述,基本操作的定义格式为

基本操作名(参数表)
    初始条件:(初始条件描述〉
    操作结果:(操作结果描述〉

基本操作有两种参数: '赋值参数只为操作提供输入值;引用参数 以 “&” ·打头,除可提供输 入值外,还将返回操作结果。

“初始条件” 描述了操作执行之前数据结构和参数应满足的条件,若 初始条件 为空,则省略。

“操作结果” 说明了操作正常完成之后,数据结构的变化状况和应返回的结果。

1.2 抽象数据类型的表示与实现

使用 Java 实现抽象数据类型 “复数” 的实现:

public class ComplexNumber {
    private double real; // 实部
    private double imaginary; // 虚部

    // 构造函数
    public ComplexNumber(double real, double imaginary) {
        this.real = real;
        this.imaginary = imaginary;
    }
    
    // 获取实部
    public double getReal() {
        return real;
    }

    // 获取虚部
    public double getImaginary() {
        return imaginary;
    }

    // 加法
    public ComplexNumber add(ComplexNumber other) {
        double newReal = this.real + other.real;
        double newImaginary = this.imaginary + other.imaginary;
        return new ComplexNumber(newReal, newImaginary);
    }

    // 减法
    public ComplexNumber subtract(ComplexNumber other) {
        double newReal = this.real - other.real;
        double newImaginary = this.imaginary - other.imaginary;
        return new ComplexNumber(newReal, newImaginary);
    }

    // 乘法
    public ComplexNumber multiply(ComplexNumber other) {
        double newReal = this.real * other.real - this.imaginary * other.imaginary;
        double newImaginary = this.real * other.imaginary + this.imaginary * other.real;
        return new ComplexNumber(newReal, newImaginary);
    }

    // 转换为字符串形式
    @Override
    public String toString() {
        if (imaginary >= 0) {
            return real + " + " + imaginary + "i";
        } else {
            // 数学函数,取绝对值
            return real + " - " + Math.abs(imaginary) + "i";
        }
    }
}

1.3 算法与算法分析(1)

算法的定义

算法 (Algorithm) 是为了解决某类问题而规定的一个有限长的操作序列。

算法的描述

  • 自然语言:英语、中文
  • 流程图:传统流程图、NS流程图
  • 伪代码:类语言:类C语言
  • 程序代码:C、Java

算法与程序

  • 算法是解决问题的一种方法或一个过程,考虑如何将输入转换成输出一个问题可以有多种算法
  • 程序是用某种程序设计语言对算法的具体实现。

image-20230718222312452

算法的特性

(1)有穷性。一个算法必须总是在执行有穷步后结束,且每一步都必须在有穷时间内完成。【比如:不能陷入死循环

(2) 确定性。对于每种情况下所应执行的操作,在算法中都有确切的规定,不会产生二义性, 使算法的执行者或阅读者都能明确其含义及如何执行。【比如对于同一个输入而出现不同的结果,这就是不确定性

(3) 可行性。算法中的所有操作都可以通过已经实现的基本操作运算执行有限次来实现。

(4) 输入。一个算法有零个或多个输入。当用函数描述算法时,输入往往是通过形参表示的, 在它们被调用时,从主调函数获得输入值。

(5) 输出。一个算法有一个或多个输出,它们是算法进行信息加工后得到的结果,无输出的 算法没有任何意义。当用函数描述算法时,输出多用返回值或引用类型的形参表示。

算法设计的要求

  • 正确性

image-20230718223040994

  • 可读性

image-20230718222821676

  • 健壮性

image-20230718222912525

  • 高效性

image-20230718223029848

1.4 算法与算法分析(2)

通常来说一个问题,往往有好几种算法可以实现,我们如何区分算法的好坏、优劣。

那么好的算法首先应该具备正确性,然后是健壮性、可读性。在几个方面都满足的情况下,主要考虑算法的效率, 通过算法效率的高度评判不同算法的优劣程度。

算法效率通常考虑以下俩个方面:

  1. 时间效率:指的是算法所耗费的时间
  2. 空间效率:指的是算法执行过程中所耗费的存储空间

这俩者之前往往是矛盾的,鱼和熊掌不可兼得~

算法时间效率的度量

算法时间效率可以用依据该算法编制的程序在计算机上执行所消耗的时间来度量。

俩种度量方法:

  • 事后统计:将算法实现,实际测算其时间和空间的开销
  • 事前分析:对算法的一种估算方法(一般采用此方法
    • 算法运行时间 = 一个简单操作所需的时间*简单操作次数

image-20230718224312440

等价于

image-20230718224534616

每条语句执行一次所需的时间,一般是随机器而异的。取决于机器的指令性能、速度以及编译的代码质量。是由机器本身软硬件环境决定的它与算法无关。

所以,我们可假设执行每条语句所需的时间均为单位时间。此时对算法的运行时间的讨论就可转化为讨论该算法中所有语句的执行次数,即频度之和了。

例如:俩个 n*n 矩阵相乘的算法可描述为:

image-20230718225015053

我们把算法所消耗的时间定义为 该算法中每条语句的频度之和,则上述算法的时间消耗 Tn为:

image-20230718225209299

以上这种方式进行统计太麻烦,为了方便比较不同算法的时间效率,仅仅比较他们之间的数量级。

若有某个辅助函数f(n),使得当n趋近于无穷大时,T(n)/f(n)的极限值为不等于零的常数,则称f(n)是T(n)的同数量级函数。记作**T(n)=O(f(n))**称O(f(n))为算法的渐进时间复杂度(O是数量级的符号),简称时间复杂度

对于上面矩阵问题的,消耗的时间为:

image-20230718230208080

n -> ∞ ∞ 时,T (n)/n3 = 2,这表示n充分大时,T(n)与n3是同阶或同数量级,引入大“O”记号,则T(n)可记作:

image-20230718230347218

因此,在我们求时间复杂度的时候,只需要找到算法中基本语句重复执行的次数

什么是基本语句

  • 算法中重复执行次数和算法的执行时间成正比的语句
  • 对算法运行时间的贡献最大
  • 执行次数最多

基本语句的重复次数(时间复杂度)问题规模n的某个函数f(n),算法的时间量度即为: T(n) = O(f(n))

  • n越大算法的执行时间越长
  • 排序: n为记录数
  • 矩阵:n为短阵的阶数
  • 多项式: n为多项式的项数
  • 集合:n为元素个数
  • 树: n为树的结点个数
  • 图: n为图的顶点数或边数

1.5 算法与算法分析(3)

分析算法事件复杂度的基本方法

image-20230719101854548

忽略是所有低次幂项最高次幂系数,体现出增长率的含义。

步骤

  1. 找出语句频度最大的那条语句作为基本语句(执行次数最多的语句)

  2. 计算基本语句的频度得到问题规模 n 的某个函数fn

  3. 取其数量级用符号“O”表示

举例:

x = 0: V =0
for ( int k = 0; k < n; k ++)
	X ++·
for ( int i = 0;i < n;i++ )
     for ( int j = 0;j < n;j++ )
		y + +

找出语句频度最大的: 第一个for循环频度为:n+1,第二个for循环为 n+1,第三层循环为 n * (n+1) 【条件判断也看做是一次执行次数】

T n = O ( n ∗ ( n + 1 ) ) Tn = O( n*(n+1)) Tn=O(n(n+1))

忽略最高次幂项系数、低次幂项,最终:Tn = O( n2)

举例:

分析以下时间复杂度

i = 1;1while(i<=n)
	i=i*2;2

若循环执行1次: i=1*2=2

若循环执行2次: i=2*2=22

若循环执行3次: i=2*2=23

若循环执行x次: i =2x

设语句(2)执行次数为x次,由循环条件 i<= n, 推出 2x< =n x<=log2n

image-20230719104635494

即 f(n) <=log2n , 取最大值 f(n) = log2n

因此该程序段的时间复杂度 Tn = O( log2n) = O( lgn)

1.6 算法与算法分析(4)

前面介绍了如何计算时间复杂度,但是在有的情况下,算法中基本操作重复执行的次数还随问题的输入数据集不同而不同

image-20230719110018665

最好情况:1次
最坏情况: n
平均时间复杂度为/O(n)


最坏时间复杂度: 指在最坏情况下,算法的时间复杂度

平均时间复杂度: 指在所有可能输入实例在等概率出现的情况下,算法的期望运行时间。

最好时间复杂度: 指在最好情况下,算法的时间复杂度

  • 一般情况下是考虑最坏时间复杂度,以保证算法的运行时间最坏不会比它更长

对于复杂的算法,可以将它分成几个容易估算的部分,然后利用大O加法法则和乘法法则,计算算法的时间复杂度。

image-20230719110612844

算法时间效率的比较

当n取得很大时,指数时间算法和多项式时间算法在所需时间上非常悬殊

image-20230719110936940

image-20230719111017900

尽量设计复杂度低的算法:

image-20230719111034662


渐进空间复杂度

空间复杂度:算法所需存储空间的度量,记作:S(n) = O(f(n)),其中 n 为问题的规模

算法要占用的空间包括

  • 算法本身占据的空间、输入、输出、指令、变量、常数等
  • 算法使用的辅助空间

例子: 将一维数组a中的n个数逆序存放到原数组中。

image-20230719112106468

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/812445.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

gti 远程操作

目录 一. 分布式版本控制管理系统 1. 理解分布式版本控制管理系统 二. 创建远程仓库 ​编辑 ​编辑 三. 克隆远程仓库_HTTP 四. 克隆远程仓库_SSH 配置公钥 添加公钥 五. git 向远程仓库推送 六. 拉取远程仓库 七. 忽略特殊文件 八. 配置别名 一. 分布式版本控制管理…

JVM内存分配机制详解

文章目录 一、对象的创建流程1、类加载检查2、分配内存3、初始化4、设置对象头5、执行方法 二、对象内存分配1、栈上分配2、对象在Eden区分配3、大对象直接进入老年代4、长期存活的对象进入老年代5、对象动态年龄判断6、老年代空间分配担保机制 三、对象内存回收1、引用计数法2…

别再分库分表了,试试TiDB!

什么是NewSQL 传统SQL的问题 升级服务器硬件 数据分片 NoSQL 的问题 优点 缺点 NewSQL 特性 NewSQL 的主要特性 三种SQL的对比 TiDB怎么来的 TiDB社区版和企业版 TIDB核心特性 水平弹性扩展 分布式事务支持 金融级高可用 实时 HTAP 云原生的分布式数据库 高度兼…

RT1052 的四定时器

文章目录 1 Quad Timer&#xff0c;简称&#xff1a;QTMR2 单个通道的框图3 QTMR配置3.1 QTMR1 时钟使能。3.2 初始化 QTMR1。3.2.1 QTMR_Init 3.3 设置 QTMR1 通道 0 的定时周期。3.3.1QTMR_SetTimerPeriod 3.4 使能 QTMR1 通道 0 的比较中断。3.4.1 QTMR_EnableInterrupts 3.…

14. Spring AOP 的组成和实现

目录 1. Spring AOP 简介 2. AOP 的组成 2.1 切面&#xff08;Aspect&#xff09; 2.2 连接点&#xff08;Join Point&#xff09; 2.3 切点&#xff08;Pointcut&#xff09; 2.4 通知&#xff08;Advice&#xff09; 3. Spring AOP的实现 3.1 新建项目 3.2 添加 AOP …

Zebec Card 将在亚洲、拉美等地区推出,生态全球化加速

随着以Visa、特斯拉、BNY Mellon、BlackRock、Mastercard、Gucci等为代表的传统商业机构巨头&#xff0c;以及萨尔瓦多、中非共和国等为代表的国家不断的向加密货币领域布局&#xff0c;越来越多的投资者开始以新的眼光来看待加密货币&#xff0c;仅在2022年&#xff0c;加密货…

1400*B. I Hate 1111(思维+数学)

Example input 3 33 144 69 output YES YES NO 题意&#xff1a; 问一个数字是否可以由 11&#xff0c;111&#xff0c;1111&#xff0c;11111...... 任意倍数加和所得。 解析&#xff1a; 可以观察到 1111%110&#xff0c;11111%1110&#xff0c;而后面更大的11111111…

C++部署学习

gcc -E src/main.c -o src/main.i gcc -S src/main.c -o src/main.s gcc -C src/main.c -o src/main.o gcc src/main.c -o exec ./exec

Vue2第八节 收集表单数据

&#xff08;1&#xff09;文本类型/密码类型 v-model收集的是value值 用户输入的就是value值 <input type"text" v-model"usrInfo.account"> <input type"password" v-model"usrInfo.password"> &#xff08;2&#xf…

Java程序逻辑控制的几个小练习(熟悉一下Java的语法)

虽然都是一些很简单的题目&#xff0c;但是都是很经典的编程题&#xff0c;多写几道可以熟悉一些Java代码&#xff0c; 之前C语言敲多了一时半会有点不适应&#xff0c;敲起来怪怪的&#xff0c;感觉手不是自己的了哈哈 目录 1. 根据年龄, 来打印出当前年龄的人是少年(低于18)…

多臂治疗规则的 Qini 曲线(Stefan Wager)

英文题目&#xff1a; Qini Curves for Multi-Armed Treatment Rules 中文题目&#xff1a;多臂治疗规则的 Qini 曲线 单位&#xff1a;Stefan Wager 论文链接&#xff1a; 代码&#xff1a;GitHub - grf-labs/maq: Treatment rule evaluation via the multi-armed Qini …

软件测试面试【证券项目公司】

这家公司是做证券项目的&#xff0c;约的9点钟&#xff0c;路程还是有点遥远&#xff0c;转了一趟公交两趟地铁&#xff0c;精力都花在了路上&#xff0c;感觉有点累&#xff0c;以下是今天得面试流程。 到公司前台给我了一张面试表&#xff0c;写完之后就是等待面试。一共面试…

Python模块psycopg2连接postgresql

目录 1. 基础语法 2. 基础用法 3. 多条SQL 4. 事务SQL 1. 基础语法 语法 psycopg2.connect(dsn #指定连接参数。可以使用参数形式或 DSN 形式指定。host #指定连接数据库的主机名。dbname #指定数据库名。user #指定连接数据库使用的用户名。…

TMS XData v5.11 2023 crack,全功能查询机制

TMS XData v5.11 2023 crack,全功能查询机制 用于多层REST/JON-HTTP/HTTPS应用服务器开发和ORM远程处理的Delphi框架。 功能概述 基于REST/JONS架构风格的服务器 从不同的客户端平台(如.NET、Java、jаvascript)轻松访问&#xff0c;因为它是基于REST/JSON的 使用标准POST、GET…

【RabbitMQ】golang客户端教程2——工作队列

任务队列/工作队列 在上一个教程中&#xff0c;我们编写程序从命名的队列发送和接收消息。在这一节中&#xff0c;我们将创建一个工作队列&#xff0c;该队列将用于在多个工人之间分配耗时的任务。 工作队列&#xff08;又称任务队列&#xff09;的主要思想是避免立即执行某些…

[golang gin框架] 43.Gin商城项目-微服务实战之后台Rbac微服务之管理员的增删改查以及管理员和角色关联

上一节讲解了后台Rbac微服务角色增删改查微服务,这里讲解权限管理Rbac微服务管理员的增删改查微服务以及管理员和角色关联微服务功能 一.实现后台权限管理Rbac之管理员增删改查微服务服务端功能 1.创建Manager模型 要实现管理员的增删改查,就需要创建对应的模型,故在server/r…

使用Beego和MySQL实现帖子和评论的应用,并进行接口测试(附源码和代码深度剖析)

文章目录 小项目介绍源码分析main.gorouter.gomodels/user.gomodels/Post.gomodels/comment.gocontrollers/post.gocontrollers/comment.go 接口测试测试增加帖子测试查看帖子测试增加评论测试查看评论 小项目介绍 经过对需求的分析&#xff0c;我增加了一些额外的东西&#x…

Linux学习之脚本优先级控制

fork炸弹 在编写Shell脚本时不要写出不可控的死循环&#xff0c;比如func() { func | func& } ; func&#xff0c;简写版为.(){ .|.& };.。接下来见证一下这两条语句的威力。因为在root用户下许多资源没有限制&#xff0c;所以useradd userfork新建一个用户userfork&a…

fwrite函数

1、函数声明 size_t fwrite( const void *buffer, size_t size, size_t count, FILE *stream ); 2、参数说明 buffer 指向要写入的数据的指针。 size 项大小&#xff08;以字节为单位&#xff09;。 count 要写入的项的最大数量。 stream 指向 FILE 结构的指针。 3、…

OpenCloudOS 与PolarDB全面适配

近日&#xff0c;OpenCloudOS 开源社区签署阿里巴巴开源 CLA (Contribution License Agreement, 贡献许可协议), 正式与阿里云 PolarDB 开源数据库社区牵手&#xff0c;并展开 OpenCloudOS &#xff08;V8&#xff09;与阿里云开源云原生数据库 PolarDB 分布式版、开源云原生数…