include

     using namespace std;
#define Maxsize 5
typedef int DataType; typedef struct Queue {
DataType data[Maxsize];
int front; //循环 队列头指针
int rear; //循环 队列尾指针
}QueueList; void intit(QueueList *list) {
list->front=list->rear = 0;
}
// 队列是否已满
bool IsFull(QueueList *list) {
if (!list) return false;
if ((list->rear + 1) % Maxsize == list->front) {
return false;
}
return true;
}
// 队列是否为空
bool isEmpty(QueueList *list) {
if (list->rear == list->front) {
return true;
}
return false;
}
void showData(QueueList *list) {
int i = list->front;
while (i != list->rear)
{
cout << list->data[i] << "\t";
i = (i + 1) % Maxsize;
}
}
void EnterQueue(QueueList *list, DataType datas) {
if (!list) return;
if (!IsFull(list)) {
cout << "队列已满:" << datas << "不能插入此队列" << endl;
return;
}
list->data[list->rear] = datas; // 在队尾插入元素值
list->rear = (list->rear + 1) % Maxsize; // 队尾指针后移一位
}
bool DeleteQueue(QueueList *list, DataType *datas) {
if (!list || isEmpty(list)) {
cout << "此队列为空" << endl;
return false;
}
*datas = list->data[list->front];
list->front = (list->front + 1) % Maxsize;
return true;
}
void ClearQueues(QueueList *list) {
if (!list) return;
list->front = list->rear = 0;
}
// 获取队列元素 个数
int getLengths(QueueList *list) {
return (list->rear - list->front + Maxsize) % Maxsize;
}
int main() {
QueueList *list = new QueueList;
intit(list);
for (int i = 0; i < 7; i++)
{
EnterQueue(list, i);
}
cout << "---------------------入队的值-----------------:" << endl;
showData(list);
cout << "队列元素个数:" << getLengths(list) << endl;
int k = 0;
int *p = &k;
cout << "------------------------删除队列元素-----------------------" << endl;
for (int i = 0; i < 3;i++) {
DeleteQueue(list, p);
cout << "出列的值:" << endl;
cout<< *p <<'\t';
}
cout << "队列剩余的值" << endl;
showData(list);
cout << "队列元素个数:" << getLengths(list) << endl;
cout << "--------------删除后再添加元素--------------" << endl;
for (int i = 0; i < 3;i++) {
EnterQueue(list, i);
}
cout << "入队的值:" << endl;
showData(list);
cout << "队列元素个数:" << getLengths(list) << endl;
}

c++ 队列算法的更多相关文章

  1. 双有序队列算法——处理哈夫曼K叉树的高效算法

    算法介绍: 哈夫曼树的思路及实现众所周知,大部分是用堆来维护和实现,这种思路比较清晰,在K比较小的时候处理较快(具体例子接下来再说),而且编程复杂度不是很高,利于应用.但是,其所用的数据结构是树,是在 ...

  2. 『Python CoolBook:heapq』数据结构和算法_heapq堆队列算法&容器排序

    一.heapq堆队列算法模块 本模块实现了堆队列算法,也叫作优先级队列算法.堆队列是一棵二叉树,并且拥有这样特点,它的父节点的值小于等于任何它的子节点的值. 本模块实际上实现了一系列操作容器的方法,使 ...

  3. php队列算法[转]

    <?php/*** php队列算法* * Create On 2010-6-4* Author Been* QQ:281443751* Email:binbin1129@126.com**/cl ...

  4. 5.4 heapq--堆队列算法

    本模块实现了堆队列算法,也叫作优先级队列算法.堆队列是一棵二叉树.而且拥有这样特点,它的父节点的值小于等于不论什么它的子节点的值,假设採用数组array实现,能够把它们的关系表示为:heap[k] & ...

  5. 约瑟夫环-循环队列算法(曾微软,google笔试题)

    这也是我们聚会时常常做的游戏之一. 算法思路: 此处我使用循环链表模拟人围城一圈,每一个结点代表一个人.链表是一个有序链表,链表结点数据域是一个整型,代表人的序号.出局等同于链表删除元素,每次出局后重 ...

  6. FIFO队列算法的C程序实现

    头文件:Queue.h #ifndef _Queue_H #define _Queue_H typedef struct QueueDef_ //队列对象定义 { u16 front; //队列头部 ...

  7. ACM山东工商 栈和队列算法练习

    #include <stdio.h>#include <stdlib.h> #define SIZE   20 typedef struct hold{ char sign[S ...

  8. Michael-Scott非阻塞队列(lock-free)算法的C实现

    Michael-Scott非阻塞队列算法,即MS-queue算法,是1 9 9 6 年由Maged . M .Michael and M. L. Scott提出的,是最为经典的并发FIFO队列上的算法 ...

  9. PHP队列的实现 算法

    <?php /** * php队列算法 * * Create On 2010-6-4 * Author Been * QQ:281443751 * Email:binbin1129@126.co ...

随机推荐

  1. Libevent:7Bufferevents基本概念

    很多时候,应用程序除了能响应事件之外,还希望能够处理一定量的数据缓存.比如,当写数据的时候,一般会经历下列步骤: l  决定向一个链接中写入一些数据:将数据放入缓冲区中: l  等待该链接变得可写: ...

  2. hdu 2412 Party at Hali-Bula【树形dp】

    HDU 2412 和poj 2342(hdu 1520)差不多,多了一个判断最优解是(Yes)否(No)唯一.关键问题也在这个判断最优解是否唯一上. 先定义dp[u][2],表示选(dp[][1])或 ...

  3. AtCoder Regular Contest 082 D Derangement

    AtCoder Regular Contest 082 D Derangement 与下标相同与下个交换就好了.... Define a sequence of ’o’ and ’x’ of lengt ...

  4. Uva 10334

    UVa 10334 这道题几乎和UVa 495是一样的. #include<iostream> #include<cstdio> #define mod 1000000 usi ...

  5. H5页面IOS中键盘弹出导致点击错位的问题

    IOS在点击输入框弹出键盘  键盘回缩 后 定位没有相应改变  还有  textarea 也会弹出键盘 $("input").blur(function() { console.l ...

  6. Android GDI 图形渲染

      发布于2011-07-26   导读:对于Android开发者来说,成系列的技术文章对他们的技术成长帮助最大.如下是我们向您强烈推荐的主题为Android开发的第一个系列文章. <Andro ...

  7. 7-3三个模块 hashlib ,logging,configparser和序列化

    一 hashlib 主要用于字符串加密 1 import hashlib md5obj=hashlib.md5() # 实例化一个md5摘要算法的对象 md5obj.update('alex3714' ...

  8. 8-2udp和tcp网络编程以及粘包和解决粘包的方法

    一  tcp网络编程 server 端 import socket sk=socket.socket() #实例化一个对象 sk.setsockopt(socket.SOL_SOCKET,socket ...

  9. oracle函数 VSIZE(X)

    [功能]返回X的大小(字节)数 [参数]x select vsize(user),user from dual; 返回:6 asdied select length('adfad合理') " ...

  10. hdu 2473 Junk-Mail Filter (暴力并查集)

    Problem - 2473 为什么标题写的是暴力并查集?因为我的解法跟网上的有所不同,方法暴力很多. 先解释题意,这是一个模拟处理垃圾邮件的问题.垃圾邮件要根据它们的性质进行分类.对于10w个邮件, ...