C 语言

关注公众号 jb51net

关闭
首页 > 软件编程 > C 语言 > C++反转字符串单词字符顺序

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

作者: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 再逐个单词反转

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

五、总结

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

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

关键函数:

reverse()

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

您可能感兴趣的文章:
阅读全文