[剑指 offer]左旋转字符串
题目要求
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!
题目分析
- 这道题一开始我会错意啦,以为是一个反转字符串问题……后来才发现搞错了。
- 一开始的时候我在前面加上了对n的判断处理,将n改成同样符合题意的n`(保证范围在0-str.length()-1之间,但后来发现没有必要。
- 所以就直接将每一位的字符串都向左移,需要注意的就是注意下标,不要越界。这可以通过加一个()%str.length()来解决。
- 我一开始用的是需要O(n)空间的,看了一下别人的思路是不需要的,下面贴一下别人的思路:
- 思路1: 将前n个直接剪切下来粘贴到字符串后面的位置,但是这样的话其实就默认n的范围了,我觉得在题目没有明确说明n在0-str.length()-1的情况下,还是进行一下对n的处理比较好。将前n个直接剪切下来粘贴到字符串后面的位置,但是这样的话其实就默认n的范围了,我觉得在题目没有明确说明n在0-str.length()-1的情况下,还是进行一下对n的处理比较好。
- 思路2:将两个str拼接起来,然后选择从n开始len长度的那一段返回。相对来说更精巧一点吧,但是没有考虑n<0的情况
代码
//我的远古方法
class Solution {
public:
string LeftRotateString(string str, int n) {
if(str.length()==0)return str;
string ans=str;
for(int i=0;i<str.length();++i){
ans[(ans.length()-n+i)%ans.length()]=str[i];
}
return ans;
}
};
//别人的思路1,我认为需要加上对n的处理比较合适
class Solution {
public:
string LeftRotateString(string str, int n) {
if(n<0) return NULL;
if(n==0) return str;
string strTemp="";
strTemp=str.substr(0,n);
str.erase(0,n);
str+=strTemp;
return str;
}
};
//别人的思路2,没有考虑n<0的情况
class Solution {
public:
string LeftRotateString(string str, int n) {
int len = str.length();
if(len == 0) return "";
n = n % len;
str += str;
return str.substr(n, len);
}
};