如何把string的元素逆序

论坛里见到这个问题:如何把string的元素逆序?

我直接想到的是利用反向迭代器reverse_iterator:rbegin()和rend():

  1. string str1("1234567890");
  2. string str2(str1.rbegin(), str1.rend());
string str1("1234567890");
string str2(str1.rbegin(), str1.rend());


这样的话逆序string就保存在str2里了。要是想保存在原string呢,这样:

  1. string str1("1234567890");
  2. str1 = string(str1.rbegin(), str1.rend());
string str1("1234567890");
str1 = string(str1.rbegin(), str1.rend());

这是利用operator=(const string&),别忘了还有成员函数assign这个利器:

  1. string str1("1234567890");
  2. str1.assign(str1.rbegin(), str1.rend());
string str1("1234567890");
str1.assign(str1.rbegin(), str1.rend());

这是使用了成员函数assign的一种重载:

  1. template<class InputIterator>
  2. basic_string& assign(InputIterator first, InputIterator last);
template<class InputIterator>
basic_string& assign(InputIterator first, InputIterator last);

不过这很容易产生疑问(这少我是产生了):看起来都是在相同的内存上操作,会不会有问题。类似memcpy的src和dst有重叠的情况?

C++标准告诉我们,是不会有问题的——标准(ISO2003)21.3.5.3:

  1. template<class InputIterator>basic_string& assign(InputIterator first, InputIterator last);
  2. Returns: assign(basic_string<charT,traits,Allocator>(first,last))
template<class InputIterator>basic_string& assign(InputIterator first, InputIterator last);

Returns: assign(basic_string<charT,traits,Allocator>(first,last))

原来会产生一个临时变量:basic_string<charT,traits,Allocator>(first,last)。疑虑消除了。

但是,能不能直接在string中逆序元素呢?这样就避免了临时变量的产生。自己动手写是不难,不过,STL中提供了大量的算法,看看其中有没有我们需要的:

  1. template <class BidirectionalIterator>
  2. void reverse ( BidirectionalIterator first, BidirectionalIterator last)
  3. {
  4. while ((first!=last)&&(first!=--last))
  5. swap (*first++,*last);
  6. }
template <class BidirectionalIterator>
  void reverse ( BidirectionalIterator first, BidirectionalIterator last)
{
  while ((first!=last)&&(first!=--last))
    swap (*first++,*last);
}

这个template <class BidirectionalIterator> void reverse ( BidirectionalIterator first, BidirectionalIterator last)相当不错,完美解决了我们的问题:

  1. str1("1234567890");
  2. reverse(str1.begin(), str1.end());
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值