在C++中,反转一个字符串中的单词(单词之间通过空格分隔,但单词内部保持原有顺序)可以通过以下步骤实现:
- 找到字符串中的所有单词,这可以通过查找空格来实现。
- 将单词存储在一个容器中(例如
std::vector
)。 - 反转容器中单词的顺序。
- 重新构建字符串,将反转后的单词顺序拼接起来。
以下是实现这一功能的示例代码:
#include <iostream>
#include <vector>
#include <sstream>std::string reverseWords(const std::string& input) {std::vector<std::string> words;std::string word;std::istringstream iss(input);// 按空格分割字符串,存储单词while (iss >> word) {words.push_back(word);}// 反转单词的顺序std::reverse(words.begin(), words.end());// 重新构建字符串std::string reversed;for (size_t i = 0; i < words.size(); ++i) {if (i > 0) {reversed += " "; // 在单词之间添加空格}reversed += words[i];}return reversed;
}int main() {std::string text = "Hello World This is a Test";std::string reversedText = reverseWords(text);std::cout << "Original: " << text << std::endl;std::cout << "Reversed: " << reversedText << std::endl;return 0;
}
在这个示例中,我们使用 std::istringstream
来分割输入字符串 input
为单词,并使用 std::vector<std::string>
来存储这些单词。然后我们使用 std::reverse
函数来反转单词的顺序。最后,我们遍历反转后的单词容器,将单词按照反转后的顺序拼接成一个新的字符串,并在单词之间添加空格。
这种方法确保了每个单词内部的字符顺序保持不变,只是单词在整个字符串中的位置被反转了。