假溢出的解决策略

2023-05-16

假溢出:在顺序队列中,队列出队时并没有像线性表那样使后面的元素往前移。

为了解决假溢出,常用的方法是把队列想成一个首尾相接的环,这种叫循环队列。在循环队列的入队和出队操作中,用到了求模运算(%),以确保front和rear的值保持在队列的有效范围内。

对于队列q,初始化为空队列使q->front==q->rear==0。

新元素入队时操作为:

q->data[q->rear]=x;
q->rear=(q->rear+1)%MAXSIZE;

出队操作为:

x=q->data[q->front];
q->front=(q->front+1)%MAXSIZE;

此时我们发现从一开始一直入队直到队列满时,此时q->front==q->rear==0;和判队列空的条件一摸一样,那怎么办??我们有以下三种方案

  • 闲置循环队列中一个元素空间。当 rear 的下一个位置是 front 时,则宣告列满。此时,循环队列为空的条件为 rear==front,而循环队列为满的条件为:(q->rear+1)%MAXSIZE==q->front。按照这种办法,循环队列出队、入队操作不变,只是入队时循环队列的判断条件修改为(q->rear+1)%MAXSIZE= q->front 即可。

  • 在循环队列上增加一个标志变量 flag,初始时q->flag=0。当因为入队操作q->front==q->rear时,置q->flag为1;当因为出队操作使q->front==q->rear 时,置 q->flag为0。因此,循环队列空的条件为q->flag==0&&q->front==q->rear,循环队列满的条件为 q->flag==1&&q->front==q->rear。

  • 在循环队列中增加一个计数器 count,初始时 count=0;成功出队时 q->count减1,成功入队时 count 加1。因此,循环队列空的条件为 q->count==0。循环队列满的条件为 q->count==MAXSIZE,或者 q->count>0&&q->rear==q->front。

flag法

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
typedef int DataType;
#define MAXSIZE 6
typedef struct
{
    DataType data[MAXSIZE];
    int front, rear;
    int flag;
}CSeqQueue;
void Init_Queue(CSeqQueue* q)
{
    q->front = 0;
    q->rear = 0;
    q->flag = 0;
}
int Out_Queue(CSeqQueue* q, DataType* x)
{
    if (q->flag == 0 && q->front == q->rear)
    {
        printf("队列为空!\n");
        return 0;
    }
    else
    {
        *x = q->data[q->front];
        q->front = (q->front + 1) % MAXSIZE;
        if (q->front == q->rear)
            q->flag = 0;
        return 1;
    }
}

int In_Queue(CSeqQueue* q, DataType x)
{
    if (q->flag == 1 && q->flag == q->rear)
    {
        printf("队列已满!");
        return 0;
    }
    else
    {
        q->data[q->rear] = x;
        q->rear = (q->rear + 1) % MAXSIZE;
        if (q->front == q->rear)
            q->flag = 1;
        return 1;
    }
}

int Length_Queue(CSeqQueue* q)
{
    //    return (q->rear-q->front+MAXSIZE)%MAXSIZE;
    return (q->rear - q->front + MAXSIZE) % MAXSIZE;
}
int main()
{
    CSeqQueue* q;
    int i;
    DataType x;
    q = (CSeqQueue*)malloc(sizeof(CSeqQueue));
    Init_Queue(q);
    printf("请插入%d个数字:", MAXSIZE);
    for (i = 1; i <= MAXSIZE; i++)
    {
        scanf("%d", &x);
        if (In_Queue(q, x) == 0)break;
    }
    printf("现在出队三个:");
    for (i = 1; i <= 3; i++)
    {
        if (Out_Queue(q, &x) == 0)break;
        printf("%5d", x);
    }
    printf("\n目前队列中有%d个元素:", Length_Queue(q));
    for (i = q->front; i != q->rear; i = (i + 1) % MAXSIZE)
    {
        printf("%5d", q->data[i]);
    }
    system("pause");
    return 0;
}

count法

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
typedef int DataType;
#define MAXSIZE 6
typedef struct
{
    DataType data[MAXSIZE];
    int front, rear;
    int count;//队列中元素个数
}CSeqQueue;
void Init_Queue(CSeqQueue* q)
{
    q->front = 0;
    q->rear = 0;
    q->count = 0;
}
int Out_Queue(CSeqQueue* q, DataType* x)
{
    if (q->count == 0)
    {
        printf(" 队列已为空,无元素可取\n");
        return 0;
    }
    else
    {
        *x = q->data[q->front];
        q->front = (q->front + 1) % MAXSIZE;
        q->count--;
        return 1;
    }
}

int In_Queue(CSeqQueue* q, DataType x)
{
    if (q->count == MAXSIZE)
    {
        printf("队已满,不能插入元素\n");
        return 0;
    }
    else
    {
        q->data[q->rear] = x;
        q->rear = (q->rear + 1) % MAXSIZE;
        q->count++;
        return 1;
    }
}

int Length_Queue(CSeqQueue* q)
{
    return q->count;
}
void main()
{
    CSeqQueue* q;
    int i;
    DataType x;
    q = (CSeqQueue*)malloc(sizeof(CSeqQueue));
    Init_Queue(q);
    printf("请插入6个数字:");
    for (i = 1; i <= 6; i++)
    {
        scanf("%d", &x);
        if (In_Queue(q, x) == 0)break;
    }
    printf("队列现在满了,你试着再插入一个\n");
    scanf("%d", &x);
    In_Queue(q, x);
    printf("将前3个数字出队:");
    for (i = 1; i <= 3; i++)
    {
        if (Out_Queue(q, &x) == 0)break;
        printf("%5d", x);
    }
    printf("\n目前队列中有%d个元素:", Length_Queue(q));
    for (i = q->front; i != q->rear; i = (i + 1) % MAXSIZE)
    {
        printf("%5d", q->data[i]);
    }
    printf("\n");
    system("pause");
}

少用一个空间

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
typedef int DataType;
#define MAXSIZE 6
typedef struct
{
    DataType data[MAXSIZE];
    int front, rear;
}CSeqQueue;
void Init_Queue(CSeqQueue* q)
{
    q->front = 0;
    q->rear = 0;
}
int Out_Queue(CSeqQueue* q, DataType* x)
{
    if (q->front == q->rear)
    {
        printf("队列为空!\n");
        return 0;
    }
    else
    {
        *x = q->data[q->front];
        q->front = (q->front + 1) % MAXSIZE;
        return 1;
    }
}

int In_Queue(CSeqQueue* q, DataType x)
{
    if ((q->rear + 1) % MAXSIZE == q->front)
    {
        printf("队列已满!");
        return 0;
    }
    else
    {
        q->data[q->rear] = x;
        q->rear = (q->rear + 1) % MAXSIZE;
        return 1;
    }
}

int Length_Queue(CSeqQueue* q)
{
    //    return (q->rear-q->front+MAXSIZE)%MAXSIZE;
    return (q->rear - q->front + MAXSIZE) % MAXSIZE;
}
int main()
{
    CSeqQueue* q;
    int i;
    DataType x;
    q = (CSeqQueue*)malloc(sizeof(CSeqQueue));
    Init_Queue(q);
    printf("请插入%d个数字:", MAXSIZE-1);
    for (i = 1; i < MAXSIZE; i++)
    {
        scanf("%d", &x);
        if (In_Queue(q, x) == 0)break;
    }
    printf("现在出队三个:");
    for (i = 1; i <= 3; i++)
    {
        if (Out_Queue(q, &x) == 0)break;
        printf("%5d", x);
    }
    printf("\n目前队列中有%d个元素:", Length_Queue(q));
    for (i = q->front; i != q->rear; i = (i + 1) % MAXSIZE)
    {
        printf("%5d", q->data[i]);
    }
    system("pause");
    return 0;
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

假溢出的解决策略 的相关文章

  • set容器(c++黑马程序员笔记)

    3 8 set multiset容器 3 8 1 set基本概念 简介 所有元素都会在插入时自动被排序 本质 set multiset属于关联式容器 xff0c 底层结构是用二叉树实现 set和multiset区别 set不允许容器中有重复
  • map函数

    3 9 map multimap容器 3 9 1 map基本概念 简介 map中所有元素都是pair pair中第一 个元素为key 键值 xff0c 起到索引作用 xff0c 第二个元素为value 实值 所有元素都会根据元素的键值自动排
  • 解决Maven配置本地仓库路径不生效问题多个方法详解。(已成功解决自己遇到的问题)

    首先我尝试了很多种方法 xff0c 就是这个方法让我成功 xff0c 和大家分享一下 xff01 xff08 我用方法二成功的 xff01 xff09 maven本地仓库默认值 xff1a 用户家目录 m2 repository 由于本地仓
  • Servlet快速学习和Tomcat快速部署(web)

    Servlet快速学习和Tomcat快速部署 xff08 web xff09 一 快速入门二 执行流程三 生命周期四 Servlet体系结构五 Servlet urlPattern配置六 XML配置方式编写Servlet七 Tomcat快速
  • 蓝桥杯必备模板(python)

    蓝桥杯必备算法模板 xff08 python xff09 xff1a 前缀和模板差分模板二分双指针位运算最大公约数和最小公倍数模板判断质数和埃氏筛法模板唯一分解定理和质因数分解关系和模板快速幂并查集区间合并回溯算法模板 xff1a DFS
  • 蓝桥杯必备模块及常用操作(python)

    蓝桥杯必会模块 xff08 python xff09 xff1a 字符类型模块日期函数模块 常用 优先级队列itertools模块collections模块Bisect模块List 集合set 集合Math模块 字符类型模块 先看点常用但比
  • string的几个常见库函数

    文章目录 前言一 strlen直接求字符串长度二 strcpy用来赋值三 strcat追加字符串四 strcmp用于比较两个字符串五 strstr子串查找六 strtok应用七 加长度限制八 strerror 九 其他操作1 iscntrl
  • vector详解

    在开始学习C 43 43 的STL之后 xff0c 相信大家都学会通过查文档来了解一些库函数 xff0c 今天我来给大家介绍vector xff0c 从基本的使用到vector背后的源码实现 xff0c 迭代器等展开讲 xff0c 仔细阅读
  • 如何利用开源思想开发一个SEO友好型网站

    当你对一个网站进行 SEO 优化的时候 xff0c 不要期望你的努力能立即得到回报 耐心等待并更正内容营销策略 xff0c 最终会发现你的网站很受用户欢迎 下面就教你如何利用开源思维开发一个SEO友好型网站 xff01 首先 xff0c 你
  • 【STM32】串口通讯USART串口中断配置

    目录 STM32 USART 简介 程序编写 硬件接线 实际波形 STM32 USART 简介 STM32的USART通用同步异步收发器是一个串行通信设备 xff0c 可以灵活的与外部设备进行全双工数据交换 有别于USART xff0c 还
  • openmv第三天之标记跟踪

    AprilTag是一个视觉基准系统 感觉就是一个可以定位 校准帮助openmv来找到 定位的东西 官方解释的用处 xff1a 简单来说 xff0c 只要把这个tag贴到目标上 xff0c 就可以在OpenMV上识别出这个标签的3D位置 xf
  • 【A_star三维路径规划】A_star算法无人机三维路径规划【含Matlab源码 1387期】

    一 A star算法简介 0 引言 随着现代技术的发展 飞行器种类不断变多 应用也日趋专一化 完善化 如专门用作植保的大疆PS X625无人机 用作街景拍摄与监控巡察的宝鸡行翼航空科技的X8无人机 以及用作水下救援的白鲨MIX水下无人机等
  • 【路径规划】A_star算法机器人动态避障路径规划【含Matlab源码 1033期】

    一 A star算法简介 1 A Star算法及其应用现状 进行搜索任务时提取的有助于简化搜索过程的信息被称为启发信息 启发信息经过文字提炼和公式化后转变为启发函数 启发函数可以表示自起始顶点至目标顶点间的估算距离 也可以表示自起始顶点至目
  • C语言打印输出字符串的几种方法

    思路分析 知识点补充 1 xff0c 在C语言中 xff0c 一维数组的数组名实际上就是指向数组首项元素的指针 2 xff0c 如果指针p已经指向一个字符串 xff0c 判断字符串是否结束 xff0c 一般采用while p 61 39 0
  • 对‘fmt::v9::detail::throw_format_error(char const*)’未定义的引用

    在学习视觉SLAM十四讲第十二章的过程中 xff0c 尝试跑了一下单目稠密地图构建的代码 xff0c 在编译源代码的过程中遇到该问题 xff0c 编译结果中显示长篇的 CMakeFiles dense mapping dir dense m
  • [STM32F103C8T6] 串口

    1 非中断串口发送数据 串口发送 接收函数 xff1a HAL UART Transmit 串口发送数据 xff0c 使用超时管理机制 HAL UART Receive 串口接收数据 xff0c 使用超时管理机制 HAL UART Tran
  • 【C语言】strcat函数_字符串追加/连接

    前言 xff1a 在C C 43 43 的学习过程当中一定一定要多刷题 xff0c 牛客网作为国内内容超级丰富的IT题库 xff0c 尤其是它的C C 43 43 xff0c 有从入门到大厂真题 xff0c 而且大部分的考试题目也是从中抽取
  • SWUST OJ448: 字符串查找

    题目描述 在一段句子中找出给定字符串出现在句子中第一个字母出现的位置 句子中字符个数小于4500 字符串字符个数小于120 输入 两行 第一行是给定字符串 第二行是句子 输出 整数 xff0c 字符串出现的位置 样例输入 abcde thi
  • C语言十进制转十六进制

    输入 xff1a 123 输出 xff1a 7B include lt stdio h gt int main int n scanf 34 d 34 amp n int a 100 int count int i 61 0 while 1
  • CentOS软件那么老为什么大家还要用它?

    作为一个专业的服务器系统 xff0c RHEL 系统理论上每一个软件包都有 RedHat 内部的人员负责维护 xff0c 这个维护包括长期 xff08 和系统生命周期一样长 xff09 的开发 更新 测试 运维等 也就是说你能从 RHEL

随机推荐

  • vscode配置C/C++调试环境

    转自作者知乎的原创文章 vscode配置C 43 43 调试环境 在环境变量path中添加mingw中bin后 在vscode界面侧边栏点击调试界面 xff0c 创建launch json文件 添加配置后保存就行 下为我的添加配置后自动生成
  • ROS通信机制~话题通信(Publisher&Subscriber)·笔记2

    系列文章目录 xff1a ROS开发 xff08 ubuntu xff09 笔记 1 嘻 嘻的博客 CSDN博客 ROS通信机制 服务通信 server amp client 笔记3 嘻 嘻的博客 CSDN博客 话题通信 理论模型 xff1
  • postman Windows的详细安装过程

    1 首先去postman官网下载postman 官网地址 xff1a Download Postman Get Started for Free https www postman com downloads 2 根据你浏览器下载的所在位置
  • 数据结构链表的结构体定义的理解(C语言)

    此理解有参考数据结构的教材和一些博主的文章 xff1b 1 先补充一下typedef在此处的基本用法 xff1a typedef可用来建立已经定义好的数据类型的别名 形式为 xff1a typedef 已有变量名 别名 通俗的来说就是给已有
  • ROS安装与Rviz的摄像头视频采集与标定

    文章目录 一 ROS的安装与配置1 添加 ROS 软件源 xff0c 将下列命令输入到 Ubuntu 的终端执行2 添加密钥 xff0c 将下列命令输入到 Ubuntu 的终端执行3 安装desktop full4 初始化rostep5 设
  • HTTP协议的基本格式

    目录 一 HTTP请求 1 1 首行 1 1 1 URL 1 1 2 方法 1 2 请求报头 xff08 header xff09 1 2 1 host 编辑 1 2 2 Content Length和Content Type 1 2 3
  • 思岚雷达win与ubuntu18.04连接并测试详细过程

    雷达简介 包含套件 雷达模组 xff08 内置pwm电机驱动 xff09 usb适配器 Micro USB线缆 电源线 接线方式 ps 雷达不需额外的电源供电 xff0c 直接使用电脑USB接口 xff0c 5V供电 驱动安装 USB 适配
  • c/c++常见字符串函数(strlen,strcmp,strcat,strcpy,strstr,strncpy,strncat,strncmp)的详解和自己编辑实现

    下面介绍c语言中指针与数组的面试题 再看下列题之前首先要知识储备 下面用c语言介绍常用字符串函数和进行编译 一 介绍strlen函数 unsigned int strlen char s 或size t strlen const char
  • 【C语言】学数据结构前必学的结构体struct详细

    佛祖说 xff0c 他可以满足程序猿一个愿望 程序猿许愿有生之年写出一个没有bug的程序 xff0c 然后他得到了永生 目录 1 结构体的声明与定义 1 1结构体是什么 xff1f 1 2为什么要有结构 xff1f 1 3结构体的声明 1
  • 数据结构哈希查找的C语言实现

    大家好 xff0c 我是练习编程时长两年半的昆工第一ikun xff0c 今天我们来分享查找算法中的一个 哈希查找 xff0c 哈希查找适用于有庞大的数据量时的查找 xff0c 是一种很好用的查找算法 xff0c 话不多说 xff0c 开团
  • 为什么很多程序员喜欢linux系统?

    a gt Linux哪些行业在运用 xff1f Linux系统运用极其广泛 xff0c 不少用户只知道windows xff0c 是因为 xff0c Linux的运用主要是在企业端 现在科技极其发达 xff0c 我们手机在手 xff0c 就
  • Linux Ubuntu下的标准IO相关库函数的介绍与使用

    大家好 xff0c 我是练习编程时长两年半的个人练习生昆工第一ikun xff0c 今天我们来分享一下标准IO相关函数库的介绍与使用 xff0c 话不多话 xff0c 开团 xff01 xff01 xff01 xff01 xff01 目录
  • Linux Ubuntu下的文件IO介绍及实例应用(C语言)

    大家好 xff0c 我是练习编程时长两年半的个人练习生昆工第一ikun xff0c 昨天咋们说了标准IO xff0c 今天咋们来分享文件IO xff0c 以及一个很有趣的实例 xff0c 给图片加密 xff0c 使其无法打开 话不多说 xf
  • 输入年月日得出该天是星期几(C语言)

    大家好 xff0c 我是练习编程时长两年半的个人练习生昆工第一ikun xff0c 昨天因为在写Thoughtworkers的2018年笔试题 xff0c 所以没有更新 xff0c 今天就先把笔试题中的一个函数分享出来 xff0c 该函数可
  • Linux下的UDP服务器客户端的搭建(C语言实现)

    大家好 xff0c 我是练习编程时长两年半的个人练习生昆工第一ikun xff0c 昨天我们说了搭建TCP的服务器和客户端 xff0c 今天我们就来分享一下UDP的服务器和客户端搭建 UDP的特点是无连接 xff0c 多个客户端可以发送消息
  • 使用STL库list类实现单双向约瑟夫环问题(C++)

    目录 一 单向约瑟夫环 1 问题描述 2 list类函数用法 xff08 1 xff09 list构造 xff08 2 xff09 list iterator迭代器 xff08 3 xff09 list容量 xff08 4 xff09 li
  • 使用Qt制作个人计算器

    我们知道windows系统有自带的计算器 xff0c 那么我们也可以用Qt制作一款类似的个人计算器 xff0c 实现整数的加减乘除括号运算 xff0c 界面设计使用Qt xff0c 计算使用逆波兰算法 xff0c 下面我就来分享一下个人计算
  • 使用Qt制作简易的图片查看器

    我们知道windows系统有自带的图片查看器 xff0c 那么我们也可以用Qt制作一款类似的图片查看器 xff0c 实现图片的打开查看以及图片的翻页 xff0c 下面我就来分享一下图片查看器的制作方法 目录 一 描述 二 代码实现 1 头文
  • 计算机网络第二章总结

    目录 1 1物理层的基本概念 1 2数据通信的基础知识 1 2 1数据通信系统的模型 1 2 2信道的几个基本概念 常用的编码方式 1 2 3信道的极限容量 1 3物理层下面的传输媒体 1 3 1导引型传输媒体 1 双绞线 2 同轴电缆 3
  • 假溢出的解决策略

    假溢出 xff1a 在顺序队列中 xff0c 队列出队时并没有像线性表那样使后面的元素往前移 为了解决假溢出 xff0c 常用的方法是把队列想成一个首尾相接的环 xff0c 这种叫循环队列 在循环队列的入队和出队操作中 xff0c 用到了求