C++ STL-deque双向队列

C++ STL-deque双向队列


deque双向队列是一种双向开口的连续线性空间,可以高效的在头尾两端插入和删除元素,deque在接口上和vector非常相似,下面列出deque的常用成员函数:
这里写图片描述


代码

注释写了

//双向队列
#include<deque>
#include<cstdio>
#include<algorithm>
const int MAX_N = 20;
using namespace std;
int main(){

    deque<int> ideq(MAX_N);
    deque<int>::iterator pos;
    int i;
    // 进行赋值
    for (i = 0; i < MAX_N; i++) {
        ideq[i] = i;
    } 
    // 输出deque
    for (i = 0; i < MAX_N; i++) {
        printf("%d ", ideq[i]);
    } 

    // 在头部和尾部加入数据
    puts("");
    puts("在头部和尾部加入数据");
    ideq.push_back(100);  // 尾部 
    ideq.push_front(101); //头部 

    // 输出deque的数据

    for (pos = ideq.begin(); pos != ideq.end(); pos++) {
        printf("%d ", *pos);
    } 
    puts("");

    //查找
    const int FIND_NUMBER = 12;
    printf("查找数据%d\n", FIND_NUMBER); 


    pos = find(ideq.begin(), ideq.end(), FIND_NUMBER);

    if (pos != ideq.end()) {
        printf("成功找到! %d\n", *pos);
    } else {
        printf("失败!\n");
    }

    // 在头部和尾部删除数据
    puts("在头部和尾部删除数据");
    ideq.pop_back();
    ideq.pop_front();

    // 再次输出数据
    puts("再次输出数据!");

    for (pos = ideq.begin(); pos != ideq.end(); pos++) {
        printf("%d ", *pos);
    }

    return 0;
}

运行输出:
这里写图片描述


2016年1月11日14:53:17 记录一下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值