字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
示例 1: 输入: s = "abcdefg", k = 2 输出: "cdefgab"
示例 2: 输入: s = "lrloseumgh", k = 6 输出: "umghlrlose"
限制: 1 <= k < s.length <= 10000
class Solution {
public String reverseLeftWords(String s, int n) {
int len=s.length();
StringBuilder sb=new StringBuilder(s);
reverseString(sb,0,n-1);
reverseString(sb,n,len-1);
return sb.reverse().toString();
}
public void reverseString(StringBuilder sb, int start, int end) {
while (start < end) {
char temp = sb.charAt(start);
sb.setCharAt(start, sb.charAt(end));
sb.setCharAt(end, temp);
start++;
end--;
}
}
}
abcdefg n=2 先反转指定,在反转剩余,在整体反转
bacdefg
bagfedc
cdefgab ----正确结果
StringBuilder sb=new StringBuilder(s);
reverseString(sb,0,n-1);
reverseString(sb,n,len-1);
return sb.reverse().toString();
abcdefg
gfedcba 全部转
gfedcab 需要的转
cdefgab 剩余转
StringBuilder sb=new StringBuilder(s);
reverseString(sb,0,len-1);
reverseString(sb,len-n,len-1);
reverseString(sb,0,len-n-1);
return sb.toString();
此时我们已经反转好多次字符串了,来一起回顾一下吧。
在344.反转字符串,第一次讲到反转一个字符串应该怎么做,使用了双指针法。
然后发现541. 反转字符串II,这里开始给反转加上了一些条件,当需要固定规律一段一段去处理字符串的时候,要想想在在for循环的表达式上做做文章。
后来在151.翻转字符串里的单词中,要对一句话里的单词顺序进行反转,发现先整体反转再局部反转 是一个很妙的思路。
最后再讲到本题,本题则是先局部反转再 整体反转,与151.翻转字符串里的单词类似,但是也是一种新的思路。
好了,反转字符串一共就介绍到这里,相信大家此时对反转字符串的常见操作已经很了解了