首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏nnngu

    数据结构10

    那么关于图,我将从以下几点进行总结: 1、图定义 2、图相关概念和术语 3、图创建和遍历 1、图定义 什么是图呢? 图是一种复杂非线性结构。 父节点)及下一层多个元素(孩子节点)相关; 而在图形结构中,节点之间关系是任意,图中任意两个数据元素之间都有可能相关。 同理,将具有n(n-1)条边有向图称为有向完全图。 2-3、顶点度 对于无向图,顶点度表示以该顶点作为一个端点数目。 比如,图(a)无向图中顶点V3度D(V3)=3 对于有向图,顶点度分为入度和出度。入度表示以该顶点为终点入边数目,出度是以该顶点为起点出边数目,该顶点度等于其入度和出度之和。 下面是一个非连通图例子: ? 上图中,因为V5和V6是单独,所以是非连通图。 2-7、强连通图(有向图) 强连通图是对于有向图而言,与无向图连通图类似。 2-8、网 带”权值”连通图称为网。

    97870发布于 2018-03-15
  • 来自专栏zaking's

    用js来实现那些数据结构10(集合02-集合操作)

      前一篇文章我们一起实现了自定义set集合类。那么这一篇我们来给set类增加一些操作方法。那么在开始之前,还是有必要解释一下集合操作有哪些。便于我们更快速理解代码。    1、并集:对于给定两个集合,返回一个包含两个集合中所有元素新集合。注意,集合中不会有重复值。     2、交集:对于给定两个集合,返回一个包含两个集合中共有元素新集合。    这里我们就不详细再赘述一遍集合操作数学计算方法了。有兴趣或者忘记了小伙伴可以百度一下。那么咱们就正式开始集合操作方法。 中值存入新unionSet中就可以了。 只是要注意是如果setA子集是setB,那么setA元素个数是一定大于或等于setB

    1.3K60发布于 2018-05-02
  • 来自专栏全栈程序员必看

    用js来实现那些数据结构10(集合02-集合操作)

    大家好,又见面了,我是你们朋友全栈君。   前一篇文章我们一起实现了自定义set集合类。那么这一篇我们来给set类增加一些操作方法。那么在开始之前,还是有必要解释一下集合操作有哪些。 便于我们更快速理解代码。   1、并集:对于给定两个集合,返回一个包含两个集合中所有元素新集合。注意,集合中不会有重复值。      2、交集:对于给定两个集合,返回一个包含两个集合中共有元素新集合。   3、差集:对于给定集合,返回一个包含所有存在于第一个集合且不存在于第二个集合元素新集合。 4、验证一个给定集合是否是另一个集合子集。   这里我们就不详细再赘述一遍集合操作数学计算方法了。有兴趣或者忘记了小伙伴可以百度一下。那么咱们就正式开始集合操作方法。 回顾一下代码,我们发现其实集合各种操作方法在我们实际工作中也是经常应用到,只是我们在用数组操作,并没有十分去注意这些细节。比如并集操作,我们在合并两个数组时候肯定用到过。

    1K20编辑于 2022-07-20
  • 来自专栏合集

    数据结构|队列实现

    队列 队列特性是先进先出。每次数据出去只能队列头部,每次数据进来只能加在队列尾部。 队列实现一般有两种方式,线性队列,链表队列。 链表队列 链表队列实现可以参考单向链表。 线性队列 超简单,基于数组实现,每次删除数据则把数组第一个删除,把后续往前面移动,最后一个直接置空;添加数据只需要在最后继续添加即可;数组会有定长,删除和添加数据一定要检验。 #include <iostream> using namespace std; typedef struct queue { int data[10]; int length; int rear; } queue; queue add_num(queue q, int num) { if (q.length + 1 <= 10) { q.data [q.length] = num; q.length += 1; } else if (q.length + 1 > 10) { cout <<

    38620发布于 2020-06-05
  • 来自专栏我的计算机成长

    数据结构-栈实现

    1.栈概念及结构 栈:一种特殊线性表,其只允许在固定一端进行插入和删除元素操作。进行数据插入和删除操作一端称为栈顶,另一端称为栈底。 栈中数据元素遵守后进先出LIFO(Last In First Out)原则。 压栈:栈插入操作叫做进栈/压栈/入栈,入数据在栈顶。 出栈:栈删除操作叫做出栈。出数据也在栈顶。 2.栈实现实现一般可以使用数组或者链表实现,相对而言数组结构实现更优一些。因为数组在尾上插入数据代价比较小。   0,则相当于是malloc,扩容完之后就将数据放进top这个位置,然后再将top++,这样才会使得top一直是栈顶元素下一个位置。 void STPop(ST* ps, STDataType x) { assert(ps); //空 assert(ps->top > 0); --ps->top; } 2.6栈数据个数 int

    24310编辑于 2024-01-23
  • 来自专栏zxctscl个人专栏

    数据结构】堆实现

    前言 在上一篇关于树和二叉树博客中,最后提到了堆。有小根堆和大根堆。 左边结构是我们想象出来,右边才是实际存储结构。 这次来实现堆。 2. 堆实现 用数组来实现,这里以实现小堆为例子,它特点是父节点小于子节点。 先定义一个堆结构体:为了方便扩容,加了size。 2.2.1.3 情况三 这里先将10与它父节点28比较,发现10比较小,此时就交换它们两个;再往上看,发现18比10小,又交换;再往上,发现15也比10小,此时又交换。 2.2.2 插入代码实现 先判断空间是否足够,不够就扩容,够就直接插入x,再将php->size++。 2.3.2 删除代码实现 首尾交换删除,然后将php->size--,最后向下调整。

    32110编辑于 2024-01-23
  • 来自专栏Yui编程知识

    数据结构——单链表实现

    链表概念 概念:链表是一种物理存储结构上非连续、非顺序存储结构,数据元素逻辑顺序是通过链表中指针链接次序实现 。 这里我来解释一下什么叫做逻辑上连续而物理上补连续。 所谓逻辑上连续,就是指你你可以通过第一个节点找到第二个节点,就行火车一样你可以从一节车厢走到另一节车厢。 物理上不连续是指内存地址不连续,不想顺序表中数组是连续。 next就起到了重要作用,我们把2地址存在1next中,把3地址存在2next中,最后把3next指向NULL就可以了,再画一个图就是这样。 我还用了一个头节点来指向第一个节点,从图上来看是不是每个节点都联系了起来,这就是有了逻辑上连续。 下面我来讲解实现链表都要哪些函数。 头插函数 想要实现头部插入,我们先画图。 要想吧新节点插入头部,我们就要把,新节点nest指向第一个节点,然后把pphead指向新节点。

    26610编辑于 2024-10-15
  • 来自专栏c/c++

    数据结构——循环队列实现

    之前我们学习过数据结构栈和队列,详情可点击这里数据结构——lesson5栈和队列详解进行查看,队列是一种先进先出结构,但是我们之前讲队列都是类似于线性物理结构,这次我们所介绍队列则是一直类似于环状循环结构 1.循环队列介绍 循环队列是一种线性数据结构,其操作表现基于 FIFO(先进先出)原则并且队尾被连接在队首之后以形成一个循环。它也被称为“环形缓冲器”。 rear下一个元素指向front,如果增加一个空闲位置,队列满时rear下一个位置就不再指向front; 在决定选哪种方法之前,我们先要考虑一下是使用链表来实现还是使用数组也就是顺序表来实现循环队列 ;当然这里土土会将两种方法都写下来,并和大家一起分析两种方法优劣之处,以便大家选择合适和喜欢形式(对于顺序表链表有疑问可以在土土数据结构专栏里——数据结构学习笔记 进行查看复习哦~) 3.用单链表实现循环队列 ,对应数组实现循环队列则需要front,rear不断进行取模运算以防越界; 但是链表实现需要手动将开辟节点链接在一起,数组则不一样它一开辟就是地址连续一段空间; 其他实现链表和数组都差不多;

    85110编辑于 2024-03-24
  • 来自专栏技术之路

    数据结构】栈基本实现

    之前编写了自己数组,下来基于之前基础之上实现了栈基本内容 namespace DataStructure { class Program { ///

    public class Array<E> { private E[] data; private int size; //构造函数,传入数组容量 capacity=10 public Array() : this(10) { } //获取数组元素个数 public int getSize() { return size; } //获取数组容量 public int } res.Append("] top"); return res.ToString(); } } } 上面是栈基本实现

    21010编辑于 2024-04-23
  • 来自专栏QT

    数据结构】-- 单链表实现

    这时我们就可以使用另一种数据结构--链表。 和顺序表一样,链表也是一种线性表。和顺序表不同是,虽然链表在逻辑上是连续,链表在物理上并不是连续。 链表中节点通过指针域相互连接,形成一个动态数据结构,可以方便地进行插入、删除等操作,而不需要像数组一样需要连续内存空间。 单链表实现 模块划分 和实现顺序表一样,分为三个文件来实现,SList..c用来实现顺序表各种方法,SList.h用来包含实现方法所需头文件和所需方法初始化。 test.c用来测试写方法是否有问题。 节点 实现链表节点需要创建两个变量,数据域用来储存数据,指针域用来存放下一个节点地址。我们用结构体来实现。 = NULL) { printf("找到了\n"); } else { printf("没找到\n"); } SLTNode* find2 = SLTFind(plist, 10); if (find2

    18210编辑于 2025-12-30
  • 来自专栏Yui编程知识

    顺序表实现数据结构

    1.线性表 线性表(linear list)是n个具有相同特性数据元素有线序列。 线性表是一种在实际中广泛使用数据结构,常见线性表有:顺序表、链表、栈、队列、字符串… 线性表在逻辑上是线性结构,也就是说是连续一条线。但是在物理结构上并不一定是连续,比如链表。 * a; int sz;//有效数据个数 int capacity;//存储空间大小 }SL; 3.模拟实现 静态顺序表只适合于确定知道要存储多少数据场景下。 下面是模拟实现: 3.1 准备工作 定义一个结构体 typedef int Datatype;//为了适用不同类型顺序表 typedef struct SeqList { Datatype* a; 同时还要删除该顺序表中数据也又两种情况: 1.顺序表中数据已经删完了,无法再删。 2.顺序表中数据足够删除。

    26110编辑于 2024-10-16
  • 来自专栏我的博客

    数据结构:单链表实现

    上一次我们实现了顺序表应用,但是对于顺序表还是会有以下几个问题: 1. 中间/头部插入删除,时间复杂度为O(N)。 2. 增容需要申请新空间,拷贝数据,释放旧空间。会有不小消耗。 3. 单链表概念 单链表是一种链式存取数据结构,用一组地址任意存储单元存放线性表中数据元素。单链表中数据元素由一个数据域和一个指针域组成,其中指针域指向下一个数据元素。 注意:每次申请一块节点空间时,它和之前节点空间不一定是连续,所以要想找到这块空间就得通过地址来找。 链表一共有8种分类,如下图所示: 今天我们来实现单链表,也就是不带头单向不循环链表。 同顺序表一样我们先创建一个SList.h头文件和一个SList.c源文件,.h文件实现函数声明,.c文件实现函数定义。 现在我们来实现尾插,如下图: 尾插很简单,我们只需要注意,循环遍历时结束条件是尾节点next指针为空,而不是尾节点为空。

    21110编辑于 2025-12-22
  • 来自专栏我的博客

    数据结构:双链表实现

    上一次我们实现了单链表,也就是不带头单向不循环链表,这次我们首先双链表(带头双向循环链表)。 对于单链表来说,还是存在一些缺点,例如:查找效率低(需要从头开始遍历链表),不能随机访问。 在List.h文件中,首先创建一个结构体用来存放节点信息,这里和单链表区别是我们额外增加了一个结构体指针成员prev用来指向上一个节点指针。 接下来我们来实现双链表增删查改操作。 所以我们要养成良好编程习惯。 我们创建一个test.c文件调试一下: 2.链表尾插 双链表尾插实现就很简单了,不同于单链表还要先找到尾节点,这里phead->prev指向就是尾节点。 为了方便测试我们先将打印方法实现。 3.链表打印 打印就需要循环遍历一遍,注意我们条件现在不再是pcur->next != NULL,而是!= phead。 10.链表销毁 只需要循环遍历链表,将所有节点释放就行。 但需要注意是,我们在释放前要先将下一个节点地址存在next中,不然在我们释放掉pcur之后,拿不到下一个节点地址。

    16110编辑于 2025-12-22
  • 来自专栏Yui编程知识

    数据结构——堆实现(详解)

    实现 介绍的话就到此为止,下面我们来进行堆实现。无非就是那几样。 ,没错就是顺序表,但实现起来会比顺序表更难一些哦。 函数声明 我们先把初始化,销毁,插入,删除等等要实现函数声明一下: void HpInit(HP* php); void Hppush(HP* php, HpDataType x); void Hpdestroy 这里我们插入40,40比56小那么它应该是“父亲”,所以我们就要把他和56调换位置,但是如果我们再多想一想,我插入是9呢,是不是就还要和10调换一下位置了?对,这就是小堆内涵,小永远再上面。 我们发现下面我有写了有个函数,向上调整函数adjustup,没错上面我们讲谁小于谁交换就要通过这个函数来实现

    28511编辑于 2024-10-15
  • 来自专栏合集

    数据结构|栈实现

    栈满足特性是先进后出,就像货车装货物,把货物一次放进去,但是卸货时候,你得先把最外面的卸载了,才能继续卸载里层货物。 栈实现有两种形式,一种是数组,一种是链表。 ? 数组栈长度一定,使用top记录当前位置,比如说,array长度为10,但是我们指存储了5个数据,那么top值就是4。往栈里面加入一个数据,top变成5,当已经10个数据时,top为9。 关于实现一个顺序栈 #include <stdio.h> #include <iostream> #include <stdlib.h> using namespace std; class Stack { public: int top; int length; int content[10]; int push(int num); int pop(); ; }; int Stack::peek() { return content[top]; }; int Stack::push(int num){{top += 1; if (top >= 10

    39720发布于 2020-06-04
  • 来自专栏Linux学习~

    数据结构】开卷数据结构?--堆实现超详解

    目录 前言 堆概念和结构 堆实现 接口展示 堆结构创建 堆初始化 堆销毁 入堆 数据向上调整 入堆测试 出堆 向下调整数据 出堆测试 堆顶数据获取 堆数据个数 判断空堆 堆数据打印 堆源码 ---- 前言 ---- 本章主要讲解: 数据结构知识以及实现概念和结构 ---- 概念: 将所有元素按完全二叉树顺序存储方式存储在一个一维数组中并以一定数据要求存储 堆总是一棵完全二叉树 注:在上节基础知识讲解中我们知道父节点和左右子节点编码关系,以此可以对应到数组中下标关系,这里我们主要用数组来表示和实现堆 图示:数组堆 堆实现 ---- 注:这里我们主要实现大堆,对于小堆实现与大堆只有数据调整上出入 接口展示 //堆初始化 void HeapInit(HP* hp); //堆销毁 void HeapDestroy(HP* hp) = parent; parent = (child - 1) / 2; } } 入堆测试 测试代码: int main() { int a[] = { 70, 56, 30, 25, 15, 10

    39030编辑于 2022-11-30
  • 来自专栏C语言入门到精通

    数据结构 | 每日一练(10

    数据结构 合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下 ——老子 1 每日一练 1.评价一个好算法,您是从哪几方面来考虑? 2.解释和比较以下各组概念 (1)算法时间复杂性 (2)算法 (3)频度 3. 根据数据元素之间逻辑关系,一般有哪几类基本数据结构? 4.对于一个数据结构,一般包括哪三个方面的讨论? 5. 当你为解决某一问题而选择数据结构时,应从哪些方面考虑? 6. 若将数据结构定义为一个二元组(D,R),说明符号 D,R 应分别表示什么? 正确答案 1.评价好算法有四个方面。一是算法正确性;二是算法易读性;三是算法健壮性;四是算法时空效率(运行)。 2.(1)算法时间复杂性是算法输入规模函数。 算法输入规模或问题规模是作为该算法输入数据所含 数据元素数目,或与此数目有关其它参数。有时考虑算法在最坏情况下时间复杂度或平均时间复杂度。

    7973029发布于 2019-06-10
  • 来自专栏Python数据结构与算法

    数据结构与算法-(10)---列表(List)

    (为了简单起见,假设表中不存在重复数据项) 如一个考试分数集合“54,26,93,1777和31” 如果用无序表来表示,就是[54,26,9317, 77, 31] 采用链表实现无序表 采用链表实现无序表主要原因是 另外,链表实现无序表还有以下优点: 内存使用效率高:链表只需要分配和使用存储空间,而不需要事先设置固定存储大小,这可以节省内存空间。 链表是一种非常适合实现无序表数据结构,因为它具有动态性,灵活性,高效性和内存使用效率高等优点。 可以采用 链接结点 方式来构建数据集 实现无序表 链表第一个 和 最后一个 节点最重要 如果想访问到链表中所有节点,就必须从第一个节点沿链接遍历下去. Unordered List - 无序表 箭头所指为表头 最快捷就是从表头开始(相当于insert[0]), 但是之前列表实现inser[0]时间复杂度是O(n), 而链表是O(1) 结点(node

    32910编辑于 2024-01-18
  • 来自专栏海仔技术驿站

    java实现数据结构

    数据结构与算法 : 一.数据结构和算法简介 数据结构是指数据在计算机存储空间中安排方式,而算法时值软件程序用来操作这些结构中数据过程. 二. 在这个例子中数组就是一个数据结构,而使用for循环来遍历数组,则是一个简单算法.可见数据结构和算法是构成程序灵魂所在,而且也有人提出数据结构+算法=程序. 数据结构 = 逻辑结构 + 存储结构 + (在存储结构上)运算/操作; 数据逻辑结构 数据逻辑结构指数据元素之间逻辑关系(和实现无关). 表和树是最常用两种高效数据结构,许多高效算法能够用这两个数据结构来设计实现. 线性结构 : 数据结构中线性结构值得是数据元素之间存在着"一对一"线性关系数据结构. 一个带头结点单链表实现线性表结构图如图所示.

    1.2K81发布于 2019-08-06
  • 来自专栏学习成长指南

    数据结构------栈介绍和实现

    : 栈实际上也是一个存储数据结构,和我们线性表是一样,但是栈肯定是有自己独特之处,否则也不会作为一个单独数据结构存在,确实,栈特殊性就在于我们数据都是从栈顶进入,栈顶出去,这个就是栈特殊之处 拿这个{(【】)}作为案例,我们{先进栈,(再进栈,【再进栈,这个时候我们左边括号都判断完了,我们需要判断右边符号和左边是不是一一对应,这个时候就可以使用栈这个数据结构,因为我们栈是后进先出 ,这个时候栈这个数据结构就可以帮助我们判断这个一串符号前后是不是一一对应。 2.栈实现 我们还是写一个系统文件,包括栈实现头文件,源文件和测试文件这三个文件; 我们在头文件里面进行相关函数声明,源文件里面进行相关函数定义,测试文件里面定义一个栈进行我们写函数测试 5.栈应用--有效括号 这里应用就是我们开始提到括号匹配问题,我们要判断这个括号之间是否是相互匹配; 因为现阶段我们还是使用C语言进行实现,所以我们要自己实现栈,如果是C++,我们可以使用相应一些库

    25310编辑于 2025-02-24
领券