数据结构 队列

news2025/1/22 21:42:25

一定义

1.1概述:

            队列只允许在一端进行插入操作,而在另一端进行删除操作的线性表

特点:队列是先进先出的线性表 允许插入的一端称为队尾,允许删除的一端是队头

这里我们就介绍链式的 

1.2 建立队列

这里说一句 其实不管是栈还是队列都是一种特殊的线性表,我们只需要将线性表了解透彻 其他的都是按照一些特殊的规则来要求线性表的

#include <stdio.h>
#include <malloc.h>
typedef struct qnode
{
    int data;
    struct qnode *next;
}qnode,*queueptr;//定义结构体数据域和指针域

typedef struct Linkqueue
{
   queueptr front,rear;//队头,队尾指针
}Linkqueue;
//初始化队列函数,将队头,队尾结构体变量传入,以及队列的个数
void initlist(Linkqueue *L,int n)
{
    //下面就是尾插法建立队列了 
    queueptr head;
    queueptr temp;
    queueptr tail;
    head=(queueptr)malloc(sizeof(qnode));
    head->next=NULL;
    for(int i=0;i<n;i++)
    {
        temp=(queueptr)malloc(sizeof(qnode));
        temp->data=i;
        if(head->next==NULL)
        {
            head->next=temp;
            L->front=head;//将对头指针指向头结点
        }
        else
        {
            tail->next=temp;
        }
        tail=temp;
    }
    L->rear=tail;//将队尾指针指向尾结点
    tail->next=NULL;//尾结点的指针指向空
}
int main()
{
    Linkqueue L;
    initlist(&L,5);
    printf("队头指针指向的元素数据域%d\n",L.front->next->data);
    printf("队尾指针指向的元素数据域%d\n",L.rear->data);
    L.front=L.front->next;// 我们队头指针指向的是头结点不是首元结点所以需要指向后继结点才能输出需要的数据域
    for(int i=0;i<5;i++)
    {
      printf("%d\n",L.front->data);
      L.front=L.front->next;
    }
    return 0;
}

1.3入队操作

入队操作时,其实就是在链表的尾部插入结点

核心代码:

void enqueuelist(Linkqueue *L,int n)
{
    queueptr new;//声明一个新的结点
    new=(queueptr)malloc(sizeof(qnode));
    new->data=n;
    L->rear->next=new;//将之前尾结点的指针域指向新建结点
    new->next=NULL;
    L->rear=new;//将队尾指针指向新的尾元素
}

完整实现,插入一个新结点数据域是6 

#include <stdio.h>
#include <malloc.h>
typedef struct qnode
{
    int data;
    struct qnode *next;
}qnode,*queueptr;//定义结构体数据域和指针域

typedef struct Linkqueue
{
   queueptr front,rear;//队头,队尾指针
}Linkqueue;
//初始化队列函数,将队头,队尾结构体变量传入,以及队列的个数
void initlist(Linkqueue *L,int n)
{
    //下面就是尾插法建立队列了 
    queueptr head;
    queueptr temp;
    queueptr tail;
    head=(queueptr)malloc(sizeof(qnode));
    head->next=NULL;
    for(int i=0;i<n;i++)
    {
        temp=(queueptr)malloc(sizeof(qnode));
        temp->data=i;
        if(head->next==NULL)
        {
            head->next=temp;
            L->front=head;//将对头指针指向头结点
        }
        else
        {
            tail->next=temp;
        }
        tail=temp;
    }
    L->rear=tail;//将队尾指针指向尾结点
    tail->next=NULL;//尾结点的指针指向空
}

void enqueuelist(Linkqueue *L,int n)
{
    queueptr new;//声明一个新的结点
    new=(queueptr)malloc(sizeof(qnode));
    new->data=n;
    L->rear->next=new;//将之前尾结点的指针域指向新建结点
    new->next=NULL;
    L->rear=new;//将队尾指针指向新的尾元素
}
int main()
{
    Linkqueue L;
    initlist(&L,5);
    enqueuelist(&L,6);
    printf("队头指针指向的元素数据域%d\n",L.front->next->data);
    printf("队尾指针指向的元素数据域%d\n",L.rear->data);
    L.front=L.front->next;// 我们队头指针指向的是头结点不是首元结点所以需要指向后继结点才能输出需要的数据域
    for(int i=0;i<6;i++)
    {
      printf("%d\n",L.front->data);
      L.front=L.front->next;
    }
    return 0;
}

1.4出队操作

int  deletelist(Linkqueue *L)
{
    //出栈操作时,将头节点指向的结点出栈
        queueptr p;
        if(L->front==L->rear)
        {
            return 0;
        }
        p=L->front->next;//p是要删除的首元结点
        L->front->next=p->next;//将头结点后继指向p的后继结点
        if(L->rear==p)
        {
            L->rear=L->front;//如果只有一个结点 队头和队尾指针应相同
        }
        free(p);
        return 1;
}
#include <stdio.h>
#include <malloc.h>
typedef struct qnode
{
    int data;
    struct qnode *next;
}qnode,*queueptr;//定义结构体数据域和指针域

typedef struct Linkqueue
{
   queueptr front,rear;//队头,队尾指针
}Linkqueue;
//初始化队列函数,将队头,队尾结构体变量传入,以及队列的个数
void initlist(Linkqueue *L,int n)
{
    //下面就是尾插法建立队列了 
    queueptr head;
    queueptr temp;
    queueptr tail;
    head=(queueptr)malloc(sizeof(qnode));
    head->next=NULL;
    for(int i=0;i<n;i++)
    {
        temp=(queueptr)malloc(sizeof(qnode));
        temp->data=i;
        if(head->next==NULL)
        {
            head->next=temp;
            L->front=head;//将对头指针指向头结点
        }
        else
        {
            tail->next=temp;
        }
        tail=temp;
    }
    L->rear=tail;//将队尾指针指向尾结点
    tail->next=NULL;//尾结点的指针指向空
}

int  deletelist(Linkqueue *L)
{
    //出栈操作时,将头节点指向的结点出栈
        queueptr p;
        if(L->front==L->rear)
        {
            return 0;
        }
        p=L->front->next;//p是要删除的首元结点
        L->front->next=p->next;//将头结点后继指向p的后继结点
        if(L->rear==p)
        {
            L->rear=L->front;//如果只有一个结点 队头和队尾指针应相同
        }
        free(p);
        return 1;
}
int main()
{
    Linkqueue L;
    initlist(&L,5);
    int a=deletelist(&L);
    if(a)
    {
        printf("队头指针指向的元素数据域%d\n",L.front->next->data);
        printf("队尾指针指向的元素数据域%d\n",L.rear->data);
    L.front=L.front->next;// 我们队头指针指向的是头结点不是首元结点所以需要指向后继结点才能输出需要的数据域
    for(int i=0;i<4;i++)
    {
      printf("%d\n",L.front->data);
      L.front=L.front->next;
    }        
    }
    else
    printf("delete error");
    return 0;
}

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

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

相关文章

php基础学习之错误处理(其一)

一&#xff0c;错误处理的概念 错误处理指的是系统(或者用户)在执行某些代码的时候&#xff0c;发现有错误&#xff0c;就会通过错误处理的形式告知程序员&#xff0c;俗称报错 二&#xff0c;错误分类 语法错误&#xff1a;书写的代码不符合 PHP 的语法规范&#xff0c;语法错…

【医学影像】LIDC-IDRI数据集的无痛制作

LIDC-IDRI数据集制作 0.下载0.0 链接汇总0.1 步骤 1.合成CT图reference 0.下载 0.0 链接汇总 LIDC-IDRI官方网址&#xff1a;https://www.cancerimagingarchive.net/nbia-search/?CollectionCriteriaLIDC-IDRINBIA Data Retriever 下载链接&#xff1a;https://wiki.canceri…

基于springboot+vue的编程训练系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

斯元Z-ONE-China Cybersecurity Tech Landscape·中国网络安全全景图-百度网盘下载

面向全球&#xff0c;斯元Z-ONE正式发布首版「China Cybersecurity Tech Landscape中国网络安全全景图」。 为了提升海外市场对中国网络安全行业的全局认识&#xff0c;方便国际客户及合作伙伴了解中国网络安全科技的赛道分布和国内外厂商对标&#xff0c;助力中国网安厂商出海…

Qt中tableView控件的使用

tableView使用注意事项 tableView在使用时&#xff0c;从工具栏拖动到底层页面后&#xff0c;右键进行选择如下图所示&#xff1a; 此处需要注意的是&#xff0c;需要去修改属性&#xff0c;从UI上修改属性如下所示&#xff1a; 也可以通过代码修改属性&#xff1a; //将其设…

个人玩航拍,如何申请无人机空域?

我们在《年会不能停》一文中&#xff0c;有分享我们在西岭雪山用无人机拍摄的照片和视频&#xff0c;有兴趣可以去回顾。 春节的时候&#xff0c;趁着回老家一趟&#xff0c;又将无人机带了回去&#xff0c;计划拍一下老家的风景。 原本以为穷乡僻壤的地方可以随便飞&#xf…

【c语言】内存函数

欢迎关注个人主页&#xff1a;逸狼 创造不易&#xff0c;可以点点赞吗~ 如有错误&#xff0c;欢迎指出~ 目录 memcpy函数的使用和模拟实现 memcpy函数的使用 memcpy函数的模拟实现 memmove的使用和模拟实现 memmove的使用 memmove的模拟实现 memset函数的使用 memcmp函数…

【Docker】安装及相关的命令

目录 一 Docker简介 1.1 是什么 1.2 优缺点 1.3 应用场景 1.4 安装 二 命令 2.1 Docker基本命令 2.2 Docker镜像命令 2.3 Docker容器命令 一 Docker简介 1.1 是什么 Docker是一个开源的应用容器引擎&#xff0c;它基于Go语言实现&#xff0c;并利用操作系统本身已有的…

Kafka安全模式之身份认证

一、简介 Kafka作为一个分布式的发布-订阅消息系统&#xff0c;在日常项目中被频繁使用&#xff0c;通常情况下无论是生产者还是消费者只要订阅Topic后&#xff0c;即可进行消息的发送和接收。而kafka在0.9.0.0版本后添加了身份认证和权限控制两种安全服务&#xff0c;本文主要…

六、防御保护---防火墙内容安全篇

六、防御保护---防火墙内容安全篇 一、IAE&#xff08;Intelligent Awareness Engine&#xff09;引擎二、深度检测技术(DFI和DPI&#xff09;2.1 DPI -- 深度包检测技术2.1.1 基于“特征字”的检测技术2.1.2 基于应用网关的检测技术2.1.3 基于行为模式的检测技术 2.2 DFI -- 深…

CGI程序与ShellShock漏洞

CGI是什么&#xff1f; CGI&#xff08;通用网关接口&#xff0c;Common Gateway Interface&#xff09;程序是一种用于在Web服务器上执行动态内容的技术。与服务器上普通的后端代码相比&#xff0c;CGI程序有几个区别&#xff1a; 执行环境&#xff1a; CGI程序在服务器上作为…

k8s部署java微服务程序时,关于配置conusl acl token的方法总结

一、背景 java微服务程序使用consul作为服务注册中心&#xff0c;而consul集群本身的访问是需要acl token的&#xff0c;以增强服务调用的安全性。 本文试着总结下&#xff0c;有哪些方法可以配置consul acl token&#xff0c;便于你根据具体的情况选择。 个人认为&#xff…

BL0942 内置时钟免校准计量芯片 用于智能家居领域 低成本

BL0939是上海贝岭股份有限公司开发的一款用于智能家居领域进行电能测量的专用芯片&#xff0c;支持两路测量&#xff0c;可同时进行计量和漏电故障检测&#xff0c;漏电检测电流可设&#xff0c;响应时间快&#xff0c;具有体积小&#xff0c;外围电路简单&#xff0c;成本低廉…

C++ 前缀和

目录 1、DP34 【模板】前缀和 2、DP35 【模板】二维前缀和​编辑 3、724. 寻找数组的中心下标 4、238. 除自身以外数组的乘积 5、560. 和为 K 的子数组 6、974. 和可被 K 整除的子数组 7、525. 连续数组 8、1314. 矩阵区域和 1、DP34 【模板】前缀和 思路&#xff1a;…

Project_Euler-11 题解

Project_Euler-11 题解 题目 题目中给出的数据如下&#xff1a; 08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08 49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00 81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65 52 70 95 23 04 …

ESP32语音转文字齐护百度在线语音识别

一、导入(10分钟&#xff09; 学习目的 二、新授(70分钟) 1.预展示结果(5分钟) 2.本节课所用的软硬件(5分钟) 4.图形化块介绍(10分钟) 5.单个模块的简单使用(10分钟) 6.在线语音转换工具逻辑分析(10分钟) 7.在线语音转换工具分步实现(30分钟) 三、巩固练习(5分钟) 四、课堂小结…

考研数据结构算法机试训练1

中南大学上机压轴题 测试数据&#xff1a; 3 500 0.6 100 0.8 200 0.7 100 输出 390首先要对输入的折扣进行排序&#xff0c;优先使用比率低的z进行支付。 然后用lowcost记录目前多少钱是打过折的。T-lowcost就是剩余没打折的。 每次循环用上一个人的折扣额度。若所有人折扣额…

VR转接器:破解虚拟与现实边界的革命性设备

VR转接器&#xff0c;这一革命性的设备&#xff0c;为虚拟现实体验带来了前所未有的自由度。它巧妙地连接了虚拟与现实&#xff0c;使得用户在享受VR眼镜带来的奇幻世界的同时&#xff0c;也能自由地在现实世界中活动。这一设计的诞生&#xff0c;不仅解决了VR眼镜续航的瓶颈问…

react-组件基础

1.目标 能够使用函数创建组件 能够使用class创建组件 能够给React元素绑定事件 能够使用state和setState() 能够处理事件中的this指向问题 能够使用受控组件方式处理表单 2.目录 React组件介绍 React组件的两种创建方式 React事件处理 有状态组件和无状态组件 组件中的state…

Flink CDC 提取记录变更时间作为事件时间和 Hudi 表的 precombine.field 以及1970-01-01 取值问题

博主历时三年精心创作的《大数据平台架构与原型实现&#xff1a;数据中台建设实战》一书现已由知名IT图书品牌电子工业出版社博文视点出版发行&#xff0c;点击《重磅推荐&#xff1a;建大数据平台太难了&#xff01;给我发个工程原型吧&#xff01;》了解图书详情&#xff0c;…