软件设计师-基础知识科目-数据结构3

news2025/1/15 19:53:05

三、 数据结构:

时间复杂度:

  • 背复杂度对应的代码。
  • Tips:时间复杂度估算看最内层循环,如若没有循环和递归则为O(1)。

空间复杂度:

  • 需要单独空间存储数据时使用。
  • 考点:非递归的空间复杂度。
  • Tips:声明一个变量和有限个数的变量都是O(1)。

递归式:

时间/空间复杂度:

  • 递归算法的时间/空间复杂度 = 递归的次数 × 每次递归的时间/空间复杂度
    • 上述适用于每次递归时间复杂度不变的情况。
  • 如果每次递归的时间复杂度随着n变化而变化,则要根据代码来观察。

主方法求递归式:(似懂非懂)

指数计算公式:

线性表:

  • 考点:如果没有给出最好最坏平均时间复杂度的话,默认是平均时间复杂度。

顺序表:

  • 插入、删除操作最好时间复杂度为O(1),平均和最坏时间复杂度都为O(n)。
  • 查找最好、最坏、平均情况都为O(1)。

单链表:

  • 查找、插入、删除操作最好时间复杂度为O(1),平均和最坏时间复杂度都为O(n)。

顺序存储:

  • 通过元素在存储空间中的相对位置来表示数据元素之间的逻辑关系。

队列:

  • 优先队列通常采用 堆 数据结构实现,向优先队列中插入一个元素的时间复杂度为O( lgn)。

数组:

一维数组:

  • LOC:数组首地址、L:元素大小。
  • 下标从0开始:a_i = LOC + i × L
  • 下标从1开始:a_i = LOC + ( i - 1) × L
  • Tips:理解记忆。

二维数组:a[i][j] -> i表示行,j表示列

  • LOC:数组首地址、N:行数、M:列数、L:元素大小
  • 按行优先存储并且下标从0开始:a_(i,j) = LOC + (i × M + j) × L
  • 按行优先存储并且下标从1开始:a_(i,j) = LOC + [(i - 1) × M + (j-1)] × L
  • 按列优先存储并且下标从0开始:a_(i,j) = LOC + (j × N + i) × L
  • 按列优先存储并且下标从1开始:a_(i,j) = LOC + [(j - 1) × N + (i - 1)] × L
  • Tips:理解记忆。

矩阵:

对称矩阵:

概念:

  • 有一个n×n的矩阵,若矩阵中的任意一个元素都有A_(i,j) = A_(j,i),则该矩阵为对称矩阵。

考点:

  • 一般考存储下三角和主对角线;按行优先存储;基于一维数组下标从1开始存储的公式。

对称矩阵按行存储下三角区和主对角线并且下标从1(A_1,1)开始的公式:

  • 当(i≥j)时:A_(i,j) = i(i - 1) / 2 + j
  • 当(i≤j)时:A_(i,j) = j(j - 1) / 2 + i
  • ---- ----
  • 对称矩阵按行存储下三角区和主对角线并且下标从0(A_0,0)开始:
    • 当(i≥j)时:A_(i,j)=i(i+1)/2+j+1
    • 当(i≤j)时:A_(i,j)=j(j+1)/2+i+1

三对角矩阵:

概念:

  • 有一个n×n矩阵A称为三对角矩阵,其中第(i,j)个元素在j > i + 1和j < i - 1时为零。

考点:

  • 按行优先存储。

三对角矩阵按按存储并且下标从1(A_1,1)开始的公式:背

  • A_(i,j) = 2i + j - 2
  • ---- ----
  • 三对角矩阵按按存储并且下标从1(A_1,1)开始:A_(i,j) = 2i + j - 2

稀疏矩阵:

  • 三元组顺序表和十字链表是对稀疏矩阵进行压缩存储的方式。背

上述三种矩阵图例:

二叉树:

  • 完全二叉树、满二叉树概念。
  • 性质3。

二叉树的存储结构:

  • 顺序存储需要维护结点和左、右孩子的关系:结点编号为n,则左孩子为2n,右孩子为2n+1。
  • 链式存储有二叉链表和三叉链表。
    • 对于个结点n的二叉树,二叉链表的空指针为n+1,三叉链表的空指针为n+2。

二叉树的遍历:

  • 先序遍历和后序遍历,不能构造中序遍历。
  • 通过序列构造二叉树必须有中序序列。

平衡二叉树:

  • 左右子树高度差不能大于1。

有序二叉树:

  • 有序二叉树,就是左子树上的数值小于树根上的值,树根上的值小于右子树的值。左右子树也是一颗二叉排序树。
  • 最坏的查找情况是单枝树(即高度h为n)要查找n次。

二叉排序树关键字排序:

  • 第一位为根节点,第二位与根节点比较插入到树中,依次类推。

最优二叉树(哈夫曼树):

  • 概念:它是一类带权路径长度最短的树。路径是从书中一个结点到另一个结点之间的通路,路径上的分支数目为路径长度。
  • 哈夫曼树中权值越大的结点离根结点越近,权值越小的结点离根结点越远。
  • 哈夫曼树只有度为0和度为2的结点,没有度为1的结点。
  • n个权值构造的哈夫曼树具有2n-1个结点。
  • 哈夫曼编码,基于贪心算法。
  • 哈夫曼树中最小的两个结点互为兄弟结点。
构造最优二叉树:
  • 方法:

  • 规则:***
    • 1. 从前往后找两个权重最小。2. 小左大右。3. 加入末尾。4. 权值相同从前往后。5. 用时再调。
压缩比计算:
  • 概念:求等长编码到哈夫曼编码压缩了多少。
  • 等长编码需要多少位。-> 公式:2^x >= 字符个数,x为需要多少位。
  • 哈夫曼编码是变长编码,在哈夫曼树中,从根节点开始,给左右分支标记0,1。即一层节点占一位。
  • 压缩比 =(等长编码长度 - 哈夫曼编码车长度) / 等长编码长度

图:

有向图、无向图:

  • 无向图:连接顶点的边是无向边
  • 有向图:连接顶点的边是有向边(弧)
  • ---- ----
  • 有向图和无向图的所有顶点度数之和 2e。(e为边数)
  • 有向图和无向图的边数 e = 顶点度数之和/2。

完全图:

  • 概念:每对顶点之间都恰连有一条边的图。
  • 无向完全图:(n*(n-1)) / 2 条边
  • 有向完全图:n*(n-1) 条边

连通图:

  • 连通图:无向图中任意两个顶点之间都有路径。最少有n-1条边,最多有(n*(n-1))/2条边。
  • 强连通图:有向图中任意两个顶点之间都有路径。 最少有n条边,最多有n*(n-1)条边。

最小生成树:

最小生成树-普利姆(Prim)算法:
  • 贪心算法。
  • 思想:从任意一个顶点开始,沿着权重最小的边进行扩展。
  • 时间复杂度:O[n2]

最小生成树-克鲁斯卡尔(Kruskal)算法:

  • 贪心算法。
  • 思想:每次选择权重最小的边来将两个顶点连接起来。
  • 时间复杂度为O[elog e]。

----- ----- -----

  • 若网较稠密,则Prim算法更好。

邻接矩阵:

  • 概念:表示顶点之间相邻关系的矩阵。
  • 查找所有顶点的邻居顶点的时间复杂度为O(n^2)。

邻接链表表示法:

  • 邻接表更适合存储稀疏图(边数很少的图)
  • 无向图采用邻接表存储有2e个表结点(e为边数)。
  • 有向图采用邻接表存储有n+e个表结点(n为结点数,e为边数) 。

哈希表:

  • 用线性探测法解决冲突容易产生聚集问题。

查找:

折半(二分)查找:

  • 折半查找在查找成功时,关键字的比较次数最多为 log2(n) +1 。
  • 折半查找的时间复杂度为O(log2n)。
  • 要求元素顺序存储,元素有序排列。
  • 考题:
    • mid = (low+high)/2 取整, k > mid时, low = mid+1,k。并且注意细节

不能构成查找过程中关键字比较序列考题:

  • 解题规律:比较序列可能是:大大大... ...大、小小小... ...小 、小大小大... ...小 大、大小大小... ...大小

排序:

  • 当数列基本有序时,采用插入排序比较合适,使用插入排序中希尔排序。背
  • 一定范围内的整数排序时,使用基数排序。例如:需要排序的记录是0-9的整数。
  • 快速排序:采用分治思想。最坏O(n^2),平均O(nlog2^n),一趟排序O(n)。基本有序时,快排具有最坏的情况。最佳的基准元素为中位数划分。
  • 归并排序:采用分治思想。时间复杂度,最好最坏一致O(nlog2^n)。稳定。
  • 堆排序:不稳定。空间复杂度O(1)。

堆:

使用数组构建大顶堆:

  • 将数组转换成二叉树。
  • 从最后一层的非叶子节点开始与叶子节点调整。一层一层的调整。调整过后导致已经调整的层大小顺序相反,则继续调整。

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

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

相关文章

希亦、石头、添可洗地机哪个更好用?资深家电测评师多角度横评

作为一个测评了许多洗地机的家电测评师&#xff0c;有很多人问我&#xff0c;他想入手一款适合自己的家用洗地机&#xff0c;不知道怎么购买到自己合适的&#xff0c;结果自己跑去搜索后发现为什么有的洗地机几百块钱就能入手&#xff0c;而有的又得几千元&#xff0c;买贵的怕…

CSS实现热门创作者排行榜(毛玻璃效果)

CSS实现热门创作者排行榜&#xff08;毛玻璃效果&#xff09; 效果展示 CSS 知识点 CSS 基础知识回顾filter 属性运用回顾 整体页面布局实现 <div class"container"><h3>Popular Creator Rank List</h3><!-- 用户列表容器 --><div cl…

NetSuite Saved Search-当前库存快照查询报表(二)

之前第一篇文章我们说明了&#xff0c;如何利用Saved Search来制作一个能够显示批次物料与非批次物料的Lot信息以及On Hand在手数量的“当前库存快照查询报表”&#xff0c;但是当用户提出“我们能否再加上批次物料的效期”需求时&#xff0c;我们原有的Saved Search并不能达到…

k8s知识

k8s是用于容器编排和管理的&#xff0c;docker或者ctr是k8s的运行时&#xff0c;k8s通过容器运行时来启动容器&#xff0c;容器启动需要镜像&#xff0c;镜像可以用docker构建&#xff0c;dockerfile就是用于自定义如何构建镜像&#xff0c;所以上面那套流水线就是先用dockerfi…

苍穹外卖Day10——总结10

前期文章 文章标题地址苍穹外卖Day01——总结1https://lushimeng.blog.csdn.net/article/details/135466359苍穹外卖Day02——总结2https://lushimeng.blog.csdn.net/article/details/135484126苍穹外卖Day03——总结3https://blog.csdn.net/qq_43751200/article/details/1363…

突破编程_前端_SVG(基础元素介绍)

1 rect 矩形 在 SVG 中&#xff0c;<rect> 元素用于创建圆形。 &#xff08;1&#xff09;基本语法 <rectx"x坐标"y"y坐标"width"宽度"height"高度"rx"可选&#xff1a;圆角x半径"ry"可选&#xff1a;圆角…

.net框架和c#程序设计第二次测试

一、实验内容 1、设计一个用户登录页面webform1.aspx&#xff0c;效果如下图所示&#xff1a; 2、点击webform1.aspx中“还未注册”连接进入register.aspx&#xff0c;注册页面效果如下图所示&#xff1a;点击用户注册信息到usershow.aspx页面&#xff0c;并显示注册的用户信息…

蓝牙学习十(扫描)

一、简介 从之前的文章中我们知道&#xff0c;蓝牙GAP层定义了四种角色&#xff0c;广播者&#xff08;Broadcaster&#xff09;、观察者&#xff08;Observer&#xff09;、外围设备&#xff08;Peripheral&#xff09;、中央设备&#xff08;Central&#xff09;。 之前的学习…

什么是LPO?

近年来&#xff0c;光通信产业的发展势头很猛。 在5G、宽带中国、东数西算等国家战略的持续刺激下&#xff0c;国内光通信技术取得了巨大突破&#xff0c;光基础设施也有了质的飞跃。 特别是今年&#xff0c;AIGC大模型爆火&#xff0c;智算和超算崛起&#xff0c;更是带动了…

VueDraggablePlus 支持 Vue2 和 Vue3 的拖拽组件

官网&#xff1a;https://alfred-skyblue.github.io/vue-draggable-plus/

Day 34:贪心 LeedCode 1005.K次取反后最大化的数组和 134. 加油站 135. 分发糖果

1005. K 次取反后最大化的数组和 给你一个整数数组 nums 和一个整数 k &#xff0c;按以下方法修改该数组&#xff1a; 选择某个下标 i 并将 nums[i] 替换为 -nums[i] 。 重复这个过程恰好 k 次。可以多次选择同一个下标 i 。 以这种方式修改数组后&#xff0c;返回数组 可…

rac数据库默认网关不通导致集群异常

集群CSSD进程reconfiguration完成&#xff0c;显示2个节点都在线。但ora.net1.network服务启动失败&#xff0c;且有依赖关系的资源随后启动失败并且已经达到上限。 查看两个节点的网络信息&#xff0c;发现两个节点的默认网关是不一致的。 修改故障节点网关 在RAC中&#xff0…

图表分析网页模版大数据可视化大屏电子沙盘合集

图表分析网页模版 大数据可视化大屏电子沙盘合集&#xff0c;项目基于html/css/js&#xff0c;包含行业&#xff1a; 智慧政务 智慧社区 金融行业 智慧交通 智慧门店 智慧大厅 智慧物流 智慧医疗 通用模板 大数据分析平台 项目包含功能 (部分)&am…

MongoDB快照(LVM)业务场景应用实战

MongoDB和LVM快照概述 MongoDB的重要性&#xff1a;MongoDB支持的灵活的文档模型&#xff0c;使其成为处理大量分散数据的理想选择&#xff0c;特别是在需要快速迭代和频繁更改数据结构的应用中。 LVM&#xff08;逻辑卷管理&#xff09;快照技术基本概念&#xff1a;LVM允许…

基于springboot+vue+Mysql的滴答拍摄影项目

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

vue3前端加载动画 lottie-web 的简单使用案例

什么是 Lottie Lottie 是 Airbnb 发布的一款开源动画库&#xff0c;它适用于 Android、iOS、Web 和 Windows 的库。 它提供了一套从设计师使用 AE&#xff08;Adobe After Effects&#xff09;到各端开发者实现动画的工具流。 UED 提供动画 json 文件即可&#xff0c; 开发者就…

Disk Drill Enterprise for Mac v5.5.1515数据恢复软件中文版

Disk Drill 是 Mac 操作系统固有的Mac数据恢复软件&#xff1a;使用 Recovery Vault 轻松保护文件免遭意外删除&#xff0c;并从 Mac 磁盘恢复丢失的数据。支持大多数存储设备&#xff0c;文件类型和文件系统。 软件下载&#xff1a;Disk Drill Enterprise for Mac v5.5.1515激…

Ubuntu 20.04.06 PCL C++学习记录(二十)

[TOC]PCL中点云分割模块的学习 学习背景 参考书籍&#xff1a;《点云库PCL从入门到精通》以及官方代码PCL官方代码链接,&#xff0c;PCL版本为1.10.0&#xff0c;CMake版本为3.16 学习内容 基于颜色的区域增长细分 源代码及所用函数 源代码 #include<iostream> #i…

【算法】第二篇 大衍数列

导航 1. 简介2. 数列特征3. 代码演示1. 简介 大衍数列,来源于《乾坤谱》中对易传“大衍之数五十”的推论。主要用于解释中国传统文化中的太极衍生原理。数列中的每一项,都代表太极衍生过程中,曾经经历过的两仪数量总和。是中华传统文化中隐藏着的世界数学史上第一道数列题。…

大厂高频面试题复习JAVA学习笔记-学习路线

对于应届生&#xff0c;要找到一份java工作&#xff0c;你得大概学会&#xff1a; java基础&#xff1a;javase、jvm、juc、gc、mysql、jdbc&#xff0c;计网计组 Java微服务基础Maven→Gradle→Spring6→SpringMVC→MyBatis→MyBatisPlus→SSM->Redis7->SpringBoot2-&…