博客
关于我
数组模拟队列
阅读量:131 次
发布时间:2019-02-26

本文共 1231 字,大约阅读时间需要 4 分钟。

文章目录


前言

复习acwing算法基础课的内容,本篇为讲解基础算法:用数组模拟队列,关于时间复杂度:目前博主不太会计算,先鸽了,日后一定补上


一、关于队列

在C++中,STL已经帮助我们实现队列,详细见这篇博客:(先鸽了),本篇博客中,讲解如何用数组去模拟栈,实现队列的一些功能.

二、队列的操作

1.数组模拟队列必备属性

int q[N];       		//数组q中存储的就是队列中的元素int hh;                 //hh表示的是对头,初始值为0int tt = -1;            //tt表示的是队尾,初始值为-1,tt初始小于hh,证明队列里无元素

2.向队尾插入一个元素x

q[ ++ tt] = x;          //因为向队尾插入了一个元素,所以对头hh不变,对尾tt向后移动一位,并把x赋值到q数组中

3.从对头弹出一个数

hh ++;                  //直接把hh向后移动一位即可

4.查询对头元素

printf("%d", q[hh]);    //q[hh] 代表的就是对头元素

5.判断队列是否为空

if (tt < hh) printf("队列为空");else printf("队列不空");

三、例题, 代码

1.AcWing 828. 模拟栈

本题链接:

本博客给出本题截图:

在这里插入图片描述

在这里插入图片描述

2.AC代码

#include 
#include
#include
using namespace std;const int N = 100010;int q[N], tt = -1, hh;int main(){ int n; scanf("%d", &n); while (n -- ) { string op; cin >> op; if (op == "push") { int x; scanf("%d", &x); q[ ++ tt ] = x; } else if (op == "pop") hh ++; else if (op == "empty") { if (tt < hh) printf("YES\n"); else printf("NO\n"); } else printf("%d\n", q[hh]); } return 0;}

四、时间复杂度

关于数组模拟栈的各操作时间复杂度以及证明,后续会给出详细的说明以及证明过程,目前先鸽了。

转载地址:http://awpk.baihongyu.com/

你可能感兴趣的文章
Nginx负载均衡(upstream)
查看>>
nginx转发端口时与导致websocket不生效
查看>>
Nginx运维与实战(二)-Https配置
查看>>
Nginx部署_mysql代理_redis代理_phoenix代理_xxljob代理_websocket代理_Nacos代理_内网穿透代理_多系统转发---记录021_大数据工作笔记0181
查看>>
Nginx配置HTTPS服务
查看>>
Nginx配置Https证书
查看>>
Nginx配置http跳转https
查看>>
Nginx配置ssl实现https
查看>>
Nginx配置TCP代理指南
查看>>
NGINX配置TCP连接双向SSL
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
查看>>
nginx配置中的服务器名称
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
nginx配置全解
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置后台网关映射路径
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>
Nginx配置多个不同端口服务共用80端口
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>