如何用双指针法解决力扣“反转单词前缀”问题

本篇博客会讲解力扣"2000. 反转单词前缀"的解题思路,这是题目链接

本题的思路是:先调用strchr函数,在字符串word中查找字符ch,若找到了,则会返回一个非空指针p,指向ch在word中的位置。为了反转从word到ch的所有字符,我们可以使用双指针法。我们让left和right分别指向word和p,然后交换它们指向的字符,再让它们从两端向中间移动,直到相遇为止。

c 复制代码
inline void reverse(char* left, char* right)
{
    while (left < right)
    {
        char tmp = *left;
        *left = *right;
        *right = tmp;
        ++left;
        --right;
    }
}

char * reversePrefix(char * word, char ch){
    // 在word里查找ch
    char* p = strchr(word, ch);
    if (p)
    {
        // 反转word到p的字符
        reverse(word, p);
    }

    return word;
}

总结

本题的核心技巧是双指针法,它能高效地反转字符串。具体做法是,让两个指针分别从字符串的两端向中间靠拢,每次交换它们所指向的字符,直到相遇为止。

感谢大家的阅读!

相关推荐
0xDevNull26 分钟前
Java反射机制深度解析:从原理到实战
java·开发语言·后端
小小亮0129 分钟前
Next.js基础
开发语言·前端·javascript
ALex_zry39 分钟前
C++网络编程心跳机制与连接保活:长连接稳定性保障
开发语言·网络·c++
Amumu121381 小时前
Js:正则表达式(二)
开发语言·javascript·正则表达式
米粒11 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Sgf2272 小时前
ES8(ES2017)新特性完整指南
开发语言·javascript·ecmascript
好大哥呀2 小时前
C++ Web 编程
开发语言·前端·c++
ID_180079054732 小时前
小红书笔记评论 API,Python 调用示例与完整 JSON 返回参考
java·开发语言
Fuxiao___2 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
Mr_Xuhhh3 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法