循环左移字符串
来源:互联网 发布:网络装修公司靠谱吗 编辑:程序博客网 时间:2024/04/29 14:48
字符串左移K次
首先需要判断K的大小,因为左移K次和左移K%str.length()效果是一样的。
所以第一步有必要:K = K%str.length();
方法一:
每次左移一位,需要运行K轮.
时间复杂度kn, 空间复杂度 1
方法二:
需要一块与字符串同样大小的额外存储空间。
假如元数组为a[1-n], 额外分配的空间为b[1-n], 那么实现左移K位以为可以按照以下的步骤进行。
1. 将a[k+1,n]拷贝到b[1,n-k]的位置上; 时间:n-k
2. 将a[1,k]拷贝到b[n-k+1,n]位置上; 时间:k
3. 将b[1,n]拷贝到a[1,n]的、位置上; 时间:n
总的时间复杂度是2n, 空间复杂度是n
方法三:
翻转字符串,步骤如下:
1. 将a[1,k]逆序
2. 将a[k+1,n]逆序
3. 将a[1,n]逆序
时间复杂度n ,空间复杂度 1
方法四:
因为将字符串左移k位的话,可以算出移位后位置。当前字符串第i位字符左移K位之后,所在的位置应该是(i-K+n)%n。
1. 在n%K != 0的时候,将第i位字符移到第j= (i-K+n)%n位,再将第j位上的字符移到 (j-K+n)%n, 以此类推迭代n次即可。
2. 在n%K = 0的时候,按照1移动的话,达不到期望的效果,迭代会在某一个组n/K个字符里面循环K次。
所以我们将字符串分组,每组的起始字符分别为a[1,2,3.,,,.K],组内按步骤1里面的方法迭代n/K次即可。
#include<iostream>#include<string>using namespace std;string rotate(string str, int k){int len = str.length();if(len%k == 0){for(int i = 0;i!=k;++i){char tmp1 = str[i],tmp2;int index = i;for(int l = 0;l!=len/k;++l){tmp2 = str[(index-k+len)%len];str[(index-k+len)%len] = tmp1;//cout<<tmp1<<" "<<tmp2<<" ";tmp1 = tmp2;//cout<<str<<endl;index = (index-k+len)%len;}}}else{char tmp1 = str[0],tmp2;int index = 0;for(int j = 0;j != len;++j){tmp2 = str[(index-k+len)%len];str[(index-k+len)%len] = tmp1;cout<<tmp1<<" "<<tmp2<<" ";tmp1 = tmp2;cout<<str<<endl;index = (index-k+len)%len;}}return str;}int main(){int k;string str("abcdefgh");cin>>k;cout<<rotate(str,k)<<endl;getchar();getchar();return 0;}
- 字符串循环左移
- 循环左移字符串
- 循环左移字符串
- 字符串循环左移
- 字符串循环左移
- 循环左移字符串
- 字符串循环左移
- 字符串循环左移
- 循环左移字符串
- 字符串循环左移
- 字符串循环左移
- 字符串循环左移
- 字符串循环左移
- 字符串循环左移
- 字符串循环左移
- 字符串循环左移
- 1362 循环左移字符串
- 字符串循环左移(20)
- C++中int转化string的几种方法
- tar.gz rpm
- Hbase的入门配置教程(0.20.6)
- 常用网址
- 19100000
- 循环左移字符串
- shell入门基础必备
- Firefox不支持event解决方法
- JSON的数据格式
- ext4.1.1 spket1.6.23 eclipse4.2 代码提示问题
- Oracle-Sequence
- Firebug 1.10 正式版发布
- 两款HTTP流量分析工具HTTP Watch与Fiddler的比较
- Oracle-trigger