• 链表

    • 用数组模拟,不同于结构体加指针
    • 调用new关键字开上万级别的节点非常慢,基本会超时
    • 单链表

      • 来构造邻接表
      • 用于存图与树
      • 基本结构:
        • head 表示头结点的下标
        • e[i] 表示节点i的值
        • ne[i] 表示节点i的下一个节点的下标
        • idx 存储当前已经用到了哪个节点,表示新节点
      • 基本操作:
        • 向链表头插入一个节点
        • 在节点k后面插入一个节点
        • 删除节点k后面的一个节点
      • 模板:
        int head;//头指针,指向头结点
        int e[N];//e[i]表示节点i的值
        int ne[N],//en[i]表示节点i的下一个节点
        int idx;//存储新节点的下标 //初始化
        void init(){
        head = 0; //0代表空节点
        idx = 1;//第一个插入的节点的下标为1
        } //头插法
        void add_to_head(int x){
        e[idx] = x; //存值
        ne[idx] = head; //连接
        head = idx; //转移连接
        idx ++ ; //
        } //在下标为k的节点后面插入一个数
        void add(int k, int x){
        e[idx] = x;
        ne[idx] = ne[k];
        ne[k] = idx;
        idx ++ ;
        } //删除下标为k的节点的后面的数
        void del(int k){
        ne[k] = ne[ne[k]];
        } //头删法,删除头结点
        void del_the_head(){
        head = ne[head];
        } //遍历输出所有节点
        for(int i = head; i; i = ne[i]) cout << e[i];
    • 双链表

      • 用于优化某些问题
      • 基本结构:
        • l[i] 存储下标为i的节点的右边的节点
        • r[i] 存储下标为i的节点的左边的节点
        • e[i] 存储下标为i的节点的值
        • idx 存储新节点的下标
        • 默认0表示空的头结点,1 表示空的尾节点,所有节点在0与1之间插入
      • 模板:
        const int N = 1e5 + 10;
        int l[N], r[N], e[N], idx; //初始化
        void init(){
        //0表示空头节点,1表示空尾节点
        r[0] = 1;
        l[1] = 0;
        idx = 2; //1,0已经被使用,初始化为2,表示第一个插入的节点的下标为2
        } //在下标为k的节点后面插入节点
        void add(int k, int x){
        e[idx] = x; //赋值
        l[idx] = k; //连接左
        r[idx] = r[k]; //连接右
        l[r[idx]] = idx; //转移连接
        r[l[idx]] = idx; //转移连接
        idx ++ ; //更新下标
        } //删除下标为k的节点
        void del(int k){
        r[l[k]] = r[k];
        l[r[k]] = l[k];
        } //遍历输出节点,注意起点与终点
        for(int i = r[0]; i != 1; i = r[i]) cout << e[i]; //以下是统一插入个数与下标的代码
        //初始化
        void init(){
        //0表示空头结点,N - 1表示空尾节点
        r[0] = N - 1;
        l[N - 1] = 0;
        idx = 1; //0,N - 1被使用,下标从1开始,表示第一个插入的节点下标就是1
        }
        //add函数不变
        //遍历输出,注意起点和终点
        for(int i = r[0]; i != N - 1; i = r[i]) cout << e[i];
  • 邻接表

    • 一堆单链表,单链表数组
    • 先进后出
    • 模板:
      int stk[N], tt;//声明栈和栈顶下标
      stk[ ++ tt] = x; //x入栈
      tt --; //出栈
      stk[tt]; //取栈顶元素
      if(tt > 0) not empty //判断是否为空
      else empty
    • 单调栈:
      • 应用:在一段序列中求距离某数最近的最大值/最小值
  • 队列

    • 先进先出
    • 模板:
      int q[N], hh, tt = -1; //声明队列,队首下标,队尾下标
      q[ ++ tt] = x; //入队只能从队尾
      hh --; //出队只能从队首
      q[hh];//取队首
      q[tt];//取队尾
      if(hh <= tt)not empty //判断是否为空
      else empty
    • 单调队列(单调双端队列):
      • 引用:求固定大小的滑动窗口的最大值/最小值
  • KMP

    • 模式串匹配算法
    • 模板:
      int s[N], p[M];//主串和模式串,下标从1开始
      
      //求next数组
      void get_next(){
      for(int i = 2, j = 0; i <= m; ++ i){
      while(j && p[i] != p[j + 1]) j = ne[j];//j可以回跳并且匹配不成功时, j回跳
      if(p[i] == p[j + 1]) j ++ ; //匹配成功
      ne[i] = j; //存i可以回跳的位置
      }
      } //KMP
      for(int i = 1, j = 0; i <= n; ++ i){
      while(j && s[i] != p[j + 1]) j = ne[j]; //同上
      if(s[i] == p[j + 1]) j ++ ;
      if(j == n){ //当j等于模式串的长度时匹配成功
      j = ne[j]; //继续进行下一次匹配
      cout << i - n << endl; //输出匹配的起点下标
      }
      }
      //j = ne[j] ,j往前跳,相当于字串往后移

链表/栈/队列/KMP的更多相关文章

  1. java——链表、链表栈 LinkedListStack、链表队列 LinkedListQueue

    LikedList: package Date_pacage; public class LinkedList<E> { public static void main(String[] ...

  2. java 集合 Connection 栈 队列 及一些常用

    集合家族图 ---|Collection: 单列集合 ---|List: 有存储顺序 , 可重复 ---|ArrayList: 数组实现 , 查找快 , 增删慢 ---|LinkedList: 链表实 ...

  3. Java 容器之 Connection栈队列及一些常用

    集合家族图 ---|Collection: 单列集合 ---|List: 有存储顺序 , 可重复 ---|ArrayList: 数组实现 , 查找快 , 增删慢 ---|LinkedList: 链表实 ...

  4. java面向对象的栈 队列 优先级队列的比较

    栈 队列 有序队列数据结构的生命周期比那些数据库类型的结构(比如链表,树)要短得多.在程序操作执行期间他们才被创建,通常用他们去执行某项特殊的任务:当完成任务之后,他们就会被销毁.这三个数据结构还有一 ...

  5. 栈 队列 hash表 堆 算法模板和相关题目

    什么是栈(Stack)? 栈(stack)是一种采用后进先出(LIFO,last in first out)策略的抽象数据结构.比如物流装车,后装的货物先卸,先转的货物后卸.栈在数据结构中的地位很重要 ...

  6. 栈&队列&并查集&哈希表(julyedu网课整理)

    date: 2018-11-25 08:31:30 updated: 2018-11-25 08:31:30 栈&队列&并查集&哈希表(julyedu网课整理) 栈和队列 1. ...

  7. Java数据结构——用双端链表实现队列

    //================================================= // File Name : LinkQueue_demo //---------------- ...

  8. C语言 复杂的栈(链表栈)

    //复杂的栈--链表栈 #include<stdio.h> #include<stdlib.h> #define datatype int//定义链表栈数据类型 //定义链表栈 ...

  9. 教你如何使用Java手写一个基于链表的队列

    在上一篇博客[教你如何使用Java手写一个基于数组的队列]中已经介绍了队列,以及Java语言中对队列的实现,对队列不是很了解的可以我上一篇文章.那么,现在就直接进入主题吧. 这篇博客主要讲解的是如何使 ...

  10. Python与数据结构[1] -> 栈/Stack[0] -> 链表栈与数组栈的 Python 实现

    栈 / Stack 目录 链表栈 数组栈 栈是一种基本的线性数据结构(先入后出FILO),在 C 语言中有链表和数组两种实现方式,下面用 Python 对这两种栈进行实现. 1 链表栈 链表栈是以单链 ...

随机推荐

  1. Redis缓存穿透、击穿、雪崩

    文章目录 缓存穿透 缓存雪崩 缓存击穿 代码实战部分 缓存击穿实战代码封装 缓存穿透解决 Redis目前是非常流行的缓存数据库,缓存穿透.缓存击穿.缓存雪崩是常见的面试题,也是非常重要的问题. 缓存穿 ...

  2. ATL创建的ActiveX实现JS回调

    最近公司的产品需要使用ActiveX文件上传.讨论了基本所有的技术,最后还是决定C++搞个ActiveX...但上传的回调费了半天劲,才搞定.代码如下 STDMETHODIMP CFileSelect ...

  3. #Powerbi 利用时间智能函数,进行周度分析

    在实际工作中,我们往往需要同比分析,月度和年度的分析都有对应的时间智能函数,分别是MTD和YTD,但是缺少了周度的时间智能函数,而 恰恰日常工作中,我们又需要以周度来进行对应的分析,今天我们来学习一下 ...

  4. Web进阶LNMP网站部署

    Web进阶LNMP网站部署 目录 Web进阶LNMP网站部署 LNMP架构工作流程 部署LNMP架构 1.安装nginx 2.安装php 3.安装数据库 将Nginx和PHP建立连接 1.修改ngin ...

  5. 基于Django的简易博客系统教程

    1. 安装Django 在命令行中输入以下命令安装Django pip install django 2. 创建Django项目 在命令行中输入以下命令创建一个名为myblog的Django项目 dj ...

  6. 《MS17-010(永恒之蓝)—漏洞复现及防范》

    作者: susususuao 免责声明:本文仅供学习研究,严禁从事非法活动,任何后果由使用者本人负责. 一. 什么是永恒之蓝? - 永恒之蓝 永恒之蓝(Eternal Blue)是一种利用Window ...

  7. 聊聊分布式解决方案Saga模式

    Saga模式 Saga模式使用一系列本地事务来提供事务管理,而一个本地事务对应一个Saga参与者,在Saga流程里面每一个本地事务只操作本地数据库,然后通过消息或事件来触发下一个本地事务,如果其中一个 ...

  8. Groovy 基于Groovy实现MD5加密

    groovy 3.0.7 代码实现 实现方式1 import java.security.MessageDigest; public class MD5Utils { public final sta ...

  9. iOS中容易用错的常用知识点

    坐标系转换 ios中的坐标系有三种 视图坐标系:原点(0,0)视图的左上角 窗口坐标系:原点(0,0)窗口的左上角 世界坐标系:原点(0,0)游戏中世界的原点 平时开发中经常会遇到转UIWindow坐 ...

  10. .Net后台调用js,提示、打开新窗体、关闭当前窗体

    .Net后台调用js,提示.关闭当前窗体.打开新窗体 Response.Write("<script>window.alert('支付成功!');window.open('/Jk ...