• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C++循环队列实现模型

C++循环队列实现模型

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c++优先队列,c++队列,c++队列类,c++队列函数,c++队列的实现等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了C++循环队列实现模型。分享给大家供大家参考。具体分析如下:

前段时间在知乎上看到这样一个小题目:

用基本类型实现一队列,队列要求size是预先定义好的的。而且要求不可以使用语言自带的api,如C++的STL。普通的实现很简单,但是现在要求要尽可能的时间和空间复杂度的优化,要和语言自带的api比较时间和空间。这个队列还要支持如下的操作:

constructor: 初始化队列

enqueue:入队

dequeue:出队

队列是一种基本的数据结构,在平常的应用中十分广泛,多数情况队列都是用链表实现的。但是对于本题而言,用链表实现就有这样一个问题:由于每个结点都存在至少一个指向前一个结点或后一个结点的指针,这就带来了空间复杂度的加大,所以并不太适合要求。

这个时候我想到了boost中的boost::circular_buffer,它是通过类似于数组的底层结构实现的一个循环buffer。而数组的优点是空间复杂度够小(除去维持数据结构的索引项,空间复杂度为线性),再实现成循环结构可以最大化的利用空间。而且在队列这样一种只在前后端插入删除的情况下,其push和pop的时间复杂度也只有O(1)。

基本实现如下:

#ifndef __CIRCULAR_QUEUE_H__
#define __CIRCULAR_QUEUE_H__

#include <stddef.h>

template<typename T>
class circular_queue
{
public:
    explicit circular_queue(size_t maxsize)
        : maxsize_(maxsize + 1), head_(0), rear_(0)
    {
        array_ = new T[maxsize_];
    }

    circular_queue(size_t maxsize, const T& val)
        : maxsize_(maxsize + 1), head_(0), rear_(0)
    {
        array_ = new T[maxsize_];
        for (size_t i = 0; i != maxsize; ++i)
        {
            array_[i] = val;
        }
        rear_ = maxsize;
    }

    circular_queue(const circular_queue& rhs)
        : maxsize_(rhs.maxsize_), head_(rhs.head_), rear_(rhs.rear_)
    {
        array_ = new T[maxsize_];
        for (int i = 0; i != maxsize_; ++i)
        {
            array_[i] = rhs.array_[i];
        }
    }

    ~circular_queue()
    {
        delete [] array_;
    }

    circular_queue& operator=(const circular_queue& rhs)
    {
        if (this == &rhs)
        {
            return *this;
        }
        delete [] array_;
        maxsize_ = rhs.maxsize_;
        head_ = rhs.head_;
        rear_ = rhs.rear_;
        array_ = new T[maxsize_];
        for (int i = 0; i != maxsize_; ++i)
        {
            array_[i] = rhs.array_[i];
        }
        return *this;
    }

    bool empty() const
    {
        return head_ == rear_;
    }

    size_t size() const
    {
        return (rear_ - head_ + maxsize_) % maxsize_;
    }

    T& front()
    {
        return array_[head_];
    }

    const T& front() const
    {
        return array_[head_];
    }

    void push(const T& val)
    {
        if ((rear_ + 1) % maxsize_ != head_)
        {
            array_[rear_] = val;
            rear_ = (rear_ + 1) % maxsize_;
        }
    }

    void pop()
    {
        if (head_ != rear_)
        {
            head_ = (head_ + 1) % maxsize_;
        }
    }

private:
    size_t  maxsize_;
    int     head_;
    int     rear_;
    T*      array_;
};

#endif
</div>

队列长度 = 数组长度 - 1

预留了一个单位的数组元素空间作为队尾标记。

这个只是简陋的实现,没有考虑到一些情况,比如线程安全、STL算法,函数对象的兼容等。代码只是简单的测试了一下,如有错误欢迎指正:)

总的来说,这种思路的循环队列有以下优点:

1、使用固定的内存,不需要隐式或意外的内存分配。

2、从前端或后端进行快速的常量时间的插入和删除元素。

3、快速的常量时间的对元素进行随机访问。(如果需要的话可以定义operator[])

4、适用于实时和对性能有严格要求的应用程序。

还可以进一步扩展,当队列满的时候,从一端插入则覆盖冲洗掉另一端的数据,这样的一个模型可以应用于这些场合:

保存最近接收到的取样数据,在新的取样数据到达时覆盖最旧的数据。
一种用于保存特定数量的最后插入元素的快速缓冲。
高效的固定容量FIFO(先进先出)或LIFO(后进先出)队列,当队列满时删除最旧的(即最早插入的)元素。

希望本文所述对大家的C++程序算法设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C++数据结构之实现循环顺序队列
  • C++ 简单的任务队列详解
  • C++中实现队列类链式存储与栈类链式存储的代码示例
  • C++循环队列实现模型
  • C++中队列的建立与操作详细解析
  • C++中用两个标准容器stack,实现一个队列的方法详解
  • 用C++实现队列的程序代码
  • 解析C++无锁队列的实现代码

相关文章

  • 2017-05-28bloom filter概念讲解以及代码分析
  • 2017-05-28C++、C语言和JAVA开发的区别
  • 2017-05-28简单实现C++复数计算器
  • 2017-05-28基于C++自动化编译工具的使用详解
  • 2017-05-28常用的STL查找算法
  • 2017-05-28C++入门概览和尝试创建第一个C++程序
  • 2017-05-28黑客帝国数字雨效果VC6源代码分享
  • 2017-05-28详解C++编程中向函数传递引用参数的用法
  • 2017-05-28VC++开发中完美解决头文件相互包含问题的方法解析
  • 2017-05-28C语言控制台版2048小游戏

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • HDOJ 1443 约瑟夫环的最新应用分析详解
    • 基于C++ list中erase与remove函数的使用详解
    • 使用C语言实现vector动态数组的实例分享
    • C++11右值引用和std::move语句实例解析(推荐)
    • linux安装mysql和使用c语言操作数据库的方法 c语言连接mysql
    • C语言中进制知识汇总
    • c语言文件读写示例(c语言文件操作)
    • 解析static在C和C++中的用法以及区别
    • 关于《C和指针》的学习笔记
    • C++中的类型转换static_cast、dynamic_cast、const_cast和reinterpret_cast总结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有