【C++经典例题】反转字符串中单词的字符顺序:两种实现方法详解

【C++经典例题】反转字符串中单词的字符顺序:两种实现方法详解
           💓 博客主页:倔强的石头的ZEEKLOG主页 

           📝Gitee主页:
倔强的石头的gitee主页

            ⏩ 文章专栏:C++经典例题

                                  期待您的关注

 

目录

问题描述

基于快慢指针的解法

基于索引的解法

两种方法的比较


 

问题描述

在处理字符串相关的问题时,反转字符串中每个单词的字符顺序是一个常见的任务,同时要保证空格和单词的初始顺序不变。

 

给定一个字符串 s ,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。

  • s 包含可打印的 ASCII 字符。
  • s 不包含任何开头或结尾空格。
  • s 里 至少 有一个词。
  • s 中的所有单词都用一个空格隔开。

原题链接:557. 反转字符串中的单词 III - 力扣(LeetCode)

下面我们将详细介绍两种解决该问题的方法,包括其解题思路和具体实现细节。

 


基于快慢指针的解法


1. 解题思路


快慢指针是一种常用的技巧,在本题中,快指针用于遍历字符串,慢指针用于标记每个单词的起始位置。

当快指针遇到空格时,就表示一个单词已经遍历完,此时可以对慢指针到快指针之间的字符进行反转。

遍历完整个字符串后,还需要对最后一个单词进行反转,因为最后一个单词后面没有空格来触发反转操作。同时,这也对只要一个单词的情况进行了处理

 


2. 代码实现

class Solution { public: string reverseWords(string s) //快慢指针解法 { string::iterator fast = s.begin(); string::iterator slow = s.begin(); while( fast != s.end() )//快指针走完就结束 { if(*fast==' ') //快指针走到空格位置停下,反转该部分字母 { reverse(slow,fast); slow = fast+1; } ++fast; } reverse(slow,fast);//出循环时,慢指针留在最后一个单词的第一个字母 //快指针在\0位置,还需要反转一次 //同时可以对只要一个单词的string处理 return s; } };


3. 代码细节分析

  • 指针初始化:首先定义了快指针 fast 和慢指针 slow,并将它们都初始化为字符串 s 的起始位置 s.begin()。
  • 遍历字符串:通过 while 循环,只要快指针 fast 没有到达字符串末尾 s.end(),就继续循环。
  • 单词反转:当快指针 fast 指向的字符为空格时,说明一个单词已经遍历完,此时调用 reverse 函数将慢指针 slow 到快指针 fast 之间的字符进行反转。然后将慢指针 slow 移动到下一个单词的起始位置,即 fast + 1。
  • 最后一个单词处理:循环结束后,慢指针 slow 停留在最后一个单词的起始位置,快指针 fast 指向字符串末尾的下一个位置(即 \0 的位置),此时再调用一次 reverse 函数对最后一个单词进行反转。
  • 返回结果:最后返回反转后的字符串 s。

 

基于索引的解法


1. 解题思路

这种方法使用索引来遍历字符串,通过一个变量记录每个单词的起始位置,当遇到空格或者字符串结束时,对当前单词进行反转。


2. 代码实现

#include <iostream> #include <string> #include <algorithm> class Solution { public: string reverseWords(string s) { int start = 0; // 慢指针,标记每个单词的起始位置 for (int end = 0; end <= s.length(); ++end) { // 当遇到空格或者字符串结束时,反转当前单词 if (end == s.length() || s[end] == ' ') { // 反转从 start 到 end - 1 的字符 std::reverse(s.begin() + start, s.begin() + end); // 更新慢指针到下一个单词的起始位置 start = end + 1; } } return s; } };


3. 代码细节分析

  • 起始位置初始化:定义变量 start 来记录每个单词的起始位置,初始化为 0。
  • 遍历字符串:通过 for 循环,使用变量 end 遍历字符串 s,循环条件为 end <= s.length(),这样可以确保在字符串结束时也能处理最后一个单词。
  • 单词反转:当 end 等于字符串的长度 s.length() 或者 s[end] 为空格时,说明一个单词已经遍历完,此时调用 std::reverse 函数将从 s.begin() + start 到 s.begin() + end 的字符进行反转。
  • 更新起始位置:反转完当前单词后,将 start 更新为 end + 1,即下一个单词的起始位置。
  • 返回结果:循环结束后,返回反转后的字符串 s。

 

两种方法的比较

 

  • 时间复杂度:两种方法的时间复杂度都是 O(n),其中 n 是字符串的长度,因为都需要遍历字符串一次,并且每个字符最多被反转一次。
  • 空间复杂度:两种方法的空间复杂度都是 O(1),因为都只使用了常数级的额外空间。
  • 代码可读性:基于索引的方法代码相对更加简洁,使用索引来处理字符串更加直观,而基于快慢指针的方法需要对指针的操作有较好的理解


通过以上两种方法的详细介绍,我们可以根据具体的需求和个人习惯选择合适的方法来解决反转字符串中单词字符顺序的问题。

 

 

 

 

Read more

python,numpy,pandas和matplotlib版本对应关系

下面是Python、NumPy、Pandas、Matplotlib的版本对应关系表(基于官方兼容性文档和实践验证,包含常用Python版本),同时补充了推荐的稳定组合: 常用Python版本对应的库兼容版本 Python版本NumPy兼容版本Pandas兼容版本Matplotlib兼容版本推荐稳定组合示例3.8.x1.19.x ~ 1.21.x1.1.x ~ 1.3.x3.3.x ~ 3.5.xPython3.8 + NumPy1.21.6 + Pandas1.3.5 + Matplotlib3.5.33.9.x1.19.x ~ 1.24.x1.1.x ~ 1.5.x3.3.x

By Ne0inhk
生产Python Docker 镜像选择-Slim 版本(python:3.12-slim)

生产Python Docker 镜像选择-Slim 版本(python:3.12-slim)

生产Python Docker 镜像选择-Slim 版本 制作 Python Docker 镜像的最佳实践 参考链接:https://developer.aliyun.com/article/1436674 结论: 建议使用官方的 python slim 镜像作为基础镜像,Slim 才是主流生产环境的最佳实践。不建议使用 Alpine 作为 Python 的基础镜像。 python:3.12-slim Python 3.12 镜像精简版FROM python:3.12-slim 对于在不断发展的软件部署领域中摸索的开发者和小型企业主来说,选择正确的 [Docker]镜像可能会成就或毁掉您项目的效率。 python 3.12 slim 镜像在极简主义和功能之间提供了引人注目的平衡,使其成为可扩展技术工具和智能业务解决方案的理想基础。 python 3.12

By Ne0inhk
Python 基础语法完全指南:变量、类型、运算符与输入输出(零基础入门)

Python 基础语法完全指南:变量、类型、运算符与输入输出(零基础入门)

🔥草莓熊Lotso:个人主页 ❄️个人专栏: 《C++知识分享》《Linux 入门到实践:零基础也能懂》 ✨生活是默默的坚持,毅力是永久的享受! 🎬 博主简介: 文章目录 * 前言: * 一. 常量与表达式:Python 当计算器使用 * 1.1 核心算术运算符 * 1.2 关键注意点 * 1.3 实际案例:求平均值 * 二. 变量:保存数据的 “容器” * 2.1 变量定义与使用 * 2.2 变量命名规则 * 三. 数据类型:给数据 “分类” * 3.1 四大基础类型 * 3.2类型相关操作: * 四. 注释:给代码 “加说明”

By Ne0inhk
Python高效数据采集实战:基于IPIDEA代理的全方位教程

Python高效数据采集实战:基于IPIDEA代理的全方位教程

在当今数据驱动的时代,网页数据采集是获取行业洞察、支撑业务决策的核心手段。但随着网站IP限制机制升级,IP固定、访问限制等问题频繁出现,导致采集任务中断、数据获取不完整。IPIDEA作为全球领先的企业级代理服务提供商,凭借99.9%可用率的纯净IP资源、亿级并发承载能力及多场景适配优势,成为解决采集难题的关键工具。本文将从环境搭建到实战案例,带您掌握Python+IPIDEA的高效数据采集方案。 一、IPIDEA代理:数据采集的“加速器”与“防护盾” 在开始Python实战前,先了解IPIDEA为何能成为企业级数据采集的首选代理服务——其核心优势完美匹配采集场景的核心需求: 核心优势对数据采集的价值全球1亿级+纯净住宅IP模拟真实用户访问,规避网站对“非住宅IP”的拦截,适用于电商、社媒等场景99.9%IP可用率减少因IP失效导致的采集中断,保障任务连续性,尤其适合大规模、长时间采集任务无限并发请求支持亿级并发承载,可同时发起多线程/多进程采集,大幅提升数据获取效率多类型代理全覆盖动态住宅(自动变更)、静态住宅(长效稳定)、数据中心(高速低延迟)等,适配不同场景安全合规认证

By Ne0inhk