用顺序队列的方式实现输入123456,输出12345操作

文章目录

  • 用顺序队列的方式实现输入123456,输出12345操作
    • 1.队列的定义
    • 2.队列的初始化
    • 3.判空操作
    • 4.入队操作
    • 5. 出队操作
    • 6.获得对头元素的值
    • 7.源代码
    • 8.运行结构展示
    • 9.关注一起互相学习!

1.队列的定义

typedef struct {ElemType data[MaxSize];int front, rear;
}SqQueue;

2.队列的初始化

void InitQueue(SqQueue& Q) {Q.rear = Q.front = 0;
}

3.判空操作

bool QueueEmpty(SqQueue Q) {if (Q.rear == Q.front)return true;elsereturn false;
}

4.入队操作

bool EnQueue(SqQueue& Q, ElemType x) {if (Q.front == (Q.rear + 1) % MaxSize)return false;Q.data[Q.rear] = x;Q.rear = (Q.rear + 1) % MaxSize;//向后移动一格return true;
}

5. 出队操作

bool DeQueue(SqQueue& Q, ElemType& x) {if (Q.rear == Q.front)return false;x = Q.data[Q.front];Q.front = (Q.front + 1) % MaxSize;return true;
}

6.获得对头元素的值

bool GetHead(SqQueue Q, ElemType& x) {if (Q.rear == Q.front)return false;x = Q.data[Q.front];return true;
}

7.源代码

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#define MaxSize 6
typedef int ElemType;
//队列的定义
typedef struct {ElemType data[MaxSize];int front, rear;
}SqQueue;//队列的初始化
void InitQueue(SqQueue& Q) {Q.rear = Q.front = 0;
}
//判空操作
bool QueueEmpty(SqQueue Q) {if (Q.rear == Q.front)return true;elsereturn false;
}
//入队操作
bool EnQueue(SqQueue& Q, ElemType x) {if (Q.front == (Q.rear + 1) % MaxSize)return false;Q.data[Q.rear] = x;Q.rear = (Q.rear + 1) % MaxSize;//向后移动一格return true;
}
//出队操作
bool DeQueue(SqQueue& Q, ElemType& x) {if (Q.rear == Q.front)return false;x = Q.data[Q.front];Q.front = (Q.front + 1) % MaxSize;return true;
}
//获得对头元素的值
bool GetHead(SqQueue Q, ElemType& x) {if (Q.rear == Q.front)return false;x = Q.data[Q.front];return true;
}
int main() {SqQueue Q;ElemType x;int i = 0;bool ret;printf("1.初始化队列\n");InitQueue(Q);printf("2.栈为:%s\n", (QueueEmpty) ? "空" : "非空");printf("3.请依次入队:\n");while (true) {scanf("%d", &x);ret=EnQueue(Q, x);if (ret) {printf("\t元素%d入栈成功!\n",x);}else {printf("\t元素%d入栈失败!\n",x);break;}}printf("4.依次出队操作:");while (true) {ret = DeQueue(Q, x);if (ret) {printf("\t出队成功,元素的值为:%d\n", x);}else {printf("\t出队失败!\n");break;}}return 0;
}

8.运行结构展示

输入:123456
输出:12345

9.关注一起互相学习!

文章目录

  • 用顺序队列的方式实现输入123456,输出12345操作
    • 1.队列的定义
    • 2.队列的初始化
    • 3.判空操作
    • 4.入队操作
    • 5. 出队操作
    • 6.获得对头元素的值
    • 7.源代码
    • 8.运行结构展示
    • 9.关注一起互相学习!

(c语言数据结构)用顺序队列的方式实现输入12345,输出12345操作——期末数据结构程序设计相关推荐

  1. (c语言)用链栈表的方式实现输入abcde,输出edcba操作——期末数据结构程序设计

    用链栈表的方式实现输入abcde,输出edcba操作,期末数据结构程序设计 文章目录 用链栈表的方式实现输入abcde,输出edcba操作,期末数据结构程序设计 1.链栈的定义 2.链栈的初始化 3. ...

  2. (c语言数据结构)用链式队列的方式实现输入12345,输出12345操作——期末数据结构程序设计

    用链式队列的方式实现输入12345,输出12345操作 文章目录 用链式队列的方式实现输入12345,输出12345操作 1.队列的定义 2.队列的初始化 3.判空操作 4.入队操作 5.出队操作 6 ...

  3. 【数据结构】顺序队列的实现(C语言)

    队列的基本概念及其描述 队列是一种特殊的线性表,它的特殊性在于队列的插入和删除操作分别在表的两端进行. 插入的那一端称为队尾,删除的那一端称为队首.队列的插入操作和删除操作分别称为进队和出队. 先进先 ...

  4. 数据结构之顺序队列的优化

    顺序队列的优化 我们既然想优化顺序队列,首先得知道目前顺序队列的瓶颈在哪里,那样才能对症下药. 顺序队列的瓶颈: 1.线性表的第一个元素作为队头,线性表的最后一个元素作为队尾: 2.入队的新元素是在线 ...

  5. 数据结构之顺序队列和链式队列常用的一些操作

    顺序队列是队列的顺序存储结构,顺序队列实际上是运算受限的顺序表.和顺序表一样,顺序队列用一个向量空间来存放当前队列中的元素.由于队列的队头和队尾的位置是变化的,设置两个指针front和rear分别指示 ...

  6. 浅谈数据结构之顺序队列(五)

    队列:是指只允许在一端进行插入操作,而在另一端进行删除操作的线性表.队列是一种先进先出的线性表,这与栈的后进先出正好相反:其中允许插入的一端我们称为队尾,允许删除的一端我们称为队头(或队首).假设队列 ...

  7. printf输出字符串_C语言入门必学第一课,学习“输入与输出”!

    数据输入 编写程序的主要目的就是为了处理数据.数据从哪里来?数据的来源有很多种方式,如从磁盘文件中读取数据.从数据库中读取数据.从网页中抓取数据等,还有一种原始的方式就是从键盘输入数据. 在C语言中, ...

  8. C语言注释风格(函数、功能、输入、输出、返回)

    C语言编程规范-注释 规则: 1:一般情况下,源程序有效注释量必须在20%以上.     说明:注释的原则是有助于对程序的阅读理解,在该加的地方都加了,注释不宜太多也不能太少,注释语言必须准确.易懂. ...

  9. C语言新手记:应用指针进行数组输入与输出

    偶然翻到一篇以前写下的想法,对数组输入时用指针进行定位而不是用数组元素下标,遂尝试着进行验证想法. 第一种是指针自增运算p++ #include<stdio.h> int main() { ...

最新文章

  1. seaborn将图例放置在图像外部并使用move_legend函数将图例(legend)放置在图像的顶部、且单行展开显示
  2. 《深入浅出Ext JS》(第2版)即将上市
  3. 因果推理、正则化上榜:权威专家盘点过去50年最重要的统计学思想
  4. [Python人工智能] 一.TensorFlow环境搭建及神经网络入门
  5. data source from bit.ly
  6. camel apache_Apache Camel 3的工作终于开始了
  7. xadmin的html文件,django xadmin(2) 在xadmin基础上完成自定义页面
  8. Laravel Migrate
  9. 转: 借助GitHub托管你的项目代码
  10. python实现生日祝福短信_Python实现好友生日提醒
  11. 【BZOJ】3495: PA2010 Riddle
  12. pdflib textflow
  13. 桌面程序 取色器 colors.exe
  14. 快递100 快递公司编码-标准国际
  15. 将mysql数据库批量导出为word三线表格形式
  16. react 翻书效果_React实现翻页功能
  17. UCHOMe重要函数
  18. 论起凡尔赛文学,还是比不过数据分析师!
  19. 软硬件测试策略及方法
  20. SAP 预收款和收款清账

热门文章

  1. 球虫机器人_球虫机器人
  2. matlab 学生,MATLAB学生套件-购买记
  3. Android超级终端之Termux(2)
  4. Matlab入门----脚本编程
  5. 网络实验(OPenLab)
  6. 《时空幻境》的时间倒放玩法!用 Cocos Creator 实现时间回溯
  7. 台式机内存服务器内存性能,如何区别服务器内存与台式机内存?
  8. 某雅思培训网站被挂 server.exe / Dropper.Win32.BlackHole.a / Backdoor.Win32.Hupigon.jmq
  9. 利用msf实现windows的上线与提权
  10. 网站服务器上生成csr,Zeus Web服务器生成CSR文件的方法