数据结构:反转字符串(Reversing a String)

目录

方法一:双指针法

方法二:辅助数组

方法对比总结:


问题定义

给定一个字符串,例如:

cpp 复制代码
char str[] = "hello";

我们的目标是把它反转成:

cpp 复制代码
"olleh"

📌 输入特点:

  • 字符串用 char 数组表示(C风格字符串)

  • 最后一个字符是 '\0'(空字符),表示字符串结束

(可以参考类似问题:数据结构:数组:反转数组(Reverse the Array)-CSDN博客

方法一:双指针法

🧠 思路讲解:双指针对换法

我们从字符串两端出发,交换字符:

  1. 指针 left 指向开头(索引 0)

  2. 指针 right 指向结尾(索引为 length - 1,排除 '\0'

逐步交换:

  • str[left] ↔ str[right]

  • 然后 left++, right--

  • 重复,直到 left >= right

代码实现

Step 1:计算字符串长度(不包括 '\0'

cpp 复制代码
int len = 0;
while (str[len] != '\0') {
    len++;
}

Step 2:初始化左右指针

cpp 复制代码
int left = 0;
int right = len - 1;

Step 3:循环交换字符

cpp 复制代码
while (left < right) {
    char temp = str[left];
    str[left] = str[right];
    str[right] = temp;

    left++;
    right--;
}

完整代码实现

cpp 复制代码
#include <iostream>
using namespace std;

void reverseString(char str[]) {
    // 计算长度
    int len = 0;
    while (str[len] != '\0') {
        len++;
    }

    // 双指针交换字符
    int left = 0;
    int right = len - 1;

    while (left < right) {
        char temp = str[left];
        str[left] = str[right];
        str[right] = temp;

        left++;
        right--;
    }
}

int main() {
    char str[] = "hello";
    cout << "原字符串: " << str << endl;

    reverseString(str);

    cout << "反转后: " << str << endl;

    return 0;
}

示例演示

字符串 "hello"

Left Right str[left] str[right] After swap
0 4 'h' 'o' o e l l h
1 3 'e' 'l' o l l e h
2 2 - - done

结果:"olleh"


方法二:辅助数组

我们使用辅助数组,不直接在原数组中改动。

🧠 思路讲解(辅助数组方法)

  1. 首先求出原字符串长度(不包括 '\0');

  2. 创建一个新数组 rev[],长度为 len + 1,用于存放反转后的字符串;

  3. str[len - 1] 开始,把字符逐个写入 rev[0], rev[1], ..., rev[len - 1]

  4. 最后手动加上 rev[len] = '\0'

  5. rev 再复制回 str,或者直接用 rev 输出。

代码实现

Step 1:求字符串长度

cpp 复制代码
int len = 0;
while (str[len] != '\0') {
    len++;
}

Step 2:创建新数组,反向拷贝字符

cpp 复制代码
char rev[100]; // 足够大

for (int i = 0; i < len; i++) {
    rev[i] = str[len - 1 - i];
}

Step 3:别忘了加终止符号 '\0'

cpp 复制代码
rev[len] = '\0';

Step 4:把 rev 拷贝回原数组

cpp 复制代码
for (int i = 0; i <= len; i++) {
    str[i] = rev[i];
}

完整代码如下

cpp 复制代码
#include <iostream>
using namespace std;

void reverseString(char str[]) {
    // Step 1: 求字符串长度
    int len = 0;
    while (str[len] != '\0') {
        len++;
    }

    // Step 2: 使用辅助数组从后往前复制
    char rev[100]; // 假设最多100个字符
    for (int i = 0; i < len; i++) {
        rev[i] = str[len - 1 - i];
    }

    // Step 3: 添加字符串终止符
    rev[len] = '\0';

    // Step 4: 将 rev 拷贝回原数组 str
    for (int i = 0; i <= len; i++) {
        str[i] = rev[i];
    }
}

int main() {
    char str[] = "hello";
    cout << "原字符串: " << str << endl;

    reverseString(str);

    cout << "反转后: " << str << endl;

    return 0;
}

方法对比总结:

方法 说明 时间复杂度 空间复杂度
方法①:原地交换 左右指针交换 O(n) O(1)
方法②:辅助数组 用新数组逆序写入 O(n) O(n)
相关推荐
深邃-6 分钟前
字符函数和字符串函数(1)
c语言·开发语言·数据结构·c++·算法·html5
我真不是小鱼7 分钟前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
x_xbx15 分钟前
LeetCode:217. 存在重复元素
数据结构·leetcode·哈希算法
漫随流水17 分钟前
c++编程:求阶乘和
数据结构·c++·算法
再卷也是菜19 分钟前
算法基础篇(13)单调栈
数据结构·c++
旺仔.2911 小时前
STL排序算法详解
数据结构·算法·排序算法
DowneyJoy2 小时前
【Unity3D补充知识点】常用数据结构分析-集合(List<T>)
数据结构·unity·c#·list
计算机安禾2 小时前
【数据结构与算法】第16篇:串(String)的定长顺序存储与朴素模式匹配
c语言·数据结构·c++·学习·算法·visual studio code·visual studio
2401_827499992 小时前
python核心语法01-数据存储与运算
java·数据结构·python
副露のmagic2 小时前
链表章节 leetcode 思路&实现
数据结构·leetcode·链表