zoukankan      html  css  js  c++  java
  • ACM/ICPC竞赛

    04篇 ACM/ICPC竞赛之STL--vector


    STL<vector>头文件中定义了vector(向量容器模板类),vector容器以连续数组的方式存储元素序列,可以将vector看作是以顺序结构实现的线性表。
    当我们在程序中需要使用动态数组时,vector将会是理想的选择,vector可以在使用过程中动态地增长存储空间。

    vector模板类需要两个模板参数,第一个参数是存储元素的数据类型,第二个参数是存储分配器的类型,其中第二个参数是可选的,如果不给出第二个参数,
    将使用默认的分配器。

    下面给出几个常用的定义vector向量对象的方法示例:

    vector<int> s; 
    定义一个空的vector对象,存储的是int类型的元素。

    vector<int> s(n); 
    定义一个含有nint元素的vector对象。

    vector<int> s(first, last); 
    定义一个vector对象,并从由迭代器firstlast定义的序列[first, last)中复制初值。

    vector的基本操作有:

    s
    直接以下标方式访问容器中的元素。

    s.front()
    返回首元素。

    s.back()
    返回尾元素。

    s.push_back(x)
    向表尾插入元素x

    s.size()
    返回表长。

    s.empty()
    当表空时,返回真,否则返回假。

    s.pop_back()
    删除表尾元素。

    s.begin()
    返回指向首元素的随机存取迭代器。

    s.end()
    返回指向尾元素的下一个位置的随机存取迭代器。

    s.insert(it, x)
    向迭代器it指向的元素前插入新元素val

    s.insert(it, n, x)
    向迭代器it指向的元素前插入nx

    s.insert(it, first, last)
    将由迭代器firstlast所指定的序列[first, last)插入到迭代器it指向的元素前面。

    s.erase(it)
    删除由迭代器it所指向的元素。

    s.erase(first, last)
    删除由迭代器firstlast所指定的序列[first, last)

    s.reserve(n)
    预分配缓冲空间,使存储空间至少可容纳n个元素。

    s.resize(n)
    改变序列的长度,超出的元素将会被删除,如果序列需要扩展(原空间小于n),元素默认值将填满扩展出的空间。

    s.resize(n, val)
    改变序列的长度,超出的元素将会被删除,如果序列需要扩展(原空间小于n),将用val填满扩展出的空间。

    s.clear()
    删除容器中的所有的元素。

    s.swap(v)
    s与另一个vector对象v进行交换。

    s.assign(first, last)
    将序列替换成由迭代器firstlast所指定的序列[first, last)[first, last)不能是原序列中的一部分。

    要注意的是,resize操作和clear操作都是对表的有效元素进行的操作,但并不一定会改变缓冲空间的大小。

    另外,vector还有其他一些操作如反转、取反等,不再一下列举。

    vector上还定义了序列之间的比较操作运算符(>, <, >=, <=, ==, !=),可以按照字典序比较两个序列。

    还是来看一些示例代码。输入个数不定的一组整数,再将这组整数按倒序输出,如下所示:

     1 #include <iostream>
     2 #include <vector>
     3 using namespace std;
     4 main()
     5 {
     6 vector<int> L;
     7 int x;
     8 while (cin>>x) L.push_back(x);
     9 for (int i=L.size()-1; i>=0; i--) cout << L << " ";
    10 cout << endl;
    11 return 1;
    12 }

    未完待续、、、

     

     

     

     

  • 相关阅读:
    用javascript实现简单的用户登录验证
    JS创建数组的三种方法
    JS中的数据类型
    原始值和引用值
    html为什么用雪碧图的优缺点
    html,将元素水平,垂直居中的四种方式
    使用display:none和visibility:hidden隐藏的区别
    jsonview注解、RequestBody 、拦截
    02.实现图形验证码
    spring注解使用
  • 原文地址:https://www.cnblogs.com/jeff-wgc/p/4480218.html
Copyright © 2011-2022 走看看