C++经典例题之字符串特定规则反转问题的解法

 更新时间:2025年03月20日 09:24:12   作者:倔强的石头_  
这篇文章主要介绍了如何解决字符串反转问题,通过将字符串按每2k个字符为一个区间进行划分,并使用双指针方法来确定实际反转的边界,最终实现字符串按特定规则进行反转,文中通过代码介绍的非常详细,需要的朋友可以参考下

问题描述

在字符串处理的编程领域中,经常会遇到各种复杂的规则要求。

本文将深入探讨一个给定字符串 s 和整数 k,按照特定规则反转字符串的问题

要求从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符

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

原题链接

541. 反转字符串 II - 力扣(LeetCode)

解题思路

  • 区间划分:解题的核心在于将字符串按照每 2k 个字符为一个区间进行划分。通过双指针的方式,定义一个左指针 left 来标记每个区间的起始位置,初始时 left 指向字符串的开头 s.begin()。
  • 确定右边界:对于每个 2k 区间,需要确定其右边界 right。如果当前区间有足够的字符,即 left + 2*k 小于字符串的末尾 s.end(),那么右边界 right 就是 left + 2*k;否则,右边界 right 就是字符串的末尾 s.end()。这一步是为了确定一个2k区间
  • 确定实际反转的右边界:在每个 2k 区间内,需要进一步确定实际反转的右边界 rightend。如果从 left 开始往后数 k 个字符不超过字符串末尾,即 (left + k) < s.end(),那么实际反转的右边界 rightend 就是 left + k;否则,实际反转的右边界 rightend 就是字符串的末尾 s.end()。这一步是为了满足题目中关于剩余字符数量不同时的反转规则
  • 反转操作:确定了实际反转的左右边界后,使用 reverse 函数对 [left, rightend) 区间内的字符进行反转。
  • 移动指针:完成一个区间的处理后,将左指针 left 移动到当前右边界 right 的位置,以便处理下一个 2k 区间。重复上述步骤,直到左指针 left 到达字符串的末尾。

代码实现

class Solution {
public:
    string reverseStr(string s, int k) 
    {
        string::iterator left = s.begin();//初始左区间
        

        while(left < s.end())
        {
            //初始右区间
            string::iterator right = (left + 2*k )< s.end() ?  left+ 2*k : s.end();
            
            //确定右区间的实际值
            //剩余数量小于k,就全部反转;剩下数量大于k,就反转前k
            string::iterator rightend =(left + k)<s.end() ? (left + k) : s.end();

            reverse(left,rightend);
            
            //移动
            left = right;
            
        }
        return s;
    }
};
  • 初始化左指针:string::iterator left = s.begin(); 这行代码初始化了左指针 left,使其指向字符串 s 的开头。
  • 循环处理区间:while(left < s.end()) 循环用于遍历整个字符串,只要左指针 left 还未到达字符串末尾,就继续处理下一个 2k 区间。
  • 确定右边界:string::iterator right = (left + 2*k )< s.end()? left+ 2*k : s.end(); 这行代码根据当前 left 的位置和 2k 的长度,确定了当前 2k 区间的右边界 right。
  • 确定实际反转的右边界:string::iterator rightend =(left + k)<s.end()? (left + k) : s.end(); 这行代码根据当前 left 的位置和 k 的长度,确定了实际需要反转的右边界 rightend。
  • 反转操作:reverse(left,rightend); 这行代码调用 reverse 函数,对 [left, rightend) 区间内的字符进行反转。
  • 移动左指针:left = right; 这行代码将左指针 left 移动到当前右边界 right 的位置,为处理下一个 2k 区间做准备。

复杂度分析

  • 时间复杂度:由于每个字符最多被处理一次,所以时间复杂度为 O(n),其中 n 是字符串的长度
  • 空间复杂度:代码中只使用了常数级别的额外空间,如指针 left、right 和 rightend,所以空间复杂度为 O(1)

通过上述解题思路和代码实现,我们可以高效地解决这个字符串特定规则反转的问题。这种方法不仅逻辑清晰,而且在时间和空间复杂度上都达到了较好的性能。

总结

到此这篇关于C++经典例题之字符串特定规则反转问题解法的文章就介绍到这了,更多相关C++字符串特定规则反转问题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++中多才多艺的 const

    C++中多才多艺的 const

    在C++中,关键字const可以用来修饰任何作用域内的变量、函数参数、函数本体、函数返回值、成员函数、迭代器,也可以用来修饰指针本身和指针目标,可谓多才多艺,我们要详细了解其内部细节,以及逻辑奥秘,让这把多功能瑞士军刀尽情发挥其作用,需要的朋友可以参考一下
    2021-09-09
  • C语言中socket相关网络编程函数小结

    C语言中socket相关网络编程函数小结

    这篇文章主要介绍了C语言中socket相关网络编程函数小结,是C语言入门学习中的基础知识,需要的朋友可以参考下
    2015-09-09
  • C++非递归建立二叉树实例

    C++非递归建立二叉树实例

    这篇文章主要介绍了C++非递归建立二叉树的方法,实例分析了二叉树的原理与C++实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-04-04
  • Qt定时器(QTimer)的3种使用方法

    Qt定时器(QTimer)的3种使用方法

    本文主要介绍了Qt定时器(QTimer)的3种使用方法,主要包括QObject类提供的定时器,QTimer类提供的定时器,静态的singleShot ()函数创建单触发定时器,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • C语言的函数概念与规则你了解吗

    C语言的函数概念与规则你了解吗

    这篇文章主要介绍了C语言中的函数概念与规则,本文给大家介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下,希望能给你带来帮助
    2021-08-08
  • C语言扫雷详细代码分步实现流程

    C语言扫雷详细代码分步实现流程

    扫雷是电脑上很经典的游戏,特意去网上玩了一会,几次调试之后,发现这个比三子棋要复杂一些,尤其是空白展开算法上和堵截玩家有的一拼,与实际游戏差别较大,不能使用光标,下面来详解每一步分析
    2022-02-02
  • C++实现二叉树非递归遍历算法详解

    C++实现二叉树非递归遍历算法详解

    在C++中,二叉树非递归遍历是一种常用的算法,可避免递归过程中的系统开销和栈溢出问题。非递归遍历算法利用栈数据结构实现,可以实现前序、中序和后序遍历,是C++程序员必备技能之一
    2023-04-04
  • C语言常见的文件操作函数

    C语言常见的文件操作函数

    这篇文章主要为大家介绍了C语言文件操作函数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • Visual Studio2022的完全卸载及安装到D盘的操作方法

    Visual Studio2022的完全卸载及安装到D盘的操作方法

    这篇文章主要介绍了Visual Studio2022的完全卸载以及完全安装到D盘,因为VS如果随便写在会有很多很多的乱七八糟的东西掉出来,所以我们选择制式一点的卸载方式,需要的朋友可以参考下
    2022-09-09
  • QT中对Mat类的一些操作详解

    QT中对Mat类的一些操作详解

    本文主要介绍了QT中对Mat类的一些操作详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06

最新评论