创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下?>𖥦<)!!
主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!
更多算法知识专栏:算法分析🔥
给大家跳段街舞感谢支持!? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
LeetCode题解专栏:【LeetCode刷题笔记】
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 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])
另一个指针指向字符串结尾,循环控制两个指针指向的字符进行交换,直到左指针超过右指针为止,此时各个字符完成了前后交换
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--;
}
}
大家的点赞、收藏、关注将是我更新的最大动力! 欢迎留言或私信建议或问题。 |
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容! |
如果本文哪里有错误的地方还请大家多多指出(●'?'●) |