答案:c++中字符串反转常用方法包括std::reverse函数、双指针法、栈结构和递归。使用std::reverse最简便,#include <algorithm>后调用reverse(str.begin(), str.end())即可原地反转;手动双指针通过left和right索引从两端向中间交换字符,适合理解算法原理;利用栈的后进先出特性,将字符逐个入栈再出栈拼接成反转字符串;递归方式则通过函数调用栈实现逆序输出,适用于小字符串或教学场景。日常推荐std::reverse,学习时可尝试其他方法掌握底层逻辑。

在C++中实现字符串反转有多种方法,既可以用标准库函数快速完成,也可以手动编写逻辑来掌握底层原理。下面介绍几种常用且实用的方式。
使用std::reverse函数(最简单)
最直接的方法是使用algorithm头文件中的std::reverse函数,它能对字符数组或std::String进行原地反转。
示例代码:
#include <algorithm>
#include <string>
#include <iostream>
int main() {
std::string str = “hello”;
std::reverse(str.begin(), str.end());
std::cout << str << std::endl; // 输出: olleh
return 0;
}
手动双指针反转(理解原理)
通过两个指针分别指向字符串首尾,逐步向中间移动并交换字符,适合学习算法思想。
立即学习“C++免费学习笔记(深入)”;
实现方式:
- 定义左索引从0开始,右索引从Length-1开始
- 当左小于右时,交换对应字符并移动指针
- 直到两指针相遇
代码示例:
#include <string>
#include <iostream>
void reverseString(std::string& s) {
int left = 0;
int right = s.length() – 1;
while (left < right) {
std::swap(s[left], s[right]);
left++;
right–;
}
}
int main() {
std::string str = “world”;
reverseString(str);
std::cout << str << std::endl; // 输出: dlrow
return 0;
}
利用栈结构实现反转(辅助空间法)
利用栈“后进先出”的特性,将字符依次压入再弹出,自然形成反转顺序。
适用场景:理解数据结构应用,或处理需要缓存字符的复杂逻辑。
#include <stack>
#include <string>
#include <iostream>
std::string reverseWithStack(const std::string& str) {
std::stack<char> stk;
for (char c : str) {
stk.push(c);
}
std::string result;
while (!stk.empty()) {
result += stk.top();
stk.pop();
}
return result;
}
递归方式反转(练习思维)
递归方法不改变原字符串,而是通过函数调用栈实现逆序输出或构建新字符串。
注意:深度较大时可能引发栈溢出,仅建议用于教学或小字符串。
void reverseRecursively(const std::string& s, int index) {
if (index == s.length()) return;
reverseRecursively(s, index + 1);
std::cout << s[index];
}
基本上就这些常见的C++字符串反转方法。日常开发推荐使用std::reverse,简洁高效;学习阶段可尝试其他方式加深理解。不复杂但容易忽略细节,比如边界判断和引用传参。


