reverse_iterator的插入和删除操作

本文探讨了C++标准容器中的逆向迭代器及其base成员函数的应用,特别是在插入和删除操作中的技巧。通过实例说明如何正确使用逆向迭代器进行元素的插入和删除。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于标准容器的4种迭代器的转化,我前面的博客已经提到了,可以参考一下


一、base成员函数的用法

举个例子,看一下这段代码,我们首先把从数字1-5放进一个vector中,然后产生一个指向3的reverse_iterator,并且通过reverse_iterator的base初始化一个iterator:
vector<int> v;
v.reserve(5);                                   
for(int i = 0;i < 5; ++ i) {                    
        v.push_back(i);
 } 


// 使ri指向3
vector<int>::reverse_iterator ri = find(v.rbegin(), v.rend(), 3);

// 使i和ri的base一样
vector<int>::iterator i(ri.base());                     
执行上述代码后,可以想到产生的结果就像这样: 


这张图很好,显示了reverse_iterator和它对应的base iterator之间特有的偏移量,就像rbegin()和rend()与相关的begin()和end()一样,但并没有说出了所有你需要知道的东西


二、利用base()函数插入和删除操作

1、插入


先让我们假设你要在ri指出的位置上把一个新元素插入v。特别的,我们假设你要插入的值是99。记住ri在上图中遍历的顺序是自右向左,而且插入操作会将新元素插入到ri位置,并且将原先ri位置的元素移到遍历过程的“下一个”位置,我们认为3应该出现在99的左侧。插入操作之后,v看起来像上图。
当然,我们不能用ri来指定插入的地方,因为它不是一个iterator。我们必须用i来代替。如上所述,当ri指向3时,i(就是ri.base())指向4。如果我们用ri来指定插入位置,那么用i指向插入位置,那个假设就是正确的。


结论:

要实现在一个reverse_iterator ri指出的位置上插入新元素,在ri.base()指向的位置插入就行了。对于insert操作而言,ri和ri.base()是等价的,而且ri.base()真的是ri对应的iterator。


2、删除

现在再来考虑删除元素的情况。回顾一下最初的vector(也就是在插入99之前)ri与i的关系:



如果你要删除ri指向的元素,你不能直接使用i了,因为i与ri不是指向同一个元素。因此,你要删除的是i的前
一个元素。

结论:

要实现在一个reverse_iterator ri指出的位置上删除元素,就应该删除ri.base()的前一个元素。对于删除操作而言,ri和ri.base()并不等价,而且ri.base()不是ri对应的iterator。


我们还是有必要看看删除操作的代码,因为它还挺令人惊讶的。

vector<int> v;

// 向v插入1到5,同上
...        

// 同上,ri指向3                                     
vecot<int>::reverse_iterator ri =  find(v.rbegin(), v.rend(), 3);

 // 尝试删除ri.base()前面的元素,对于vector,一般来说编译不通过
v.erase(--ri.base());                          

对于大多数vector和string的实现,iterator(和const_iterator)会采用内建的指针来实现,所以ri.base()的结果是一个指针。C和C++都规定了不能直接修改函数返回的指针,所以在string和vector的迭代器是指针的STL平台上,像--ri.base()这样的表达式无法通过编译。                                       


 // 同上

...

// 删除ri指向的元素;这下编译没问题了!                                            
v.erase((++ri).base());                         
                                                
因为这个方法适用于所有的标准容器,这是删除一个由reverse_iterator指出的元素时首选的技巧。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值