左旋转字符串

scorlw 发布于

左旋转字符串

关键词:string

题目描述

字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串”abcdefg”和数字2,该函数将返回左旋转两位得到的结果”cdefgab”。

示例 1:

1
2
输入: s = "abcdefg", k = 2
输出: "cdefgab"

示例 2:

1
2
输入: s = "lrloseumgh", k = 6
输出: "umghlrlose"

解法

解法一:

思路:

遍历。

代码:

1
2
3
4
5
6
7
8
9
class Solution {
public:
string reverseLeftWords(string s, int n) {
string ans = "";
for (int i = n; i < s.size(); ++i) ans += s[i];
for (int i = 0; i < n; ++i) ans += s[i];
return ans;
}
};

解法二:

思路:

切片一:

代码:

1
2
3
4
5
6
class Solution {
public:
string reverseLeftWords(string s, int n) {
return (s + s).substr(n, s.size());
}
};

解法三:

思路:

切片二:

代码:

1
2
3
4
5
6
7
8
class Solution {
public:
string reverseLeftWords(string s, int n) {
string a1(s, 0, n);
string a2(s, n);
return a2 + a1;
}
};

解法四:

思路:

三次翻转

代码:

1
2
3
4
5
6
7
8
9
class Solution {
public:
string reverseLeftWords(string s, int n) {
reverse(s.begin(), s.begin() + n);
reverse(s.begin() + n, s.end());
reverse(s.begin(), s.end());
return s;
}
};

知识点

  1. string函数的使用