reverse/reverse_copy详解

41 篇文章 0 订阅
39 篇文章 2 订阅

reverse:逆转元素次序               

//TEMPLATE FUNCTION reverse

template<class_BidIt> inline

         void_Reverse(_BidIt _First, _BidIt _Last, bidirectional_iterator_tag)

         {       // reverse elements in [_First, _Last), bidirectionaliterators

         for (;_First != _Last && _First != --_Last; ++_First)

                   _STD iter_swap(_First,_Last);//这里居然没有使用反向迭代器.

         }

reverse_copy:逆转元素,并返回逆转后的容器

                   //TEMPLATE FUNCTION reverse_copy

template<class _BidIt,

         class_OutIt> inline

         _OutIt _Reverse_copy(_BidIt _First,_BidIt _Last,

                   _OutIt _Dest)

         {       // copy reversing elements in [_First, _Last)

         for (;_First != _Last; ++_Dest)

                   *_Dest = *--_Last;

         return(_Dest);

         }

举例:

int main()

{

         typedefvector<int> vecIntContains;

         vecIntContains vecInt;

         vecInt.push_back( 2 );

         vecInt.push_back( 7 );

         vecInt.push_back( 7 );

         vecInt.push_back( 5 );

         vecInt.push_back( 4 );

         vecInt.push_back( 1 );

         vecInt.push_back( 4 );

         vecInt.push_back( 1 );

         vecIntContains vecNew;

         copy(vecInt.begin(),vecInt.end(),ostream_iterator<int>(cout," " ) );

         cout<<"\nvecIntfirst:\n";

         reverse( vecInt.begin(),vecInt.end() );//left > right

         copy(vecInt.begin(),vecInt.end(),ostream_iterator<int>(cout," " ) );

 

         cout<<"\nuniquesecond operator:\n";

         reverse_copy(vecInt.begin(),vecInt.end(),ostream_iterator<int>(cout," " ));//left > right

         system( "pause");

         return0;

}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在C++中,vector的reverse函数用于反转容器中元素的顺序。它接受两个迭代器参数,分别指定了要反转的范围的起始和结束位置。reverse函数会将指定范围内的元素进行反转,并修改原容器中的元素顺序。\[1\]例如,可以使用reverse函数来反转一个vector容器中的元素顺序,如下所示: ```cpp vector<int> vi ={1,2,3,4,5,6}; reverse(vi.begin(),vi.end()); //反转后的vi为6,5,4,3,2,1 ``` reverse函数的原理是通过交换容器中的元素来实现反转。具体实现方式可以参考C++标准库中的reverse函数的源代码。\[2\]另外,如果不想修改原容器中的元素顺序,可以使用reverse_copy函数将反转后的元素放入一个新的容器中。reverse_copy函数也接受两个迭代器参数,分别指定了要反转的范围的起始和结束位置,以及一个输出迭代器参数,指定了反转后的元素放置的位置。\[3\]例如,可以使用reverse_copy函数将一个vector容器中的元素反转后放入另一个vector容器中,如下所示: ```cpp vector<int> vi ={1,2,3,4,5,6}; vector<int> reversedVi; reverse_copy(vi.begin(),vi.end(),back_inserter(reversedVi)); //反转后的reversedVi为6,5,4,3,2,1 ``` 这样,原容器vi的元素顺序不会改变,而反转后的元素会被放入新的容器reversedVi中。 #### 引用[.reference_title] - *1* [c++中reverse函数实现vector变量的翻转](https://blog.csdn.net/qq_31672701/article/details/102594300)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [C++中vector的reverse函数及其用法(详解)](https://blog.csdn.net/Adae_Stevens/article/details/127721285)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [c++ vector反转reverse](https://blog.csdn.net/qq634416025/article/details/8459462)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值