0

0

c++如何使用std::rotate_c++容器元素循环移动【入门】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-18 15:49:02

|

426人浏览过

|

来源于php中文网

原创

std::rotate是将[first, middle)与[middle, last)两段交换位置的确定性切割拼接操作,不是动画式旋转;要求middle∈[first,last)且不可为last(除非first==last),支持所有可赋值迭代器,时间复杂度o(n),对move-only类型安全使用move语义。

c++如何使用std::rotate_c++容器元素循环移动【入门】

std::rotate 是什么,不是什么

std::rotate 不是“把容器转个圈”那种直观的旋转动画,它干的是一个确定的切割+拼接操作:把迭代器范围 [first, middle)[middle, last) 两段内容交换位置。结果上看起来像“循环左移”,但本质是三段内存的重排——中间点 middle 决定了哪部分被“移到前面”。

常见错误现象:std::rotate(v.begin(), v.begin() + 2, v.end()) 想左移 2 位,却因 middle 超出范围崩溃;或误以为它支持负偏移(实际不支持,得自己算等效正 offset)。

  • 使用场景:实现数组/向量的循环位移、轮转调度、滑动窗口重置
  • 参数差异:middle 必须在 [first, last] 范围内,且不能是 last(除非 first == last
  • 性能影响:平均时间复杂度 O(n),内部用 swap 或 move,对 std::vector<int></int> 很快,但对大对象可能触发多次移动构造

怎么写一个安全的循环左移函数

直接裸用 std::rotate 容易越界或逻辑反向。封装一层能规避多数坑:

template <typename It>
void rotate_left(It first, It last, size_t k) {
    if (first == last) return;
    const auto n = std::distance(first, last);
    if (n <= 1) return;
    k = k % n; // 防止 k 大于长度
    if (k == 0) return;
    std::rotate(first, first + k, last); // 左移 k 位 = 把前 k 个挪到后面
}

关键点:

立即学习C++免费学习笔记(深入)”;

  • 必须先算 std::distance,不能依赖容器 size()(比如传入 list::iterator 时)
  • k % n 不可省——否则 k > n 会令 first + k 越界
  • std::liststd::rotate 仍可用,但 first + k 无效(不支持随机访问),得改用 std::next(first, k)

std::rotate 和手写 for 循环比,差在哪

有人觉得“不就移几个数?我自己 swap 就行”,但忽略了几点:

  • 兼容性:std::rotate 对所有符合要求的迭代器都有效(vectordequelist、甚至 std::array 的原始指针),手写循环往往只适配 vector
  • 异常安全:标准库实现保证强异常安全(移动失败时状态不变),手写容易漏掉中间异常点
  • 优化空间:libc++ / libstdc++ 对 std::rotate 有特化,比如对 POD 类型可能用 memmove,比逐个 swap 快得多
  • 边界陷阱:手写左移常错把 v[i] = v[(i+k)%n] 当成原地操作,实际需要额外空间或反向遍历,而 std::rotate 原生就是原地、稳定、无额外分配

容易被忽略的 const_iterator 和 move-only 类型

std::rotate 要求迭代器可 dereference 并能赋值,所以:

  • 不能传 const_iterator —— 因为无法修改元素(报错类似 assignment of read-only location
  • 对 move-only 类型(如 std::unique_ptr),std::rotate 用 move 而非 copy,没问题;但若自己写 swap,得确保类型支持 std::move,否则编译失败
  • 如果容器元素是 const 修饰的(比如 std::vector<const int></const>),根本无法编译——这不是 std::rotate 的问题,而是设计错误,const 元素容器本身几乎无实用价值

真正麻烦的是调试时看到 error: use of deleted function 'std::unique_ptr<...>& std::unique_ptr<...>::operator=(const std::unique_ptr<...>&)'</...></...></...>,其实只是你传了 const_iterator,而不是类型本身不支持。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.25

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

547

2023.09.20

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

770

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

572

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

254

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

494

2023.08.04

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.7万人学习

C 教程
C 教程

共75课时 | 4.8万人学习

C++教程
C++教程

共115课时 | 18.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号