STL review:vector & struct

I.vector

1.头文件:#include<vector>                        //容器vector是一个能实现随机存取、插入删除的动态数组,还可以当栈使。  

2.创建: vector<int> v1:                             // < >里可以是struct或者vector嵌套:vector< vector<int> > ivec;

vector是一个类模板,创建一个vector的过程称为实例化。

3.初始化:

  • vector<T> v2(v1);   //  效果同拷贝初始化 vector<T> v2=v1;
  • vector<T> v2(n,val);
  • vector<T> v2{a,b,c,d};  // vector<T> v2={a,b,c,d};
  • 数组指针
  • int iarray[]={0,1,2,3,4,5,6,6,6,7,8};
    vector<int> v1(iarray,iarray+sizeof(iarray)/sizeof(int));

4.尾部插入数字:v1.push_back(a);     //  pop_back();

5.下标实现随机存取: v1[0]=a;

6.常用函数: empty()  size()  clear()  <=

7.使用迭代器访问元素.

vector<int>::iterator it;
for(it=v1.begin();it!=v1.end();it++)
    cout<<*it<<endl;

8.插入和删除 insert,erase   配合迭代器,如删除所有值为8的元素

v1.insert(v1.begin()+i,a);  //在第i+1个元素前面插入a

v1.erase(v1.begin()+2);  //删除第3个元素

9.#include<algorithm>

(1) 元素翻转:

reverse(vec.begin(),vec.end());   //将元素翻转(在vector中,如果一个函数中需要两个迭代器,一般后一个都不包含.)

(2)排序:

bool Comp(const int &a,const int &b){
    return a>b;
}

sort(vec.begin(),vec.end());  //升序排列
sort(vec.begin(),vec.end(),Comp)  //降序排序

II. struct

typedef struct rect
{
    int id;
    int length;

  bool operator< (const rect &a)  const
    {
        if(id!=a.id)
            return id<a.id;
        else
        {
            if(length!=a.length)
                return length<a.length;
        }
    }
}Rect;

  

时间: 2024-10-14 21:00:05

STL review:vector & struct的相关文章

C++ STL:vector

  不定长数组:vetor 它就像一个二维数组,只是第一维的大小是固定的,但是第二维的大小不固定. 下面是一些尝试代码: 1. <pre name="code" class="cpp"> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #include<cmath> #include<vec

STL(三):vector

一和二中吧STL 的基础都说明白了,那我们尝试着实现一下第一个容器:vector (好敷衍呀-) vector 算是比较简单的一种容器了,但饶是如此,我都写了好久(主要是其他的各种函数费时间) 准备工作 在直接开始说vector 的时候的时候,我会假设你懂得以下函数的运用(最好自己去实现一下吧) uninitialized_copy uninitialized_copy_n uninitialized_fill uninitialized_fill_n copy copy_n fill fill

转:用STL中的vector动态开辟二维数组

用STL中的vector动态开辟二维数组 源代码:#include <iostream>#include <vector>using namespace std;int main(){ int m, //行数     n; //列数 cout << "input value for m,n:"; cin>>m>>n;  //注意下面这一行:vector<int后两个">"之间要有空格!否则会被认

C++ STL 学习 :for_each与仿函数(functor)

简单来将,仿函数(functor)就是一个重载了"()"运算符的struct或class,利用对象支持operator()的特性,来达到模拟函数调用效果的技术. 我们平时对一个集合类遍历的时候,例如vector,是这样做的: for(vector<int>::const_iterator iter = ivec.begin(); iter != ivec.end(); ++iter) { //do your whatever you want here } 例如下面的代码:

C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法

每次忘记都去查,真难啊 1 /* 2 C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法 3 */ 4 5 /* 6 vector常用用法 7 */ 8 //头文件 9 #include<vector> 10 11 //常用的初始化方法 12 vector<int> v; //直接定义一个整型元素的向量 且未声明长度,其中int的位置可以换成别的数据类型或者结构体等 13 vector<int> v(10);

stl容器区别: vector list deque set map及底层实现

在STL中基本容器有: vector.list.deque.set.map set 和map都是无序的保存元素,只能通过它提供的接口对里面的元素进行访问 set :集合, 用来判断某一个元素是不是在一个组里面,使用的比较少 map :映射,相当于字典 ,把一个值映射成另一个值,如果想创建字典的话使用它好了 底层采用的是树型结构,多数使用平衡二叉树实现 ,查找某一值是常数时间,遍历起来效果也不错, 只是每次插入值的时候,会重新构成底层的平衡二叉树,效率有一定影响. vector.list.dequ

STL中的Vector相关用法

STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int>是一种数据类型. Vector的存储空间是连续的,list不是连续存储的. 1. 定义和初始化 vector< typeName > v1; //默认v1为空,故下面的赋值是错误的v1[0]=5;//v2是v1的一个副本,若v1.size()>v2.size()则赋值后v2.size()被

STL容器之一vector

STL中最简单也是最有用的容器之一是vector<T>类模板,称为向量容器,是序列类型容器中的一种. 容器容量可以选择性修改.(1)声明:vector<type>  v;    //容量为0构造v对象,指定元素类型为typevector<type>  v(n);    //容量为n构造v对象,指定元素类型为typevector<type>  v(n, initValue);    //容量为n构造v对象,指定元素类型为type,且所有元素被初始化为initV

C++:vector的用法详解(转载)

原文地址:http://blog.csdn.net/hancunai0017/article/details/7032383 vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的. 用法: 1.文件包含: 首先在程序开头处加上#include<vector>以包含所需要的类文件vector 还有一定要加上using namespace std; 2.变量声明: 2.1 例: