0

0

C++如何使用指针实现数组旋转

P粉602998670

P粉602998670

发布时间:2025-09-12 10:26:01

|

633人浏览过

|

来源于php中文网

原创

数组旋转可通过指针实现高效操作,核心为三次反转法:先反转前n-k个元素,再反转后k个元素,最后反转整个数组,实现右旋k位;左旋则调整反转顺序或用n-k调用右旋函数。

c++如何使用指针实现数组旋转

在C++中,可以使用指针来高效地实现数组旋转。数组旋转通常分为左旋和右旋。例如,将数组 {1, 2, 3, 4, 5} 左旋2位变成 {3, 4, 5, 1, 2}。通过指针操作,可以在不额外分配大量内存的情况下完成该操作。

使用指针反转法实现数组旋转

最常用且高效的方法是“三次反转法”,也叫“翻转法”。其核心思想是:

  • 先反转前 n-k 个元素
  • 再反转后 k 个元素
  • 最后反转整个数组

这样就能实现右旋k位。左旋可类似调整顺序。

下面是使用指针实现的完整示例(以右旋为例):

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

#include 

// 使用指针反转数组的一段 void reverse(int start, int end) { while (start < end) { int temp = start; start = end; end = temp; start++; end--; } }

// 右旋数组k位 void rotateRight(int* arr, int n, int k) { if (n == 0) return; k = k % n; // 处理k大于数组长度的情况 if (k == 0) return;

int* begin = arr;
int* end = arr + n - 1;

// 步骤1:反转前n-k个元素
reverse(begin, begin + (n - k) - 1);
// 步骤2:反转后k个元素
reverse(begin + (n - k), end);
// 步骤3:反转整个数组
reverse(begin, end);

}

Red Panda AI
Red Panda AI

AI文本生成图像

下载

// 打印数组 void printArray(int arr, int n) { for (int i = 0; i (arr + i)

int main() { int arr[] = {1, 2, 3, 4, 5}; int n = 5; int k = 2;

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "原数组: ";
printArray(arr, n);

rotateRight(arr, n, k);

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "右旋" zuojiankuohaophpcnzuojiankuohaophpcn k zuojiankuohaophpcnzuojiankuohaophpcn "位后: ";
printArray(arr, n);

return 0;

}

指针操作的关键点

在这个实现中,指针的作用体现在:

  • reverse函数:接收两个指针,分别指向要反转区域的首尾,通过移动指针完成交换
  • 地址计算:arr + i 直接访问第i个元素,体现指针与数组的等价性
  • 无需额外数组:所有操作都在原数组上通过指针完成,空间效率高

左旋的实现方式

左旋k位可以通过类似方法实现,只需调整反转顺序:

  • 反转前k个元素
  • 反转后n-k个元素
  • 反转整个数组

或将右旋的k替换为 n-k 来调用上述函数即可。

基本上就这些。使用指针进行数组旋转既高效又直观,关键是掌握指针的移动和解引用操作。反转法的时间复杂度是O(n),空间复杂度是O(1),适合处理大规模数据。

相关专题

更多
string转int
string转int

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

312

2023.08.02

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

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

521

2024.08.29

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

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

48

2025.08.29

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

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

190

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2023.11.23

java中void的含义
java中void的含义

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

92

2025.11.27

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

2

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

6

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

16

2025.12.31

热门下载

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

精品课程

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

共15课时 | 0.9万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.2万人学习

XML教程
XML教程

共142课时 | 5.3万人学习

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

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