Vector与Map表的区别

1)vector为顺序容器,erase迭代器不仅使所有指向被删元素的迭代器失效,而且使被删元素之后的所有迭代器失效,所以不能使用erase(iter++)的方
式,但是erase的返回值为下一个有效的迭代器:可以这样使用:

for( iter = c.begin(); iter != c.end(); )

iter = c.erase(iter);

2)erase迭代器只是被删元素的迭代器失效:所以可以这样使用:

for( iter = c.begin(); iter != c.end(); )

c.erase(iter++);

 

正因为:map erase 会使被删元素的迭代器失效:所以在使用map iterator时候要注意:

 

一种很常见的错误是:

for ( map<int, string>::iterator it = str_map.begin(); it!=str_map.end(); it++ ) {

if ( some_condition )

str_map.erase(it);

}

删除操作会使it乱掉,再使用it++就出错了。正确的做法是:

for ( map<int, string>::iterator it = str_map.begin(); it!=str_map.end(); ) {

if ( some_condition ) {

str_map.erase(it++);

} else {

it++;

}

}

 

3)Map可以通过key查找元素,而vector查找元素也类似,通过值查找;

 

4)对于vector的值得注意的地方,可以对vector调用排序算法,举例如下:

typedef struct {

std::string strName;

int money;

}company_person;

 

然后可以按照strName进行排序;我在一个项目中用到过这个,在一个项目中,客户端以随机的发送strName,然后在服务端对他们进行重新排序;

 

5)map和vector 插入元素的方式不一样,map没有push_back这样的函数,只有insert依次插入元素,或者直接通过构造函数初始化;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值