答案:C++中反转字符串常用方法包括std::reverse函数、双指针法、逆序遍历构建新字符串和栈结构模拟。使用std::reverse最简洁高效,适合日常开发;双指针法通过交换首尾字符实现,逻辑清晰,适用于面试场景;逆序遍历创建新字符串保留原串,但占用额外内存;栈结构利用后进先出特性完成反转,有助于理解数据结构应用。根据需求选择合适方法即可。

在C++中反转一个字符串有多种方法,最常见的是使用标准库函数或手动实现。下面介绍几种实用且高效的实现方式。
使用 std::reverse 函数
这是最简单直接的方法,利用
#include
#include iostream>
std::string str = "hello";
std::reverse(str.begin(), str.end());
// 结果: "olleh"
这种方法代码简洁,效率高,推荐日常使用。
双指针法(手动翻转)
通过两个指针从字符串两端向中间靠拢,逐个交换字符:
立即学习“C++免费学习笔记(深入)”;
void reverseString(std::string& s) {int left = 0;
int right = s.length() - 1;
while (left std::swap(s[left], s[right]);
left++;
right--;
}
}
这种方式不依赖额外库函数,适合学习算法逻辑或面试场景。
构建新字符串(逆序遍历)
从原字符串末尾开始遍历,逐个添加到新字符串中:
std::string reverseString(const std::string& s) {std::string reversed;
for (int i = s.length() - 1; i >= 0; --i) {
reversed += s[i];
}
return reversed;
}
逻辑清晰,但会额外占用内存,适用于需要保留原字符串的场景。
使用栈结构模拟反转
利用栈“后进先出”的特性实现反转:
#includestd::string reverseWithStack(const std::string& s) {
std::stack
for (char c : s) {
stk.push(c);
}
std::string result;
while (!stk.empty()) {
result += stk.top();
stk.pop();
}
return result;
}
虽然不如前几种高效,但有助于理解数据结构的应用。
基本上就这些常用方法。日常开发推荐用 std::reverse,面试或教学可展示双指针或栈的方式。每种方法都能正确反转字符串,选择取决于具体需求和上下文。











