力扣刷题 DAY_24 字符串

剑指Offer58-II

链接:力扣 

题目:

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

示例1:

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

示例2:

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

思路:

和上一题相同的思路。将整个字符串看成两个单词,前k个字母为一个单词,后面剩下的 len - k 个字母为一个单词。先将整个字符串反转,然后将两个单词分别反转即可。这样做也是十分节省时间和空间的。

需要一提的是,在上一题的做法中,我们手动实现了反转字符串函数。实际上在algorithm库中给出了反转容器内元素的函数 reverse(iterator1,iterator2),可以反转[iterator1, iterator2)范围的元素。

参考代码:

直接调用algorithm库函数。

class Solution {
public:
    string reverseLeftWords(string s, int n) {
        reverse(s.begin(), s.end());
        std::string::iterator it = s.begin();
        n = s.size() - n;
        while (n--) {
            it++;
        }
        reverse(s.begin(), it);
        reverse(it, s.end());
        return s;
    }
};

手动实现reverse函数。

class Solution {
public:
    void reverse(string &s, int left, int right) {
        for (int i = left, j = right; i < j; i++, j--) {
            swap(s[i], s[j]);
        }
    }
    string reverseLeftWords(string s, int n) {
        int len = s.size();
        reverse(s, 0, len - 1);
        reverse(s, 0, len - 1 - n);
        reverse(s, len - n, len - 1);
        return s;
    }
};

你可能感兴趣的:(力扣刷题,leetcode,算法,字符串)