数组循环移位操作实例
题:
如标题,要求时间复杂度为O(N)。
解法:
右移k位,前k位逆序,后N-k位逆序,再整个逆序即可。
#include <stdio.h>
#include <stdlib.h>
void reverse(int* array, int b, int e)
{
int temp = 0;
for(; b < e; b++,e--)
{
temp = array[e];
array[e] = array[b];
array[b] = temp;
}
return;
}
void rightShift(int* array, int n, int k)
{
k = k % n;
reverse(array, 0, n - k - 1);
reverse(array, n - k, n - 1);
reverse(array, 0, n - 1);
return;
}
int main()
{
int array[] = {6,7,8,9,1,2,3,4};
int i = 0;
rightShift(array, 8, 4);
for (; i < 8; i++)
{
printf("%d\n", array[i]);
}
return 0;
}
上一篇:static_cast,dynamic_cast,reinterpret_cast和const_cast的区别详解
栏 目:C语言
下一篇:c语言中getch,getche,getchar的区别
本文标题:数组循环移位操作实例
本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/4134.html
您可能感兴趣的文章
- 01-10求子数组最大和的解决方法详解
- 01-10如何寻找数组中的第二大数
- 01-10深入线性时间复杂度求数组中第K大数的方法详解
- 01-10数组中求第K大数的实现方法
- 01-10深入理解数组指针与指针数组的区别
- 01-10c语言字符数组与字符串的使用详解
- 01-10基于c的for循环中改变变量值的问题
- 01-10解析sizeof, strlen, 指针以及数组作为函数参数的应用
- 01-10c语言中用字符串数组显示菜单的解决方法
- 01-10探讨C++中数组名与指针的用法比较分析
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 01-11ajax实现页面的局部加载
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-10SublimeText编译C开发环境设置
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10C#中split用法实例总结
- 01-10delphi制作wav文件的方法
- 04-02jquery与jsp,用jquery