C++中反转字符串单词字符顺序的两种方法

 更新时间:2026年03月16日 09:49:07   作者:likuolei  
本文介绍了C++中反转字符串中每个单词字符顺序的两种方法:方法一使用字符串流按单词拆分并反转,方法二使用双指针原地反转,两种方法各有优缺点,适合不同的场景,需要的朋友可以参考下

在 C++ 中,字符串处理是常见的面试与算法练习题。本题目标是:反转字符串中每个单词的字符顺序,但保持单词顺序不变。

示例:

输入:  "Hello World"
输出:  "olleH dlroW"

也就是说:

Hello → olleH
World → dlroW

下面介绍 两种经典实现方法

一、方法一:使用字符串流(stringstream)

利用 将字符串按单词拆分,然后逐个反转。

思路

  1. 使用 stringstream 按空格分割单词
  2. 使用 reverse() 反转单词
  3. 拼接结果字符串

代码实现

#include <iostream>
#include <sstream>
#include <algorithm>
using namespace std;
string reverseWords(string s) {
    stringstream ss(s);
    string word;
    string result;
    while (ss >> word) {
        reverse(word.begin(), word.end());
        result += word + " ";
    }
    result.pop_back();
    return result;
}
int main() {
    string str = "Hello World";
    cout << reverseWords(str) << endl;
    return 0;
}

输出:

olleH dlroW

时间复杂度

O(n)

空间复杂度:

O(n)

优点:

  • 代码简单
  • 可读性好

缺点:

  • 使用额外空间

二、方法二:双指针原地反转

使用 双指针扫描字符串,找到每个单词的范围并进行反转。

思路

  1. 遍历字符串
  2. 找到单词起始位置
  3. 找到单词结束位置
  4. 调用 reverse() 反转

代码实现

#include <iostream>
#include <algorithm>

using namespace std;

string reverseWords(string s) {

    int start = 0;

    for (int i = 0; i <= s.size(); i++) {

        if (i == s.size() || s[i] == ' ') {

            reverse(s.begin() + start, s.begin() + i);

            start = i + 1;
        }
    }

    return s;
}

int main() {

    string str = "Hello World";

    cout << reverseWords(str) << endl;

    return 0;
}

输出:

olleH dlroW

时间复杂度

O(n)

空间复杂度:

O(1)

优点:

  • 原地操作
  • 更节省内存

缺点:

  • 实现稍复杂

三、两种方法对比

方法思路空间复杂度适合场景
stringstream拆分单词再反转O(n)简单实现
双指针原地扫描O(1)面试优化

四、进阶问题(面试常问)

很多面试会继续延伸:

1 反转单词顺序

例如:

"Hello World"
→ "World Hello"

2 去除多余空格

例如:

"  hello   world "
→ "world hello"

3 整个字符串反转 + 单词反转

经典算法:

1 先整体反转
2 再逐个单词反转

该题在很多算法平台都有类似题目,例如:

  • LeetCode

五、总结

反转字符串中单词字符顺序的核心方法:

1️⃣ 使用 字符串流分割单词
2️⃣ 使用 双指针原地反转

关键函数:

reverse()

以上就是C++中反转字符串单词字符顺序的两种方法的详细内容,更多关于C++反转字符串单词字符顺序的资料请关注脚本之家其它相关文章!

相关文章

  • C/C++编程语言中的指针(pointer)你了解吗

    C/C++编程语言中的指针(pointer)你了解吗

    这篇文章主要为大家详细介绍了C/C++编程语言中的指针,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • C++程序内存栈区与堆区模型案例分析

    C++程序内存栈区与堆区模型案例分析

    一直以来总是对这个问题的认识比较朦胧,我相信很多朋友也是这样的,总是听到内存一会在栈上分配,一会又在堆上分配,那么它们之间到底是怎么的区别呢,让我们一起来看看
    2022-03-03
  • QT编写tcp通信工具(Server端)

    QT编写tcp通信工具(Server端)

    这篇文章主要为大家详细介绍了QT编写tcp通信工具,一个类似网上常见的网络调试工具,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C++ vector数组用法及解析

    C++ vector数组用法及解析

    这篇文章主要给大家分享的是C++ vector数组用法及解析,什么是什么是vector数组呢?下面文章将对打家做详细介绍,感兴趣的小伙伴可以参考一下
    2021-10-10
  • C++如何调用opencv完成运动目标捕捉详解

    C++如何调用opencv完成运动目标捕捉详解

    OpenCV作为机器视觉开源库,使用起来非常不错,这篇文章主要给大家介绍了关于C++如何调用opencv完成运动目标捕捉的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • 浅谈VC++中的内联

    浅谈VC++中的内联

    在 Visual C++ 中使用内联汇编 一、内联汇编的优缺点 因为在Visual C++中使用内联汇编不需要额外的编译器和联接器,且可以处理Visual C++ 中不能处理的一些事情,而且可以使用在 C/C++中的变量,所以非常方便。
    2015-07-07
  • C语言用封装方法实现飞机大战游戏

    C语言用封装方法实现飞机大战游戏

    这篇文章主要为大家详细介绍了C语言用封装方法实现飞机大战游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • C语言数组学习之特殊矩阵的压缩存储

    C语言数组学习之特殊矩阵的压缩存储

    矩阵在计算机图形学、工程计算中都占有举足轻重的地位,本文将讨论如何将矩阵更有效地存储在内存中,并且能够方便地提取矩阵中的元素。感兴趣的同学可以了解一下
    2021-12-12
  • C++ 数据结构实现两个栈实现一个队列

    C++ 数据结构实现两个栈实现一个队列

    这篇文章主要介绍了详解C++ 数据结构实现两个栈实现一个队列的相关资料,需要的朋友可以参考下
    2017-03-03
  • C++中unordered_set哈希集合的实现

    C++中unordered_set哈希集合的实现

    std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unordered_set的使用,感兴趣的可以了解一下
    2025-11-11

最新评论