算法--双指针2

目录

前言

解题

分析


前言

OK啊,各位,我又来给你们分享我的算法了,今天依旧是双指针算法。这一章是关于字符串的处理的双指针。下面是题目

345. 反转字符串中的元音字母 - 力扣(LeetCode)


解题

如果想直接编写的,可以直接在自己的编译器中编程序了,题目我放这里了。然后说一下我框的这几个。首先,我看的是有点懵的。仔细想一想,他的意思就是说,我们要找出一个字符串中的元音字母,然后翻转就好了。

那么 好,我们应该怎么实现呢?我可以像上次一样,定义两个变量,然后去找有那些元音字母

python 复制代码
left = 0
right = len(s) - 1
while left <= right:

OK,那下面我们应该怎么写呢?因为我们主要针对的就是元音字母对不对,所以我的left和right指针应该指向的是元音字符,所以我们要移动他们到对应的位置。

python 复制代码
left = 0
right = len(s) - 1
while left <= right:
    if s[left] not in 'aeiouAEIOU':
        left += 1
        continue
    if s[right] not in 'aeiouAEIOU':
        right -= 1
        continue

是吧,这样我们就可以交换了,但是我们发现这个是字符串我们是无法直接交换的,因为他是不可变变量,所以我们可以把它转成list。即s = list(s)。这样我们就可以直接交换了。

OK,下面展示完整的代码

python 复制代码
class Solution:
    def reverseVowels(self, s: str) -> str:
        word = list(s)
        left = 0
        right = len(s) - 1
        while left <= right:
            if word[left] not in 'aeiouAEIOU':
                left += 1
                continue
            if word[right] not in 'aeiouAEIOU':
                right -= 1
                continue
            word[left], word[right] = word[right], word[left]
            left += 1
            right -= 1
        return ''.join(word)
            
            

那么OK,这个题目我们就解决了,我们真是太棒了。

分析

来说一下问题哈,首先为什么要使用到双指针,使用别的方法不行吗?答案是,双指针不是唯一答案但是他是最优的答案。你们如果想的话,是可以这样的,就额外开空间,找出所有元音字母的位置,并要把值给带出来,建议使用字典,然后创建一个ans数组,先填充不变的字母,如果遇到事元音字母的位置你就去你创建的字典哪里查找,并填入位置为最后面的元音字母,就是倒着填入

有点麻烦,所以我没有写,如果想锻炼自己的编程,可以去试一下

然后就是这里,为什么我中间要使用if和continue,而不是直接使用while。使用while不是更快更简洁吗?嗯,没错,可以使用到while,但是如果要使用到while的话,就要考虑到更多的因数了,不太建议新手去使用,但是我建议新手去学习。

为什么这么说,首先,你的while语句,很明确的说明了,你的left或者right指针要指向对应的值,那我问你,如果你直接使用while而不去考虑边界的话,会出现什么情况?会出现left>right。那么这里就已经违反了题目了。而且如果你不设置它的left和right的区域的话,还会执行出错

python 复制代码
class Solution:
    def reverseVowels(self, s: str) -> str:
        word = list(s)
        left = 0
        right = len(s) - 1
        while left <= right:
            while left < len(s) and word[left] not in 'aeiouAEIOU':
                left += 1    
            while right > 0 and word[right] not in 'aeiouAEIOU':
                right -= 1
            if left <= right:
                word[left], word[right] = word[right], word[left]
                left += 1
                right -= 1
            else:
                break
        return ''.join(word)

那,这个就是while的写法,所以有有点麻烦,但是新手确实应该去掌握。最后的if-else呢就是一个剪枝,因为left>right的话就已经不合法了。(没有上面执行效率高)但也值得学习。有不懂的可以问,谢谢大家观看^v^

相关推荐
会员源码网35 分钟前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing1 小时前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader2 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱5 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng8976 小时前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮18 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员1 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish1 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱1 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者2 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶