【算法-字符串1】反转字符串 + 反转字符串2

今天,带来字符串相关算法的讲解。文中不足错漏之处望请斧正!

理论基础点这里


1. 反转字符串

题意简化

题意已经很简洁。

题意转化

将字符串的顺序倒转。

解决思路(抽象)

这道题的反转可以直接调用一个库函数,但是这样做意义不大。

  • 能直接用库函数秒的题就自己写
  • 只有部分功能用库函数实现,并且对库函数了解了就可以调用库函数

解决思路:从两边向中间,两两交换字符。

编程实现(具体)

cpp 复制代码
class Solution {
public:
    void reverseString(vector<char>& s) {
        int left = 0, right = s.size() - 1;
        while (left < right) swap(s[left++], s[right--]);
    }
};

2. 反转字符串2

题意简化

题意足够简洁:

给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。

  • 如果剩余字符少于 k 个,则将剩余字符全部反转。
  • 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。

题意转化

用变量计数到2k时,区间内如果:

  1. 够k个就反转[i, i + k]
    1. 每2k个字符,反转前k个
    2. k <= 剩余字符 < 2k,反转前k个
  2. 不够k个就把剩下都全部反转[i, end()]

解决思路(抽象)

直接按照转化的题意写出代码即可。

编程实现(具体)

暴力写法:

cpp 复制代码
class Solution {
public:
    string reverseStr(string s, int k) {
        int count = 0, begin = 0;

        for (int i = 0; i < s.size(); ++i) {
            ++count;
            if (count == 2 * k) {
                myReverse(begin, begin + k - 1, s); // 每次反转k个, 反转区间: [begin, begin + k - 1]
                begin = i + 1;
                count = 0;
            }
        }

        if (count < k) myReverse(begin, s.size() - 1, s);
        else if (count >= k && count < 2 * k) myReverse(begin, begin + k - 1, s);

        return s;
    }
private:
    void myReverse(int begin, int end, string &s) {
        while (begin < end) swap(s[begin++], s[end--]);
    }
};

简介写法:

cpp 复制代码
class Solution {
public:
    string reverseStr(string s, int k) {
        for (int i = 0; i < s.size(); i += 2 * k) { // i每次递增2k,相当于计数到2k
                // 够k个就反转
                if (i + k < s.size()) reverse(s.begin() + i, s.begin() + i + k);
                // 不够k个就全部反转
                else reverse(s.begin() + i, s.end());
        }
        return s;
    }
};

今天的分享就到这里了,感谢您能看到这里。

这里是培根的blog,期待与你共同进步!

相关推荐
爱装代码的小瓶子12 分钟前
【cpp知识铺子】map与set的底层AVL树
开发语言·数据结构·c++·b树·算法·链表
IT·小灰灰13 分钟前
腾讯HY2.0 Think推理模型深度解析:技术突破、应用场景与实践指南
开发语言·人工智能·python·深度学习·神经网络·算法·数据分析
修炼地22 分钟前
代码随想录算法训练营第二十八天 | 动态规划理论基础、509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
c++·算法·动态规划
小南家的青蛙29 分钟前
LeetCode第773题 - 滑动谜题
算法·leetcode·职场和发展
Felven39 分钟前
C. Isamatdin and His Magic Wand!
c语言·数据结构·算法
AndrewHZ42 分钟前
【芯芯相印】什么是算法定点化?
pytorch·算法·芯片设计·模型量化·定点化·芯片算法·逻辑电路
数据科学小丫1 小时前
算法:线性回归
算法·回归·线性回归
剪一朵云爱着1 小时前
PAT 1131 Subway Map
算法·pat考试·图论
CoderYanger1 小时前
动态规划算法-子序列问题(数组中不连续的一段):30.最长数对链
java·算法·leetcode·动态规划·1024程序员节
啦哈拉哈1 小时前
【Python】知识点零碎学习1
数据结构·python·算法