• STL之Deque使用小结


    /*deque: 是一个double-ended queue,
        1)支持随即存取,也就是[]操作符,
        2)支持两端操作,push(pop)-back(front),在两端操作上与list效率差不多
    
        因此在实际使用时,如何选择这三个容器中哪一个,应根据你的需要而定,一般应遵循下面的原则: 
        1、如果你需要高效的随即存取,而不在乎插入和删除的效率,使用vector 
        2、如果你需要大量的插入和删除,而不关心随即存取,则应使用list 
        3、如果你需要随即存取,而且关心两端数据的插入和删除,则应使用deque。
    */
    
    #include <iostream>
    #include <deque>
    using namespace std;
    
    void printDeque(deque<int> d)
    {
    //使用下标
    //for (unsigned int i = 0; i < d.size(); i++)
    //{
    // cout<<"d["<<i<<"] = "<<d[i]<<", ";
    //}
    
    //使用迭代器
    //deque<int>::iterator iter = d.begin();
    //for (;iter != d.end(); iter ++)
    //{
    // cout<<"d["<<iter-d.begin()<<"] = "<<(*iter)<<", ";
    //}
    
    //使用迭代器指针
    deque<int>::iterator *pIter = new deque<int>::iterator;
    if ( NULL == pIter )
    {
       return ;
    }
    for (*pIter = d.begin(); *pIter != d.end(); (*pIter)++)
    {
       cout<<"d["<<*pIter - d.begin() <<"]="<<**pIter<<", ";
    }
    if (NULL != pIter)
    {
       delete pIter;
       pIter = NULL;
    }
    
    cout<<endl;
    }
    
    void main()
    {
    //创建deque
    deque<int> d1; //创建一个没有任何元素的deque对象
    deque<int> d2(10);//创建一个具有10个元素的deque对象,每个元素值为默认
    deque<double> d3(10, 5.5); //伊妹一个具有10个元素的deque对象,每个元素的初始值为5.5
    deque<double> d4(d3); //通过拷贝一个deque对象的元素值, 创建一个新的deque对象
    int iArray[] = {11, 13, 19, 23, 27};
    deque<int> d5(iArray, iArray+5);//将迭代器区间[first, last)所指的元素拷贝到一个新创建的deque对象中
    
    //初始化赋值:同vector一样,使用尾部插入函数push_back()
    for (int i = 1; i < 6 ; i++)
       d1.push_back(i*10);
    //遍历元素: 1-下标方式 2-迭代器方式 反向遍历(略)
    cout<<"printDeque(d1) : "<<endl;
    printDeque(d1);
    
    //元素插入:尾部插入用push_back(),头部插入用push_front(),其它位置插入用insert(&pos, elem)
    cout<<"d1.push_front(100): "<<endl;
    d1.push_front(100);
    printDeque(d1);
    cout<<"d1.insert(d1.begin()+3, 200): "<<endl; //支持随机存取(即[]操作符),所以begin()可以+3
    d1.insert(d1.begin()+2,200);
    printDeque(d1);
    
    //元素删除 尾部删除用pop_back();头部删除用pop_front(); 
    //任意迭代位置或迭代区间上的元素删除用erase(&pos)/erase(&first, &last);删除所有元素用clear();
    cout<<"d1.pop_front(): "<<endl;
    d1.pop_front();
    printDeque(d1);
    
    cout<<"d1.erase(d1.begin()+1): "<<endl;
    d1.erase(d1.begin()+1); //删除第2个元素d1[1]
    printDeque(d1);
    
    cout<<"d1.erase(d1.begin(), d1.begin() + 2) = "<<endl;
    d1.erase(d1.begin(), d1.begin() + 2);
    printDeque(d1);
    
    cout<<"d1.clear() :"<<endl;
    d1.clear();
    printDeque(d1);
    
    
    //其它常用
    cout<<"其它常用用法: "<<endl;
    int flag = 0;
    while(flag < 2)
    {
       if (0 == flag )
       {
        for (int i = 1; i < 6 ; i++) //恢复
         d1.push_back(i*10);
       }
       else
       {
        d1.clear();
        cout<<"after d1.clear() , d1.front(), d1.back() is abnormal! other info.:"<<endl;
       }
       cout<<"d1.empty() = "<<d1.empty()<<endl;
       cout<<"d1.size() = "<<d1.size()<<endl;
       cout<<"d1.max_size() = "<<hex<<d1.max_size()<<endl;
       if (!d1.empty())
       {
        cout<<"d1.front() = "<<d1.front()<<endl;
        cout<<"d1.back() = "<<d1.back()<<endl;
       }
      
       flag++;
      
    }
    
    //交换
    cout<<"d1.swap(d5)= "<<endl;
    d1.swap(d5);
    cout<<"d1 = ";
    printDeque(d1);
    cout<<"d5 = ";
    printDeque(d5);
    //printDeque(d)
    
    
    }

  • 相关阅读:
    javascript 将中文符号转换成英文符号
    js 函数定义的2种方式
    javascript 面向对象编程(工厂模式、构造函数模式、原型模式)
    10.2.0.4 to 10.2.0.5 Installation of Patch Set Release (Windows)
    流接口驱动程序的工作原理和开发步骤嵌入式
    android开发面试题
    ORACLE-014:oracle中查看DBLinkpassword
    Java相关知识(一)
    Android 中模仿 Twitter 实现 Toolbar Indicator
    使用excel进行数据挖掘(3)----类别检測
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13318554.html
Copyright © 2020-2023  润新知