数据结构02 队列及其应用【C++实现】

目录

队列及其特点

利用数组模拟队列的基本操作

创建队列

空队条件

元素入队

 元素出队

 模拟超市收银问题

队列操作

初始化

入队操作

出队操作

取出队首元素

STL模板中队列的基本使用

训练:约瑟夫问题

参考程序


队列及其特点

队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,前端一般叫做队头,后端叫队尾。队列就像学校做操站队一样,来的人一个一个往后站,走的时候从前往后一个一个走。

总结队列的特点为:先入先出,即先入队的元素先出队。

利用数组模拟队列的基本操作

对于队列的使用,我们可以直接利用数组来模拟队列的基本操作,具体实现如下:

创建队列

int que[105];     //定义一个能存放105个数字的数组来模拟队列
int front=0,rear=0;    //front与rear分别表示队头和队尾元素的位置。

空队条件

front==rear;

元素入队

que[rear++]=x;    //元素x入队

 元素出队

x=que[front++];  //队首元素出队,并将元素值赋值给x

 模拟超市收银问题

假设有一批顾客来到超市,在结账时,必须排队付款。先到达收银台的顾客先结账。

我们模拟收银过程,使用队列来实现,一般队列会提供以下几个功能:

push(x):将x压入队列,即顾客来排队,应该站在队尾。
pop():弹出队首元素,即排在最前面的人结完账后,离开队列。
front():查询队首元素,即知道目前是谁结账。

队列操作

初始化

const int MAXN=1100;
int que[MAXN];
int head = 0;
int tail = 0;

入队操作

void push(int x){
    if(tail>=MAXN) printf("队列溢出");
    else{
        que[tail] = x;
        tail++;
    }
}

出队操作

void pop(){
    if(head==tail)  printf("队列为空");
    else head++;
}

取出队首元素

int front(){
    if(head==tail) printf("队列为空");
    else return que[head];
}

STL模板中队列的基本使用

对于队列的使用,我们也可以直接利用STL模板来实现,STL模板库中队列的基本操作如下:

头文件:#include<queue>

创建一个存放int类型数据的空队列s:queue<int> s;

s.empty():  判断队列是否为空,为空返回true,否则返回false;

s.size():  返回队列中元素的个数;

s.front():  获取队首元素的值;

s.back():  获取队尾元素的值;

s.push(k):   向队尾插入新的元素k;

s.pop():    删除队列s的队首元素。

训练:约瑟夫问题

n个人(n<=100)围成一圈,从第一个人开始报数,数到m的人出列,再由下一个人重新从1开始报数,数到m的人再出圈,……依次类推,直到所有的人都出圈,请输出依次出圈人的编号。

【输入描述】n和m

【输出描述】出列的顺序

【输入样例】4 17

【输出样例】1 3 4 2

参考程序

#include<iostream>
#include<queue>
using namespace std;
queue<int> que;
int m,n;
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++) que.push(i); //编号入队  
    int k=1;
    while(!que.empty()){
        if(k==m){ //数到了m
            cout<<que.front()<<" "; //输出
            que.pop(); //出队
            k=1;  //再次初始化k
        }
        else{
            que.push(que.front());//队首放到队尾            
            que.pop(); //出队
            k++;
        }
    }
    return 0;
}

从C++入门到算法,再到数据结构,查看全部文章请点击此处icon-default.png?t=N7T8http://www.bigbigli.com/ 

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 《数据结构算法与应用C语言描述PDF》是一本关于数据结构和算法在C语言中的实现应用的电子书。这本书主要介绍了各种数据结构和算法在C语言中的实现方式以及它们在实际应用中的使用。 首先,这本书详细介绍了常见的数据结构,如数组、链表、栈、队列、树和图等。对于每种数据结构,书中提供了相应的C语言实现代码,帮助读者理解数据结构的基本原理和操作。同时,书中还介绍了每种数据结构的优缺点以及适用的场景,使读者能够更好地选择合适的数据结构来解决实际问题。 其次,这本书还介绍了常用的算法,如排序、查找、图算法等。为了方便读者理解和学习,每个算法都给出了C语言实现代码,并对算法的原理和复杂度进行了详细解释。此外,书中还介绍了一些基本的算法设计思想,如贪心算法、分治算法和动态规划等,帮助读者更好地理解和应用算法。 最后,这本书还通过一些实际应用案例展示了数据结构和算法在实际开发中的应用。这些案例包括文本编辑器、文件系统和数据库等,通过应用这些案例可以帮助读者更好地理解和应用数据结构和算法。 总之,《数据结构算法与应用C语言描述PDF》是一本很好的学习资源,它通过给出C语言的实现代码和实际应用案例,帮助读者学习和理解数据结构和算法的核心概念和应用方法,对于提高编程能力和解决实际问题有很大帮助。 ### 回答2: 《数据结构算法与应用C语言描述PDF》是一本介绍数据结构与算法在C语言中应用的书籍。这本书主要内容包括数据结构的基本概念、算法的设计与分析以及在C语言中的具体实现。 首先,书中详细介绍了数据结构的基本概念,包括线性表、栈、队列、链表、树、图等常见的数据结构。对于每种数据结构,书中给出了其定义、特征以及常用操作的实现方法,并且通过示例代码加以说明,使读者能够更好地理解和掌握这些数据结构的特点和使用方法。 其次,书中介绍了算法的基本概念和常用的算法设计方法,如分治法、贪心法、动态规划等。对于每种算法设计方法,书中给出了其基本思想、步骤和实现过程,并通过一些经典算法问题的解决实例,将理论知识与实际问题结合起来,帮助读者更好地理解和运用这些算法。 此外,书中还涉及了一些常用的排序算法、查找算法以及图算法等内容。对于排序算法,书中给出了冒泡排序、插入排序、选择排序、快速排序等常见的算法及其实现代码;对于查找算法,书中介绍了顺序查找、二分查找等常用的算法及其实现方法;对于图算法,书中介绍了深度优先搜索、广度优先搜索以及最短路径算法等重要的图算法,并给出了相应的代码实现。 总之,《数据结构算法与应用C语言描述PDF》一书全面介绍了数据结构与算法在C语言中的应用,通过具体的实例和代码实现,帮助读者深入理解和掌握这些知识,并能够将其应用于实际问题的解决中。这本书对于计算机科学与技术专业的学生以及从事相关工作的人员都是一本很好的参考书籍。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bigbigli_大李

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值