数据结构之队列建议收藏

一C++标准库queue(1)成员函数(2)示例二C++实现队列

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

队列(Queue),是一种线性存储结构。它有以下几个特点:
(01) 队列中数据是按照”先进先出(FIFO, First-In-First-Out)”方式进出队列的。
(02) 队列只允许在”队首”进行删除操作,而在”队尾”进行插入操作。

一 C++标准库queue

(1)成员函数

成员函数 说明 时间复杂度
size() 返回队列大小 O(1)
push() 在末尾加入一个元素 O(1)
pop() 删除第一个元素 O(1)
front() 返回第一个元素 O(1)
end() 返回最后一个元素 O(1)
empty 队列为空返回真 O(1)

(2)示例

#include <iostream>
#include <queue>
using namespace std;

/**
 * C++ : STL中的队列(queue)的演示程序。
 *
 * @author skywang
 * @date 2013/11/07
 */
int main ()
{
    int tmp=0;
    queue<int> iqueue;

    // 将10, 20, 30 依次加入队列的末尾
    iqueue.push(10);
    iqueue.push(20);
    iqueue.push(30);

    // 删除队列开头的元素
    iqueue.pop();

    // 将“队列开头的元素”赋值给tmp,不删除该元素.
    tmp = iqueue.front();
    cout<<"tmp="<<tmp<<endl;

    // 将40加入到队列的末尾
    iqueue.push(40);

    cout << "empty()=" << iqueue.empty() <<endl;
    cout << "size()=" << iqueue.size() <<endl;
    while (!iqueue.empty()) 
    {
        tmp = iqueue.front();
        cout<<tmp<<endl;
        iqueue.pop();  
    }

    return 0;
}

二 C++实现队列

#ifndef ARRAY_QUEUE_HXX
#define ARRAY_QUEUE_HXX

#include <iostream>
using namespace std;

template<class T> class ArrayQueue{
    public:
        ArrayQueue();
        ~ArrayQueue();

        void add(T t);
        T front();
        T pop();
        int size();
        int is_empty();

    private:
        T *arr;
        int count;
};

// 创建“队列”,默认大小是12
template<class T>
ArrayQueue<T>::ArrayQueue() 
{
    arr = new T[12];
    if (!arr) 
    {
        cout<<"arr malloc error!"<<endl;
    }
}

// 销毁“队列”
template<class T>
ArrayQueue<T>::~ArrayQueue() 
{
    if (arr) 
    {
        delete[] arr;
        arr = NULL;
    }
}

// 将val添加到队列的末尾
template<class T>
void ArrayQueue<T>::add(T t) 
{
    arr[count++] = t;
}


// 返回“队列开头元素”
template<class T>
T ArrayQueue<T>::front() 
{
    return arr[0];
}

// 返回并删除“队列末尾的元素”
template<class T>
T ArrayQueue<T>::pop() 
{
    int i = 0;;
    T ret = arr[0];

    count--;
    while (i++<count)
        arr[i-1] = arr[i];

    return ret;
}

// 返回“队列”的大小
template<class T>
int ArrayQueue<T>::size() 
{
    return count;
}

// 返回“队列”是否为空
template<class T>
int ArrayQueue<T>::is_empty()
{
    return count==0;
}

#endif
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/120155.html原文链接:https://javaforall.net

(0)
上一篇 2021年12月19日 下午4:00
下一篇 2021年12月19日 下午5:00


相关推荐

  • 中兴通讯积极面向下一代推广OPNFV项目

    中兴通讯积极面向下一代推广OPNFV项目

    2022年3月4日
    41
  • pytest的使用_调用方法的具体调用格式为

    pytest的使用_调用方法的具体调用格式为Pytest执行用例规则Pytest在命令行中支持多种方式来运行和选择测试用例1.对某个目录下所有的用例pytest2.对模块中进行测试pytesttest_mod.py3.对文件夹进行

    2022年7月28日
    8
  • VB中动态创建控件

    VB中动态创建控件创建数据驱动窗体所谓数据驱动窗体就是根据所请求的数据的不同生成相应的窗体 举例来讲 假设你现在有一个数据库 其中有些字段必须根据登录者的身份加以显示 授权级别高的用户可以浏览并修改这些字段的内容 授权级别一般的用户只能浏览这些字段中的数据 授权级别低的用户则不能浏览这些字段中的内容 要做到这一点就得利用 VB 动态添加控件的功能 动态创建控件无论你想要创建何种类型的数据驱动窗体 你必须知道如何在运行时

    2026年3月18日
    3
  • List KeyValuePair

    List KeyValuePairList<KeyValuePair<string,string>>list=newList<KeyValuePair<string,string>>();list.Add(newKeyValuePair<string,string>(“asdf1″,”1”));list.Add(newKeyValuePair&l…

    2022年7月13日
    28
  • 【数据结构】什么是哈希表?为什么哈希表的查询时间复杂度是O(1)?

    【数据结构】什么是哈希表?为什么哈希表的查询时间复杂度是O(1)?力扣刷题的第一题 两数之和的最佳解决方法就是哈希表 本篇就是来讲解数据结构 哈希表的 来帮助大家认识哈希表 助力解题

    2026年3月17日
    2
  • 基于openstack构建私有云实践

    基于openstack构建私有云实践主要分享的是云计算 openstack 的使用 私有云平台建设 云服务器云硬盘的构建和使用 从基本概念入手到私有云建设 信息量非常大 对于 openstack 的安装部署都是从官方文档中一步步的介绍 内容非常详细 云计算 cloudcomputi 是基于互联网的相关服务的增加 使用和交付模式 通常涉及通过互联网来提供动态易扩展且经常是虚拟化的资源

    2026年3月26日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号