【LeetCode刷题笔记】344.反转字符串

发布时间:2024年01月05日

创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下?>𖥦<)!!
主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!
更多算法知识专栏:算法分析🔥
给大家跳段街舞感谢支持!? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?

在这里插入图片描述
LeetCode题解专栏:【LeetCode刷题笔记】


题目链接

LeetCode 344.反转字符串

一、题目描述

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须[原地]修改输入数组、使用 O(1) 的额外空间解决这一问题。

二、示例

示例 1:
输入:s = [“h”,“e”,“l”,“l”,“o”]
输出:[“o”,“l”,“l”,“e”,“h”]

示例 2:
输入:s = [“H”,“a”,“n”,“n”,“a”,“h”]
输出:[“h”,“a”,“n”,“n”,“a”,“H”]

三、题目分析

使用双指针的思想,令一个指针指向字符串开头(字符串可以看作字符数组,开头即s[0])

另一个指针指向字符串结尾,循环控制两个指针指向的字符进行交换,直到左指针超过右指针为止,此时各个字符完成了前后交换

image.png
image.png

四、代码实现(C)

void reverseString(char* s, int sSize) {
    if(s == NULL||sSize <= 0)return;
    int pLeft = 0;
    int pRight = sSize - 1;
    while(pLeft < pRight)
    {
        s[pLeft] = s[pLeft]^s[pRight];
        s[pRight] = s[pLeft]^s[pRight];
        s[pLeft] = s[pLeft]^s[pRight];
        pLeft++;
        pRight--;
    }
}

image.png


在这里插入图片描述

大家的点赞、收藏、关注将是我更新的最大动力! 欢迎留言或私信建议或问题。
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容!
如果本文哪里有错误的地方还请大家多多指出(●'?'●)
文章来源:https://blog.csdn.net/TiSg0/article/details/135417487
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。