C++ rotate(STL rotate)算法详解
rotate() 算从左边选择序列的元素。它的工作机制如图 1 所示。

图 1 rotate()算法的工作方式(点此查看大图)
为了理解如何旋转序列,可以将序列中的元素想象成手镯上的珠子。rotate() 操作会导致一个新元素成为开始迭代器所指向的个元素。在旋转之后,一个元素会在新的个元素之前。
rotate() 的个参数是这个序列的开始迭代器;第二个参数是指向新的个元素的迭代器,它必定在序列之内。第三个参数是这个序列的结束迭代器。图 1 中的示例说明在容器 ns 上的旋转操作使值为 4 的元素成为新的个元素,一个元素的值为 3。元素的圆形序列会被维持,因此可以有效地旋转元素环,直到新的个元素成为序列的开始。这个算返回一个迭代器,它指向原始的个元素所在的新位置。例如:
这段代码对 words 中的所有元素进行了旋转。执行这段代码会生成如下内容:std::vector<string> words { "one", "two", "three", "four", "five","six", "seven", "eight"};
auto iter = std::rotate(std::begin(words), std::begin(words)+3, std::end(words));
std::copy(std::begin(words), std::end(words),std::ostream_iterator<string> {std::cout, " "});
std::cout << std::endl << "First element before rotation: " << *iter << std::endl;
four five six seven eight one two three
First element before rotation: one
输出说明 "four" 成为新的个元素,而且 rotate() 返回的迭代器指向之前的个元素"one"。当然,不需要对容器中的全部元素进行旋转。例如:
这里用 find() 算法分别获取了和"two"、"eight"匹配的元素的迭代器。它们定义了被旋转的序列,这个序列是容器元素的子集。这个序列会被旋转为使"five"成为个元素,输出说明它是按预期工作的:std::vector<string> words { "one", "two", "three", "four", "five","six", "seven", "eight", "nine", "ten"};
auto start = std::find(std:rbegin(words), std::end(words), "two");
auto end_iter = std::find(std::begin(words), std::end(words), "eight");
auto iter = std::rotate(start, std::find(std::begin(words), std::end (words), "five") , end_iter);
std::copy(std::begin(words), std::end(words), std::ostream_iterator<string>{std::cout, " "});
std::cout << std::endl << "First element before rotation: " << *iter << std::endl;
one five six seven two three four eight nine ten
First element before rotation: two
- 随机文章
- 亚洲强队马尔代夫(马尔代夫成为亚洲足球强队)
- 从宿州到马尔代夫(从宿州出发,感受马尔代夫的梦幻之旅)
- 马尔代夫鲨鱼游玩(浮潜嘉年华!玩转马尔代夫海中鲨鱼)
- 一价全包马尔代夫(马尔代夫旅游,包一切,只需一价全包)
- 广东马尔代夫游泳(广东清远池尾河打造马尔代夫游泳胜地)
- 南宁海滩马尔代夫(南宁的海滩重新打造,仿若马尔代夫!)
- 汉服马尔代夫图片(中式古风超美马尔代夫旅拍照令人陶醉)
- 天津马尔代夫旅游(天津玛尔代夫,打造身临其境度假之旅)
- 江西马尔代夫萍乡(萍乡市建起江南第一座透明玻璃观景台)
- 兰溪小型马尔代夫(后的:兰溪打造小型马尔代夫旅游胜地)
- 温州永嘉马尔代夫(温州永嘉市民的马尔代夫游玩获得盛赞)
- 最美的海马尔代夫(探秘海马尔代夫,享受最佳旅行体验!)
- 福建泉州马尔代夫(福建泉州首家马尔代夫主题水乐园开业)
- 栾川马尔代夫乐园(栾川投资数百万打造马尔代夫主题公园)
- 林州马尔代夫旅游(林州的马尔代夫之旅,海岛度假好去处)
- 江滨公园马尔代夫(江滨公园的马尔代夫式海景:美不胜收)
- 海南博鳌马尔代夫(海南博鳌与马尔代夫合作迈向深度交流)
- 荆州马尔代夫酒店(荆州的马尔代夫酒店:度假解压好去处)
- 除了马尔代夫水屋(重构马尔代夫度假:享受水里别墅生活)
- 苏通建设马尔代夫(苏通公司在马尔代夫承建项目顺利推进)
- 盱眙 马尔代夫(盱眙县:马尔代夫爱好者的天堂)
- 媲美 马尔代夫(与马尔代夫媲美的度假胜地,全新推荐)
- 海南乐东马尔代夫(海南乐东一处美如马尔代夫的度假胜地)
- 马尔代夫停船旅游(马尔代夫暂停游轮停靠以遏制病毒传播)
- 随州马尔代夫全景(随州市别样马尔代夫,全景带你发现!)
- 马尔代夫别墅酒店(后的为:探访马尔代夫豪华别墅酒店。)
- 马尔代夫全包滑梯(马尔代夫全包度假村首创滑梯玩乐活动)
- 马尔代夫古代兵器(马尔代夫考古学家挖掘出古代兵器残骸)
- 马尔代夫中国游艇(马尔代夫游艇产业受益于中国游客增长)
- 马尔代夫主场现状(马尔代夫主场状态如何?统计报告揭晓)
